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 63
공지 SQLGate for CUBRID 영구 무료 라이선스 제공 file admin 2020.04.09 4464
539 window server 2016 지원 여부 문의 1 동훈이 2020.04.06 123
538 CUBRID에서 node.js Sequelize 적용 가능한가요? 1 prayccc 2021.11.11 123
537 CUBRID Manager 호스트 삭제 문의 1 ohgeumjin 2020.06.29 123
536 요청하신 내용 올려드립니다. 4 file Philip Park 2020.03.26 123
535 함수/프로시져 구동시 필요한 java버젼 1 네오랜덤 2023.03.31 123
534 Java Maven Repository 2 내멋으로 2023.11.16 123
533 시스템 카탈로그 조회 외 1 f0081 2023.11.01 123
532 부여된 권한조회 1 준88 2022.09.15 122
531 db생성경로가 db테이블과 결과조회에 영향을 미치나요? 1 dfdfdd 2023.03.15 122
530 DB 데이터 이전 관련 3 별린 2023.11.20 121
529 문의드립니다. 1 어려워 2019.04.25 120
528 Redhat 8버전 tls 1.0 에러 9 11시38분 2024.01.30 120
527 DB서버 에러로그 1 file leeee 2023.12.27 120
526 가로 데이터 세로로 조회 6 Ggyak 2023.10.18 120
525 안드로이드 개발 중, 큐브리드 접속 시 VerifyError가 출력되며 에뮬레이터가 종료되어버립니다. 2 롤롤 2021.04.19 120
524 호스트 연결이 무한 로딩도네요 1 file 큐브리드사용자 2022.10.20 120
523 타 큐브리드 db에 insert 하려면.. 1 백수인 2022.10.28 120
522 select 질의문 문의 2 태리 2024.02.26 120
521 Cannot allocate query entry any more. Maximum allocatable entries are 100. 4 jslee 2022.02.21 119
520 cubrid admin 질문 드립니다. 3 file 초코초코초 2023.03.06 119
Board Pagination Prev 1 ... 169 170 171 172 173 174 175 176 177 178 ... 200 Next
/ 200

Contact Cubrid

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