Background Image

FORUM

조회 수 123 추천 수 0 댓글 8
?

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 댓글로 가기 인쇄 첨부


* 질문 등록 시 다음의 내용을 꼭 기입하여 주세요.

OS
Windows 10 pro 64 bit
CUBRID Ver.
CUBRID 9.3 (9.3.9.0002) (64bit release build for linux_gnu) (Aug  4 2017 11:55:22)
CUBRID TOOL Ver.
[도움말]-[버전정보] 확인
응용 환경(API)
php 5.6.40 64 bit


* CUBRID 응용 오류, SQL 오류 또는 SQL 튜닝 관련된 문의는 반드시 다음의 내용을 추가해 주세요. 비밀글이나 비밀 댓글도 가능합니다.
* 저희가 상황을 이해하고, 재현이 가능해야 알 수 있는 문제들이 많습니다. 가능한 정보/정황들을 부탁합니다.

 

에러 내용 및 재현 방법 재현 가능한 Source와 SQL
관련 테이블(인덱스, 키정보 포함) 정보 CUBRID 홈 디렉토리 아래 log 디렉토리 압축


-------------- 아래에 질문 사항을 기입해 주세요. ------------------------------------------------------------------------
 

안녕하세요 php 개발환경 세팅 중 문의 드립니다.(이번에 맡은 사이트 때문에 php를 하게 된 java 개발자입니다.)

 

현재 제가 작업한 히스토리를 말씀 드립니다.

 

로컬 서버 환경 : xampp-windows-x64-5.6.40-1-VC11-installer.exe 설치 후 세팅(apache, php)

 

php VC11과 cubrid VC11로 통일

 

1. cubrid관련 .dll파일 다운로드 후 php ext경로로 이동, php.ini에서 해당 dll파일 읽을 수 있도록 설정 추가 후 phpinfo()에서도 cubrid 관련 모듈을 읽는 것 확인(첨부파일1.png)

첨부파일1.png

 

 

2. php - cubrid db 연결 테스트(첨부파일2.png)

첨부파일2.png

 

이 때 첨부파일2.png에서 사용한 코드는 $db =new PDO($conn_str, $username, $password ); 이렇게 PDO 객체를 이용했습니다.

PDO 객체를 이용한 cubrid 연결 테스트는 성공 했으나 기존 유지보수 사이트는 cubrid_connect(host, port, db); 이 함수를 이용해서 db 연결을 했습니다.

그런데 지금 에디터에서 테스트 코드를 작성해 봤는데(첨부파일3.png) 에디터에서 cubrid_"function" 이 정의되지 않았다고 나옵니다.

첨부파일3.png

 

위 작업처럼 php 설치 후 cubrid관련 dll파일을 php에 추가 설치 후 혹시 추가로 작업해 줘야 될 것이 있나요?

제가 어떤 부분을 확인해 보면 될까요?

 

https://www.cubrid.com/qna/3800018

위 글도 참조해서 아래처럼 cci도 추가로 설정 해 봤으나 여전히 안되네요.

https://www.cubrid.com/downloads > CCI > CCI Driver - CUBRID 10.2, CCI Driver - CUBRID 11.0 Windows 64 bit로 다운로드 후 apache\bin, System32에 넣은 후 apache 재시작

혹시 첨부파일1png에서 pdo_cubrid의 Client API version과 CCI Version이 달라서 그럴 수도 있을까요?

 

도움 부탁 드립니다 감사합니다.

  • ?
    김병욱 2022.04.21 11:16

    php.ini 파일에서 php_cubrid.dll이 설치된 extension directory를 설정해 주셨는지요?

     

    ex) php.ini

    ...

    extension_dir = "D:\Work\PHP\CUBRID"

    extension=php_cubrid.dll

    ...
     

  • ?
    devlsy 2022.04.21 12:47

    extension_dir="C:\xampp\php\ext"
    이렇게 php.ini에 설정 되어 있습니다.
  • ?
    김병욱 2022.04.21 13:41

    현재, 에러 메시지로 보면 php function을 인식하지 못하고 있는 것 같습니다.

    혹시 php.ini 에 short_open_tag 가 "1"로 세팅되어 있는지요?
    보통 디폴트로 short_open_tag는 "1"이 맞습니다만, 혹시 세팅이 되어 있는지 확인 부탁드립니다.
    그리고 <?php 처럼 tag를 사용해서 동작되는지 확인 부탁드리고,

    아래와 같이 extension이 load되었는지도 확인해 보세요.

     

    <?php
    if (!extension_loaded("CUBRID")) {
        die('skip CUBRID extension not available');
    }

    ?>
     

  • ?
    devlsy 2022.04.21 14:01

    먼저 답변 감사드립니다.

    현재 php.ini "short_open_tag=On"으로 되어 있습니다.
    xampp 최초 설치 후 기본값은 "Off" 였는데 "On"으로 변경했습니다.

    방금 테스트 차 php를 아래처럼 <?php ?> 태그로 만들어서 테스트 했는데 여전히 Undefined function 'cubrid_connect'.가 발생합니다.

    <?php
    $con = cubrid_connect("xx.x.x.xxx", 33000, "xxx");
    if($con) {
    $req = cubrid_execute($con, "select * from xxx");
    if($req) {
    while ($row = cubrid_fetch($req)) {
    echo $row["s_name"];
    echo $row["f_name"];
    }
    cubrid_close_request($req);
    }
    cubrid_disconnect($con);
    }
    ?>

     

    -------------------------------------------------------------------------------------------------------------------------------------------

     

    아래처럼 추가 해주신 내용도 테스트 해봤는데 

    <?php

    if (!extension_loaded("CUBRID")) {

        die('skip CUBRID extension not available');

    }

    ?>

     

    "skip CUBRID extension not available" 이렇게 표시가 됩니다.

    cubrid 확장이 제대로 세팅이 안된걸까요?

  • ?
    김병욱 2022.04.21 14:29
    cubrid php driver는 2개의 버전이 있습니다. TS (Thread Safe)와 NTS (Non Thread Safe)
    현재 설치되어 있는 PHP가 TS 버전이면 driver도 TS 버전으로 설치해야 하고, PHP가 NTS이면 driver도 NTS 버전으로 설치해야 합니다.

    php -version

    위 command로 확인해 볼 수 있습니다.
  • ?
    devlsy 2022.04.21 14:52

    php -version 결과 아래처럼 표시됩니다.

    PHP 5.6.40 (cli) (built: Jan 9 2019 15:12:06)
    Copyright (c) 1997-2016 The PHP Group
    Zend Engine v2.6.0, Copyright (c) 1998-2016 Zend Technologies

     

    그리고 phpinfo()에서 봤을 때 

    Zend Extension Build : API220131226,TS,VC11

    PHP Extension Build : API20131226,TS,VC11

    로 표시되는 걸로 보아 TS인걸로 추정이 됩니다.

     

    지금 xampp 5.6 32bit로 다운 받아서 다시 테스트 중인데
    php는 TS(Thread Safe)로 다운 받았습니다.

    더 테스트 해보겠습니다.

    여기서 제가 궁금한 점은 제가 위에서 한 작업대로만 하면 cubrid_connect()가 정상적으로 호출이 되어야 된다는 말씀이신가요?
    별다른 추가 작업이 필요 없나요?

  • ?
    김병욱 2022.04.21 14:57
    https://ftp.cubrid.org/CUBRID_Drivers/PHP_Driver/9.3.0/Windows

    위 사이트에 보면, Windows PHP 5.x 버전이 다양하게 있습니다.
    32비트, 64비트, 그리고 TS, NTS로 구분되어 있습니다.
    설치된 php에 맞춰서 driver도 다운 받아 설정하면 됩니다.
  • ?
    devlsy 2022.04.21 16:49
    답변 감사합니다.
    방금 VC14에 맞춰서 php 7.1버전에 맞춰서 테스트 했더니 잘 됩니다.
    이 걸 토대로 잘 마무리 해 보겠습니다.

List of Articles
번호 제목 글쓴이 날짜 조회 수
공지 CUBRID 사용자를 위한 DBeaver 도구 출시 안내 admin 2024.04.23 48
공지 SQLGate for CUBRID 영구 무료 라이선스 제공 file admin 2020.04.09 4458
394 sqlgate에서 프로시저 실행시 에러 3 밍아 2022.04.07 272
393 DB backup 시 문제가 발생합니다. 4 samsam 2022.04.13 126
392 INITCAP함수 대체 1 suyeon 2022.04.13 82
391 cubrid 성능 개선 1 디어사이드 2022.04.15 133
390 큐브리드 (java - 전자정부프레임워크 - 마이바티스) 연동 에러 1 file 백수인 2022.04.15 391
389 자바 배치 쉘 수행시 큐브리드 이중화 설정 1 jeinhe 2022.04.18 79
» Windows 10 php 5.6 Call to undefined function cubrid_connect() 에러 문의 8 file devlsy 2022.04.21 123
387 당혹스럽습니다. 쿼리문으로 만들어진 테이블이 있는데 삭제도 안됩니다. 7 file 눈물색 2022.04.21 424
386 php cubrid_driver 설치 에러 1 jslee 2022.04.23 299
385 php 7.4 접속 에러 16 file jslee 2022.04.27 171
384 cubrid acl reload 에러 1 hiDev 2022.04.29 63
383 Cubrid HA 구성서버 중, Slave에서 restoreslave 동작시 오류 관련하여 문의드립니다. 1 큐브짱 2022.05.02 134
382 nodejs와 cubrid 서버와 연동 (localhost 아닙니다) 7 hiDev 2022.05.02 145
381 Error Number: -17 Internal error: fetching deallocated pageid 16777216 of volume 오류 1 나라디 2022.05.04 574
380 [Cubrid HA] restoreslave 사용할 경우 Master/Slave 경로를 반드시 동일하게 맞춰야하나요? 1 큐브짱 2022.05.06 71
379 큐브리드 SYSDATETIME 문의 드립니다. 1 file 큐브리드궁금 2022.05.06 99
378 c# cubrid -> mssql BLOB type 데이타 전환 1 알고싶다! 2022.05.09 219
377 hb_thread_check_disk_failure 오류 문의 드립니다. 1 큐브짱 2022.05.11 188
376 terminate called after throwing an instance of 'std::bad_alloc' 8 영웅찬 2022.05.11 276
375 날짜 형식 변환 2 밍아 2022.05.11 82
Board Pagination Prev 1 ... 176 177 178 179 180 181 182 183 184 185 ... 200 Next
/ 200

Contact Cubrid

대표전화 070-4077-2110 / 기술문의 070-4077-2113 / 영업문의 070-4077-2112 / Email. contact_at_cubrid.com
Contact Sales