Background Image

FORUM

2010.12.10 22:55

esql 컴파일시 에러

조회 수 9396 추천 수 0 댓글 4
?

단축키

Prev이전 문서

Next다음 문서

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

리눅스에서 큐브리드 사용하는데 초기 컴파일 환경잡고 테이블 insert하려는데 에러가 나네요.

숫자형은 별도의 문자열에 저장후 작업해야된다고 해서 다음과 같이 작업했습니다.

 

        EXEC SQL BEGIN DECLARE SECTION;
                VARCHAR  user_id[16];
                VARCHAR  user_name[40];
                DB_VALUE test_numeric_col;
        EXEC SQL END DECLARE SECTION;

 

        char    numeric_buf[40];

        uci_startup("testdbcon");

        EXEC SQL whenever sqlerror call sql_error;

        
        EXEC SQL CONNECT 'supream' identified by 'dba' with 'data1234';

        
        strcpy(user_id.array, "Hong");
        user_id.length = strlen(user_id.array);

        strcpy(user_name.array, "홍길동");
        user_name.length = strlen(user_name.array);


        strcpy(numeric_buf, "123456.4321");
        db_value_domain_init(&test_numeric_col, DB_TYPE_NUMERIC, 15, 4); 
        db_value_put(&test_numeric_col, DB_TYPE_C_VARCHAR, (void *)numeric_buf, strlen(numeric_buf));


        EXEC SQL insert into oms_user(user_id,user_name, test_numeric_col)
                 values(:user_id, :user_name, :test_numeric_col);

        EXEC SQL commit work;

        EXEC SQL disconnect;

 

이걸 실행하면 다음 에러메세지가 납니다.

TestCubridInput.ec: In function 'int main()':
TestCubridInput.ec:55: error: invalid conversion from 'int' to 'DB_TYPE_C'
TestCubridInput.ec:55: error:   initializing argument 5 of 'void uci_put_value(DB_INDICATOR*, DB_TYPE, int, int, DB_TYPE_C, void*, int)'

 

샘플에 있는거 그대로 같다 했는데 numeric형을 Insert하려니까 에러가 나네요...

참고로 numeric형을 제외한 string형만 Insert했을때는 제대로 돌아갔습니다.

그리고 숫자형(실수형이나 정수형)를 다루려면 문자열변환해서 하는 작업 말고는 바로 입력하는 방법은 있는지요?

  • ?
    janus 2010.12.11 00:15

    제가 테스트한 환경에서는 잘됩니다.

    혹시 샘플문서를 그대로 하셔도 똑같으신지와 제품버전을 알려 주셨으면 합니다.

    제품버전은 cubrid_rel 명령으로 확인이 가능합니다.

     

     

  • ?
    남재우 2010.12.11 00:49

    에러가 발생한곳이 다른 라인인 것 같습니다만... 확인좀 부탁드리겠습니다.

  • ?
    프리스 2010.12.11 01:24 Files첨부 (1)

    제품버전이 아래와 같이 나왔습니다..

    CUBRID 2008 R3.1 (8.3.1.0152) (Nov  4 2010 11:00:35)

     

    보니까

    EXEC SQL insert into oms_user(user_id, user_name, test_numeric_col) values(:user_id, :user_name, :test_numeric_col);

    -> EXEC SQL insert into oms_user(user_id, user_name) values(:user_id, :user_name);

    이렇게 하니까 에러가 우선 안나네요.

    그럼 함수쓰는게 문제가 아니라 insert하는데 type이 안맞아서 에러가 나는걸까요?

    Table에서 test_numeric_col는 nemeric(15,4)로 선언했습니다.

     

    혹시 몰라서 file 첨부했습니다.

  • ?
    janus 2010.12.11 03:10

    첨부파일을 가지고 수행해 봤는데 문제없이 잘됩니다....

    아래는 제가 만든 oms_user 테이블입니다.

     <Attributes>

         user_id              CHARACTER VARYING(16)
         user_name            CHARACTER VARYING(40)
         test_numeric_col     NUMERIC(15,4)

     

     


List of Articles
번호 제목 글쓴이 날짜 조회 수
공지 CUBRID 사용자를 위한 DBeaver 도구 출시 안내 admin 2024.04.23 48
공지 SQLGate for CUBRID 영구 무료 라이선스 제공 file admin 2020.04.09 4458
854 [긴급] 성능 문의 드립니다.... 8 secret 스마트 2011.01.05 31
853 xe의 큐브리드와 mysql의 스키마 구조 확인 요청. 2 스마트 2011.01.04 8614
852 [개선요청] 데이터베이스 복구 문제 개선이 필요할 것 같습니다.. 5 secret 스마트 2011.01.04 49
851 백업 및 복구에 대한 질문 드립니다 3 유니콘 2011.01.04 7478
850 cubrid bigint를 java로 가져오는데 문제가 있네요... 2 반짝이 2011.01.04 22139
849 테이블 정보를 가지고 오는 쿼리를 알고 싶습니다. 1 미스터비니 2011.01.04 9790
848 큐브리드 성능 문의 2 스마트 2011.01.03 9819
847 큐브리드 쿼리문 문의 드립니다. 2 secret 스마트 2011.01.01 12
846 php 5.1.6 연동 문제 3 올닉스 2011.01.01 10228
845 CUBRIDServcie 서비스 시작시 오류 3 통닭 2010.12.30 8632
844 리눅스에서 환경 설정 문의 9 secret 스마트 2010.12.30 11
843 cubrid 2008 r3.0 을 쓰고 있는데요 data table 생성시 대문자로 표시 하는 법 1 Bluecat 2010.12.29 7239
842 [긴급] CMT 오류 문의 드립니다. 7 스마트 2010.12.29 6490
841 broker 로그에 대해 여쭤봅니다. 1 유겸아빠 2010.12.29 6834
840 CMT 관련 문의 드립니다. 2 secret 스마트 2010.12.29 8
839 데이터베이스 추가시 오류 메시지 6 file 종이 2010.12.24 6969
838 큐브리드 호스팅 서비스를 준비중에 있는데요.. 3 큐브리드호스팅 2010.12.23 8033
837 CUBRID 2008 R3.0, R3.1 beta 에서의 PHP 모듈사용에 대한 질문 1 potter 2010.12.23 7159
836 [긴급] odbc utf8 입력이 안됩니다.. 11 스마트 2010.12.23 12409
835 UTF8지원 관련.. 2 스마트 2010.12.21 7750
Board Pagination Prev 1 ... 153 154 155 156 157 158 159 160 161 162 ... 200 Next
/ 200

Contact Cubrid

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