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 125
공지 SQLGate for CUBRID 영구 무료 라이선스 제공 file admin 2020.04.09 4476
3763 테이블 명세서 질문 1 joke7 2014.08.04 8019
3762 테이블 명세서 재 질문 1 joke7 2014.08.08 6609
3761 테이블 명세서 1 secret nenemi 2015.01.28 8
3760 테이블 데이터 삭제 중 오류 발생하여 데이터 베이스 시작이 안됩니다. 2 잡동사니 2011.01.14 11520
3759 테이블 단위 export 2 bchlim 2020.06.16 445
3758 테이블 내 데이터타입 값 변경문제 문의 2 아네모네 2016.03.25 10149
3757 테이블 구성 방안 문의 2 종이 2012.05.01 10621
3756 테이블 가져오기 수행방법 좀 알려주세요 1 file 이야기 2021.09.23 276
3755 테이블 alter 시 오류 메세지 1 김성일컴퍼니 2013.08.06 7268
3754 테이블 Drop 시킨후 컬럼 추가하여 생성시 소팅문제 4 지니보이 2010.07.03 8952
3753 테스트 한 결과 때문에 질문글 올립니다... 2 secret 반짝이 2011.05.24 17
3752 테스트 서버와 운영서버에 COUNT(*) 쿼리 실행 속도 차이 문의 1 종이 2019.12.29 382
3751 타입비교에 대해서 1 daltago87 2010.09.16 8380
3750 타서버의 풀백업 파일을 임포트 하는 방법이 뭔가요? 2 취우다 2017.04.27 6029
3749 타 큐브리드 db에 insert 하려면.. 1 백수인 2022.10.28 120
3748 클라이언트에서 원격지 DB로의 접속이 되지 않습니다... 9 김동진81 2009.10.08 14672
3747 클라이언트 원격지 접속 4 secret 차차오 2015.02.03 12
3746 클라우드 환경에서 데이터베이스 추가 관련 1 디콘플러스 2022.11.29 68
3745 클라우드 환경에서 cubird server 비정상 동작함. 6 맘마마마 2019.04.19 405
3744 큰 자리수 연산 문의 1 초콜릿75 2013.08.01 10163
Board Pagination Prev 1 ... 8 9 10 11 12 13 14 15 16 17 ... 201 Next
/ 201

Contact Cubrid

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