Tibero
|
|
- 명국 당
- 5 years ago
- Views:
Transcription
1 Tibero tbcli 안내서 Tibero 5 Copyright 2013 TIBERO Co., Ltd. All Rights Reserved.
2 Copyright Notice Copyright 2013 TIBERO Co., Ltd. All Rights Reserved. 대한민국경기도성남시분당구서현동 우 ) Restricted Rights Legend All TIBERO Software (Tibero ) and documents are protected by copyright laws and the Protection Act of Computer Programs, and international convention. TIBERO software and documents are made available under the terms of the TIBERO License Agreement and may only be used or copied in accordance with the terms of this agreement. No part of this document may be transmitted, copied, deployed, or reproduced in any form or by any means, electronic, mechanical, or optical, without the prior written consent of TIBERO Co., Ltd. 이소프트웨어 (Tibero ) 사용서의내용과프로그램은저작권법, 컴퓨터프로그램보호법및국제조약에의해서보호받고있습니다. 사용서의내용과여기에된프로그램은 TIBERO Co., Ltd. 와의사용권계약하에서만사용이가능하며, 사용권계약을준수하는경우에만사용또는복제할수있습니다. 이사용서의전부또는일부분을 TIBERO의사전서면동의없이전자, 기계, 녹음등의수단을사용하여전송, 복제, 배포, 2차적저작물작성등의행위를하여서는안됩니다. Trademarks Tibero is a registered trademark of TIBERO Co., Ltd. Other products, titles or services may be registered trademarks of their respective companies. Tibero 는 TIBERO Co., Ltd. 의등록상표입니다. 기타모든제품들과회사이름은각각해당소유주의상표로서참조용으로만사용됩니다. Open Source Software Notice This product includes open source software developed and/or licensed by "OpenSSL," "RSA Data Security, Inc.," "Apache Foundation," "Jean-loup Gailly and Mark Adler," and "Paul Hsieh's hash". Information about the afore mentioned and the related open source software can be found in the "${INSTALL_PATH}/license/oss_licenses" directory. 본제품은 OpenSSL, RSA Data Security, Inc., Apache Foundation 및 Jean-loup Gailly와 Mark Adler 및 Paul Hsieh's hash 에의해개발또는라이선스된오픈소스소프트웨어를포함합니다. 관련상세정보는제품의디렉터리 ${INSTALL_PATH}/license/oss_licenses 에기재된사항을참고해주십시오. 안내서정보안내서제목 : Tibero tbcli 안내서발행일 : 소프트웨어버전 : Tibero 5 안내서버전 : 2.1.4
3 내용목차 안내서에대하여... xi 제1장 tbcli 소개 개요 구성요소 tbcli 핸들 tbcli tbcli 에러메시지 프로그램구조 시작설정부분 SQL 문장실행및에러처리부분 종료설정부분... 8 제2장 데이터타입 Tibero의데이터타입 tbcli의데이터타입 제3장 tbcli SQL-99 표준 API SQLAllocConnect (Deprecated) SQLAllocEnv (Deprecated) SQLAllocHandle SQLAllocStmt (Deprecated) SQLBindCol SQLBindParameter SQLCancel SQLCloseCursor SQLColAttribute SQLColAttributes (Deprecated) SQLColumnPrivileges SQLColumns SQLConnect SQLCopyDesc SQLDescribeCol SQLDescribeParam SQLDisconnect SQLDriverConnect SQLEndTran SQLError (Deprecated) SQLExecDirect SQLExecute SQLExtendedFetch (Deprecated) Tibero iii
4 SQLFetch SQLFetchScroll SQLForeignKeys SQLFreeConnect (Deprecated) SQLFreeEnv (Deprecated) SQLFreeHandle SQLFreeStmt SQLGetConnectAttr SQLGetConnectOption (Deprecated) SQLGetCursorName SQLGetData SQLGetDescField SQLGetDescRec SQLGetDiagField SQLGetDiagRec SQLGetEnvAttr SQLGetFunctions SQLGetInfo SQLGetStmtAttr SQLGetStmtOption (Deprecated) SQLGetTypeInfo SQLMoreResults SQLNativeSql SQLNumParams SQLNumResultCols SQLParamData SQLParamOptions (Deprecated) SQLPrepare SQLPrimaryKeys SQLProcedureColumns SQLProcedures SQLPutData SQLRowCount SQLSetConnectAttr SQLSetConnectOption (Deprecated) SQLSetCursorName SQLSetDescField SQLSetDescRec SQLSetEnvAttr SQLSetParam (Deprecated) SQLSetPos SQLSetScrollOptions (Deprecated) SQLSetStmtAttr iv Tibero tbcli 안내서
5 SQLSetStmtOption (Deprecated) SQLSpecialColumns SQLStatistics SQLTablePrivileges SQLTables SQLTransact (Deprecated) Tibero API SQLAllocEnv2 (Deprecated) SQLAllocHandle SQLLobClose SQLLobGetData SQLLobGetLength SQLLobGetPosition SQLLobOpen SQLLobPutData SQLLobTruncate 제4장 tbcli 에러메시지 반환코드 ~ S00 ~ 01S ~ S ~ S S01 ~ 21S ~ , 24000, S01 ~ 25S , C000 ~ 3F ~ 40003, S01 ~ 42S22, HY000 ~ HY HY090 ~ HY HYC HYT00 ~ HYT IM001 ~ IM , 제5장 tbcli와 ODBC ODBC tbcli와 ODBC의연동 Tibero v
6 Windows 계열에서의설치 UNIX 계열에서의설치 tbdsn.tbr과 ODBC 데이터원본관리자 색인 vi Tibero tbcli 안내서
7 그림목차 [ 그림 1.1] 클라이언트 / 서버환경... 5 [ 그림 1.2] tbcli 프로그램의구조... 5 [ 그림 5.1] Tibero5 ODBC Driver 설치확인 [ 그림 5.2] 사용자 DSN - 추가 [ 그림 5.3] 사용자 DSN - Tibero5 ODBC Driver 선택 [ 그림 5.4] 사용자 DSN - 데이터베이스접속정보입력 (IP, PORT 방식 ) [ 그림 5.5] 사용자 DSN - 데이터베이스접속정보입력 (SID 방식 ) [ 그림 5.6] 사용자 DSN - 등록완료 Tibero vii
8
9 예목차 [ 예 1.1] tbcli 프로그램의시작설정... 6 [ 예 1.2] tbcli 프로그램의 SQL 문장실행 - 직접실행... 7 [ 예 1.3] tbcli 프로그램의 SQL 문장실행 - 준비된실행... 7 [ 예 1.4] tbcli 프로그램의종료설정... 8 [ 예 2.1] DATE_STRUCT, SQL_DATE_STRUCT [ 예 2.2] TIME_STRUCT, SQL_TIME_STRUCT [ 예 2.3] TIME_STAMP_STRUCT, SQL_TIMESTAMP_STRUCT Tibero ix
10
11 안내서에대하여 안내서의대상 본안내서는 Tibero ( 이하 Tibero) 에서제공하는 tbcli의기본개념과프로그램구조등을알고자하는데이터베이스관리자 (Database Administrator, 이하 DBA), 애플리케이션프로그램개발자를대상으로기술한다. 안내서의전제조건 본안내서를원활히이해하기위해서는다음과같은사항을미리알고있어야한다. 데이터베이스의이해 RDBMS 의이해 SQL 의이해 안내서의제한조건 본안내서는 Tibero 를실무에적용하거나운용하는데필요한모든사항을포함하고있지않다. 따라서설 치, 환경설정등운용및관리에대해서는각제품안내서를참고하기바란다. 참고 Tibero 의설치및환경설정에관한내용은 "Tibero 설치안내서 " 를참고한다. 안내서에대하여 xi
12 안내서구성 TiberotbCLI 안내서는총 5개의장으로이루어져있다. 각장의주요내용은다음과같다. 제1장 : tbcli 소개 tbcli의기본개념과구성요소, 프로그램의구조를소개한다. 제 2 장 : 데이터타입 tbcli 프로그램에서사용하는데이터타입을기술한다. 제 3 장 : tbcli tbcli 가지원하는를기술한다. 제 4 장 : tbcli 에러메시지 tbcli 프로그램을실행하는도중에발생할수있는에러를기술한다. 제 5 장 : tbcli 와 ODBC tbcli 와 ODBC 를연동하는방법을기술한다. xii Tibero tbcli 안내서
13 안내서규약 표기 <AaBbCc123> <Ctrl>+C [Button] 진하게 " "( 따옴표 ) ' 입력항목 ' 하이퍼링크 > 참고 의미프로그램소스코드의파일명, 디렉터리 Ctrl과 C를동시에누름 GUI의버튼또는메뉴이름강조다른관련안내서또는안내서내의다른장및절언급화면 UI에서입력항목에대한메일계정, 웹사이트메뉴의진행순서하위디렉터리또는파일있음하위디렉터리또는파일없음참고또는주의사항 [ 그림 1.1] [ 표 1.1] AaBbCc123 그림이름 표이름 명령어, 명령어수행후화면에출력된결과물, 예제코드 { } 필수인수값 안내서에대하여 xiii
14 시스템사용환경 요구사항 Platform HP-UX 11i (PA-RISC, ia64) Solaris (SPARC 9/Solaris 9) AIX (PPC 5L/AIX 5.3) GNU (X86, 64, IA64) Linux kernel 2.6 이상 Windows(x86) 32bit/64bit Hardware 최소 1.5GB 하드디스크공간 512MB 이상메모리공간 Compiler PSM (C99 지원필요 ) tbesql/c (C99 지원필요 ) xiv Tibero tbcli 안내서
15 관련안내서 안내서 Tibero 설치안내서 Tibero 애플리케이션개발자안내서 Tibero External Procedure 안내서 Tibero JDBC 개발자안내서 Tibero tbesql/c 안내서 Tibero tbesql/cobol 안내서 Tibero tbpsm 안내서 Tibero tbpsm 참조안내서 Tibero 관리자안내서 Tibero tbadmin 안내서 Tibero 유틸리티안내서 Tibero 설치시필요한시스템요구사항과설치및제거방법을기술한안내서이다. 각종애플리케이션라이브러리를이용하여애플리케이션프로그램을개발하는방법을기술한안내서이다. External Procedure를소개하고이를생성하고사용하는방법을기술한안내서이다. Tibero에서제공하는 JDBC 기능을이용하여애플리케이션프로그램을개발하는방법을기술한안내서이다. C 프로그래밍언어를사용해데이터베이스작업을수행하는각종애플리케이션프로그램을작성하는방법을기술한안내서이다. COBOL 프로그래밍언어를사용해데이터베이스작업을수행하는각종애플리케이션프로그램을작성하는방법을기술한안내서이다. 저장프로시저모듈인 tbpsm의개념과문법, 구성요소를소개하고, tbpsm 프로그램을작성하는데필요한제어구조, 복합타입, 서브프로그램, 패키지와 SQL 문장을실행하고에러를처리하는방법을기술한안내서이다. 저장프로시저모듈인 tbpsm의패키지를소개하고, 이러한패키지에포함된각프로시저와의프로토타입, 파라미터, 예제등을기술한참조안내서이다. Tibero의동작과주요기능의원활한수행을보장하기위해 DBA가알아야할관리방법을논리적또는물리적측면에서하고, 관리를지원하는각종도구를기술한안내서이다. SQL/PSM 처리와 DBA를위한시스템관리기능을제공하는 GUI 기반의툴인 tbadmin을소개하고, 설치및사용방법을기술한안내서이다. 데이터베이스와관련된작업을수행하기위해필요한유틸리티의설치및환경설정, 사용방법을기술한안내서이다. Tibero를사용하는도중에발생할수있는각종에러의원인과해결방법을기술한안내서이다. 안내서에대하여 xv
16 안내서 에러참조안내서 Tibero 참조안내서 Tibero SQL 참조안내서 Tibero의동작과사용에필요한초기화파라미터와데이터사전, 정적뷰, 동적뷰를기술한참조안내서이다. 데이터베이스작업을수행하거나애플리케이션프로그램을작성할때필요한 SQL 문장을기술한참조안내서이다. 참고문헌 제품 ODBC 안내서 ODBC Programmer's Reference: X/Open X/Open CAE Specification Data Management: SQL Call Level Interface (CLI) ISBN: X/Open Document Number: C451 xvi Tibero tbcli 안내서
17 연락처 Korea TIBERO Co., Ltd 272-6, Seohyeon-dong, Bundang-gu, Seongnam-si, Gyeonggi-do, South Korea Tel: Fax: Web (Korean): 기술지원 : USA TmaxSoft, Inc. 560 Sylvan Avenue Englewood Cliffs, NJ U.S.A Tel: Fax: info@tmaxsoft.com Web (English): Japan TmaxSoft Japan Co., Ltd. 5F Sanko Bldg, Mita, Minato-Ku, Tokyo, Japan Tel: Fax: info@tmaxsoft.co.jp Web (Japanese): 안내서에대하여 xvii
18 China TmaxSoft China Co., Ltd. Beijing Silver Tower, RM 1508, 2# North Rd Dong San Huan, Chaoyang District, Beijing, China, China Tel: ~8 Fax: Web (Chinese): xviii Tibero tbcli 안내서
19 제 1 장 tbcli 소개 본장에서는 tbcli 의기본개념과구성요소, 프로그램의구조를소개한다 개요 tbcli는 Tibero가제공하는 Call Level Interface(CLI) 로사용자의애플리케이션프로그램과 Tibero간의 SQL 인터페이스역할을수행한다. 사용자는 tbcli 라이브러리를통해 Tibero에접근하려는 C 또는 C++ 애플리케이션프로그램을쉽게작성할수있다. tbcli는 ODBC(Open Database Connectivity) 및 X/Open Call Level Interface Standard를기초로개발되었다. tbcli는 ODBC 2.0의 Level 2 및 ODBC 3.0의 Level 1의모든조건, 그리고 ODBC 3.0 Level 2의대부분의조건을만족한다. 따라서 ODBC나 CLI를이용해작성된기존의애플리케이션프로그램은 tbcli 환경으로쉽게전환될수있다. 특히 tbcli는아래그림과같은클라이언트 / 서버환경에서유용하다. [ 그림 1.1] 클라이언트 / 서버환경 클라이언트의애플리케이션프로그램이 tbcli 의 API 를호출하면, 데이터베이스시스템이이를처리하고 그결과를클라이언트로반환해준다. 물론사용자는 tbesql 등의인터페이스를이용하여데이터를처리 할수있지만, tbcli 를사용함으로써애플리케이션프로그램과데이터를더세밀하게조작할수있다. tbcli는다음과같은특징이있다. 실행파일을생성할때프리컴파일러 (Precompiler) 가필요없다. tbcli는 tbesql과마찬가지로일반적인프로그램언어와 SQL 문장의장점을융합한인터페이스이다. 하지만 tbesql과다르게일반적인프로그램에가깝다. 제 1 장 tbcli 소개 1
20 모듈을효율적으로관리할수있으며, 가독성이뛰어나다. 애플리케이션패키지를바인딩할필요가없다. 접근할데이터베이스의통계 (statistics) 를사용할수있다. 스레드의안정성을보장한다. 애플리케이션프로그램을멀티스레드로작성할수있도록스레드의안정성을보장한다 구성요소 본절에서는 tbcli 프로그램을작성하거나실행하기에앞서기본적으로알아야할구성요소에대해 한다 tbcli 핸들 핸들이란 tbcli에서관리하고있는몇가지주요데이터구조에대한포인터 (pointer) 이다. 핸들을사용함으로써 tbcli 프로그램은복잡한구조를갖는데이터를보다편리하게관리할수있다. 핸들의내부데이터는데이터구조에작업이이루어지면자동으로갱신되기때문에애플리케이션프로그램개발자는핸들이가리키는데이터구조의세부사항에대해알필요가없으며, 내부데이터를직접접근할필요도없다. tbcli 프로그램은다음과같이네가지핸들을사용한다. 환경핸들 (environment handle) tbcli 프로그램의환경에대한데이터를포함한다. 포함되는데이터로는현재환경의상태, 환경에할당되어있는연결핸들의리스트, 환경에대한에러정보등이다. 연결핸들 (connection handle) 데이터소스 (data source) 와의연결에대한데이터를포함한다. 포함되는데이터로는현재연결상태, 연결에할당되어있는문장핸들의리스트, 연결에대한에러정보등이다. 문장핸들 (statement handle) tbcli 프로그램에서실행할하나의 SQL 문장에대한데이터를포함한다. 포함되는데이터로는현재문장상태, 문장내의입력파라미터및출력컬럼의리스트, 문장에대한에러정보등이다. 2 Tibero tbcli 안내서
21 서술자핸들 (descriptor handle) 문장핸들과연관된결과집합 (ResultSet) 의각컬럼이나바인드된파라미터의데이터를포함한다. 포함되는데이터로는 SQL 문장의입력파라미터, 출력컬럼에대한메타데이터 (metadata) 등이다 tbcli tbcli 프로그램에서데이터베이스작업을수행하기위해서는 tbcli 를사용해야한다. 대부분의 tbcli 는대상이되는핸들을입력파라미터로받으며, SQLRETURN 타입의반환코드를갖는다. 다음은 tbcli 중에서 SQL 문장을직접실행할수있는 SQLExecDirect 의프로토타입이다. SQLRETURN SQLExecDirect(SQLHSTMT StatementHandle, SQLCHAR *SQLString, SQLINTEGER SQLStringSize); tbcli 는기능별로몇개의그룹으로나누어제공된다. 예를들면핸들을할당하거나연결과관련된, SQL 문장실행과관련된, SQL 질의결과의검색과관련된, 서술자관련, 에러정보 와관련된, 데이터소스정보와관련된등이있다. 참고 tbcli 의사용에대한자세한내용은 제 3 장 tbcli 를참고한다 tbcli 에러메시지 tbcli 프로그램은 tbcli 를실행한후반환되는코드에의해실행결과를얻는다. 그러나사용자는보다더다양한정보를필요로한다. 이러한정보를제공하기위해서 tbcli는진단레코드를생성한다. 진단레코드는수행한의반환코드뿐만아니라실행결과에대한다양한정보를갖고있다. 진단레코드는다음과같이두가지레코드로구성된다. 헤더레코드 (header record) 반환코드, 로우개수, 상태레코드의개수, 실행된명령의타입등의필드로구성되어있다. 반환코드가 SQL_INVALID_HANDLE인경우를제외하고 tbcli 가실행되면항상헤더레코드가생성된다. 상태레코드 (status record) 상태레코드는경고및에러에대한정보를포함한다. 반환코드가 SQL_ERROR, SQL_SUCCESS_WITH_INFO, SQL_NO_DATA, SQL_NEED_DATA, SQL_STILL_EXECUTING 인경우생성된다. 제 1 장 tbcli 소개 3
22 상태레코드의필드중에서가장중요한필드중의하나는 필드이다. 에러또는경고코드 를표준화한것으로값은 X/Open 과 ISO/IEC 표준으로정해져있다. 형식은 CCSSS 다섯자리의문자 열이며, CC 는에러클래스, SSS 는에러서브클래스를의미한다. 진단레코드는하나의헤더레코드로시작되고경우에따라 1 개이상의상태레코드가추가된다. 진단레코드의값을얻기위해서는 SQLGetDiagRec 와 SQLGetDiagField 를사용해야한다. 이두 는파라미터로주어진핸들에포함된진단레코드의정보를반환하는역할만을수행한다. SQLGetDiagField 진단레코드중단일필드의정보를얻기위해사용하는이다. 헤더레코드와상태레코드모두에사용할수있다. SQLGetDiagRec 상태레코드에포함된 코드, 에러코드, 진단메시지등의여러개 의필드값을동시에얻기위해사용하는이다. 상태레코드에만사용할수있다. 진단레코드는환경, 연결, 문장, 서술자핸들에서사용되고관리된다. 참고 에러메시지에대한자세한내용은 제 4 장 tbcli 에러메시지 를참고한다. 4 Tibero tbcli 안내서
23 1.3. 프로그램구조 tbcli 프로그램은아래그림과같이크게시작설정부분 (Starting setting), SQL 문장실행및에러처리부분 (SQL query execution and error handling), 종료설정부분 (Ending setting) 으로나뉜다. [ 그림 1.2] tbcli 프로그램의구조 다음절부터는 tbcli 프로그램의구조에대해세부적으로한다 시작설정부분 tbcli 프로그램을시작하기위해서는우선초기화설정을해야한다. 초기화설정을하려면환경핸들과연결핸들을할당하고데이터소스와의실제연결을수행해야한다. 여기서데이터소스란 Tibero의소프트웨어및하드웨어의전체구성을의미한다. 제 1 장 tbcli 소개 5
24 다음은 tbcli 프로그램을시작하는예이다. [ 예 1.1] tbcli 프로그램의시작설정 SQLHENV h_env; SQLHDBC h_dbc; SQLRETURN rc = SQL_SUCCESS;... rc = SQLAllocHandle(SQL_HANDLE_ENV, NULL, &h_env); if (rc!= SQL_SUCCESS)... rc = SQLAllocHandle(SQL_HANDLE_DBC, h_env, &h_dbc); if (rc!= SQL_SUCCESS)... rc = SQLConnect(h_dbc, (SQLCHAR *)ds_name, SQL_NTS, (SQLCHAR *)user, SQL_NTS, (SQLCHAR *)passwd, SQL_NTS); if (rc!= SQL_SUCCESS && rc!= SQL_SUCCESS_WITH_INFO)... 1, 2 초기화설정을위해환경핸들과연결핸들을할당한다. 3 SQLConnect 를통해데이터소스에연결한다. 이를호출할때에는파라미터로데이터소스의이름 (ds_name) 과사용자의이름 (user), 패스워드 (passwd) 를함께전달해야한다. 뿐만아니라파라미터의길이도함께설정해주어야하는데위의 [ 예 1.1] 에서는길이대신 NULL로끝나는문자열 (null-terminating string) 즉 SQL_NTS를설정한다. 4 데이터소스에연결하는과정이끝나면 tbcli 프로그램은 SQL 문장을실행하기위해다음과같이반드시한개이상의문장핸들을할당한다. SQLHSTMT h_stmt;... rc = SQLAllocHandle(SQL_HANDLE_STMT, h_dbc, &h_stmt); if (rc!= SQL_SUCCESS)... 6 Tibero tbcli 안내서
25 SQL 문장실행및에러처리부분 직접실행 SQL 문장을실행하는방법은다음과같이두가지가있다. SQL 문장을 SQLExecDirect 를이용하여한번에실행하는방법이다. 다음은직접실행의예이다. [ 예 1.2] tbcli 프로그램의 SQL 문장실행 - 직접실행 SQLCHAR *update = "UPDATE EMP SET SALARY = SALARY * 1.05 " "WHERE DEPTNO = 5 ; rc = SQLExecDirect(h_stmt, update, SQL_NTS); if (rc!= SQL_SUCCESS)... 준비된실행 SQLPrepare와 SQLExecute 를이용하여두단계에걸쳐실행하는방법이다. 대부분 SQL 문장내에파라미터가포함된경우에는주로준비된실행방법을이용한다. SQLPrepare와 SQLExecute 사이에 SQLBindParameter 를호출하여파라미터에실제값을설정한다. 다음은두개의입력파라미터를포함한 SQL 문장을실행하는예이다. [ 예 1.3] tbcli 프로그램의 SQL 문장실행 - 준비된실행 SQLCHAR *update = "UPDATE EMP SET SALARY = SALARY *? " "WHERE DEPTNO =? ; double ratio = 0.0; short deptno = 0;... rc = SQLPrepare(h_stmt, update, SQL_NTS); if (rc!= SQL_SUCCESS)... rc = SQLBindParameter(h_stmt, 1, SQL_PARAM_INPUT, SQL_C_DOUBLE, SQL_DOUBLE, 5, 2, &ratio, 0, NULL);... a... if (rc!= SQL_SUCCESS)... rc = SQLBindParameter(h_stmt, 2, SQL_PARAM_INPUT, SQL_C_SHORT, SQL_SMALLINT, 0, 0, &deptno, 0, NULL);... b... 제 1 장 tbcli 소개 7
26 if (rc!= SQL_SUCCESS)... ratio = 1.05; deptno = 5; SQLExecute(h_stmt); if (rc!= SQL_SUCCESS)... 위의예에서는 SQL 문장내의입력파라미터를물음표 (?) 로표시한다. 입력파라미터의위치를표시할때에는 1 이상의정수를사용한다. 1 준비된 (prepared) SQL 문장에포함된각각의입력파라미터의값을저장하고있는변수의포인터를설정한다. 각각의입력파라미터 (a, b) 에입출력방향, C 또는 C++ 의데이터타입, SQL의데이터타입, 정밀도 (precision), 범위 (scale) 등을함께설정한다. 2 SQL 문장을실행한다. 이문장을실행하면설정된입력파라미터에의해 EMP 테이블이갱신된다. SQL 문장을실행하고나서몇개의로우가갱신되었는지확인하려면 SQLRowCount 를사용한다. 사용하는방법은다음과같다. rc = SQLRowCount(h_stmt, &count); 각의반환코드는수행결과에대한정보를가지고있으므로, 를호출한후에는항상반환코드 를확인해야한다 종료설정부분 tbcli 프로그램을종료하기위해서는 시작설정부분 에서수행한작업과반대되는작업을수행해야한다. 다음은 tbcli 프로그램을종료하는예이다. [ 예 1.4] tbcli 프로그램의종료설정 rc = SQLDisconnect(h_dbc); if (rc!= SQL_SUCCESS)... SQLFreeHandle(SQL_HANDLE_DBC, h_dbc); SQLFreeHandle(SQL_HANDLE_ENV, h_env); 데이터소스의연결을해제한다. 2, 3 할당한연결핸들과환경핸들을시스템에반환한다. 8 Tibero tbcli 안내서
27 제 2 장데이터타입 본장에서는 tbcli 프로그램에서사용하는데이터타입을알아보고데이터타입간의변환을한다. 데이터타입은 SQL 문장에값을입력하고, 질의결과를얻기위해사용한다. tbcli는다음과같이두가지타입을지원한다. Tibero의데이터타입데이터베이스에저장된데이터에접근할때사용한다. tbcli 의데이터타입 애플리케이션프로그램에서데이터를조작할때사용한다 Tibero 의데이터타입 본절에서는 Tibero에서디폴트로제공하는데이터타입을간략히한다. 이러한데이터타입은데이터베이스의스키마객체를생성하는데사용하는것으로 tbesql 프로그램내에서도모든데이터타입에대응되는변수를사용할수있다. 다음은 Tibero 의데이터타입이다. 구분문자형숫자형날짜형간격형대용량객체형 데이터타입 CHAR, VARCHAR, NCHAR, NVARCHAR, RAW, LONG, LONG RAW NUMBER, INTEGER, FLOAT DATE, TIME, TIMESTAMP, TIMESTAMP WITH TIME ZONE, TIMESTAMP WITH LOCAL TIMEZONE INTERVAL YEAR TO MONTH, INTERVAL DAY TO SECOND CLOB, BLOB 문자열이나바이너리데이터를저장하는데이터타입이다. LONG, LONG RAW의경우 2GB까지저장된다. 정수나실수의숫자를저장하는데이터타입이다. 시간이나날짜, 시간대를저장하는데이터타입이다. 시간사이의간격을저장하는데이터타입이다. LOB 타입을의미한다. 다른데이터타입이지원하는최대길이 (8KB 이하 ) 보다훨씬큰길이를가질수있는객체이다. 4GB까지가능하다. 제 2 장데이터타입 9
28 구분 내재형 데이터타입 ROWID 사용자가명시적으로선언하지않아도 Tibero가자동으로삽입되는로우마다포함하는컬럼의타입이다. 참고 자세한내용은 "Tibero SQL 참조안내서 " 를참고한다. 다음은각데이터타입에대한세부이다. 데이터타입 CHAR 일반문자열을저장하는데이터타입이다. VARCHAR NCHAR 유니코드문자열을저장하는데이터타입이다. NVARCHAR RAW LONG LONG RAW NUMBER INTEGER FLOAT 바이너리데이터를저장하는데이터타입이다. 대용량의문자열이나바이너리데이터를저장하는데이터타입이다. 한테이블내에하나의컬럼만선언할수있다. 정수또는실수를저장하는타입이다. NUMBER 타입을선언할때정밀도와스케일을함께선언할수있다. - 정밀도 : 데이터값의전체자릿수 - 스케일 : 소수점이하자릿수 DATE TIME TIMESTAMP TIMESTAMP WITH TIME ZONE TIMESTAMP WITH LOCAL TIME ZONE INTERVAL YEAR TO MONTH 특정날짜와시간, 시간대를나타내는데이터타입이다. - DATE: 특정날짜 - TIMESTAMP: 특정날짜와시간 - TIMESTAMP WITH TIME ZONE: UTC(Coordinated Universal Time) 으로정규화된특정날짜와시간, 해당시간대 - TIMESTAMP WITH LOCAL TIME ZOEN: UTC(Coordinated Universal Time) 으로정규화된특정날짜와시간특정날짜와시간사이의간격을나타내는데이터타입이다. - INTERVAL YEAR TO MONTH: 연도와월로계산한시간간격 10 Tibero tbcli 안내서
29 데이터타입 INTERVAL DAY TO SECOND CLOB BLOB ROWID - INTERVAL DAY TO SECOND: 일, 시, 분, 초, 소수점초로계산한시간간격대용량의문자열이나바이너리데이터를저장하는데이터타입이다. 한테이블내에여러컬럼을선언할수있다. 데이터베이스내의각로우를식별하기위해, Tibero 시스템이각로우마다자동으로부여하는데이터타입이다. 각로우가저장되어있는물리적인위치를포함한다 tbcli 의데이터타입 본절에서는애플리케이션프로그램개발자가데이터베이스프로그램을작성할때사용하게되는 tbcli 의데이터타입을한다. 다음은각데이터타입에대한 C의 typedef 이름과이에대응하는 C의데이터타입을보여주는표이다. C의 typedef 이름 SQLCHAR SQLSCHAR SQLSMALLINT SQLUSMALLINT SQLINTEGER SQLUINTEGER SQLREAL SQLDOUBLE, SQLFLOAT DATE_STRUCT, SQL_DATE_STRUCT TIME_STRUCT, SQL_TIME_STRUCT TIME_STAMP_STRUCT, SQL_TIMESTAMP_STRUCT C의데이터타입 unsigned char signed char short int unsigned short int long int unsigned long int float double [ 예 2.1] [ 예 2.2] [ 예 2.3] 다음은 C의 typedef 이름에대응하는 tbcli의데이터타입을사용한예이다. DATE_STRUCT, SQL_DATE_STRUCT [ 예 2.1] DATE_STRUCT, SQL_DATE_STRUCT typedef struct tagdate_struct { 제 2 장데이터타입 11
30 }; SQLSMALLINT SQLUSMALLINT SQLUSMALLINT year; month; day; TIME_STRUCT, SQL_TIME_STRUCT [ 예 2.2] TIME_STRUCT, SQL_TIME_STRUCT struct tagtime_struct { SQLUSMALLINT hour; SQLUSMALLINT minute; SQLUSMALLINT second; }; TIME_STAMP_STRUCT, SQL_TIMESTAMP_STRUCT [ 예 2.3] TIME_STAMP_STRUCT, SQL_TIMESTAMP_STRUCT struct tagtimestamp_struct { SQLSMALLINT year; SQLUSMALLINT month; SQLUSMALLINT day; SQLUSMALLINT hour; SQLUSMALLINT minute; SQLUSMALLINT second; SQLUINTEGER fraction; }; 12 Tibero tbcli 안내서
31 제 3 장 tbcli 본장에서는 tbcli 에서지원하는를한다 SQL-99 표준 API SQLAllocConnect (Deprecated) SQLAllocConnect 는 ODBC 3.x 에서 SQLAllocHandle 로대체된다 SQLAllocEnv (Deprecated) 애플리케이션프로그램은한번에하나의환경을사용할수있다. 이는환경핸들과연관된메모리를할당하고초기화한다. 환경핸들을할당받기위해 SQLAllocConnect 등의를호출하기전에 SQLAllocEnv 를호출해야한다. 그리고호출한이후에는환경핸들을필요로하는모든에핸들이전달된다. 참고로 SQLFreeEnv 를호출하면기존의환경핸들은반환된다. 관련 SQLAllocEnv 는 ODBC 3.x에서 SQLAllocHandle 로대체된다 SQLAllocHandle 환경, 연결, 문장핸들을할당할때사용하는이다. ISO 92 CLI/ODBC 3.0에서지원하며, 자원, 환경, 명령문핸들초기화및메모리할당을수행하는역할을담당한다. SQLAllocHandle 의세부내용은다음과같다. 문법 SQLRETURN SQLAllocHandle (SQLSMALLINT SQLHANDLE SQLHANDLE * HandleType, InputHandle, OutputHandle); 제 3 장 tbcli 13
32 파라미터 파라미터 HandleType 용도 입력 할당받을핸들의타입이다. 아래타입중하나의값을갖는다. - SQL_HANDLE_ENV - SQL_HANDLE_DBC - SQL_HANDLE_STMT InputHandle 입력 입력핸들이다. 핸들의타입에따라다른값을갖는다. - SQL_HANDLE_ENV: SQL_NULL_HANDLE - SQL_HANDLE_DBC: 환경핸들 - SQL_HANDLE_STMT: 연결핸들 OutputHandle 출력 할당받을핸들의포인터이다. 환경핸들이아닌다른핸들을할당할때 SQL_ERROR를반환하는경우, OutputHandle 파라미터를 SQL_NULL_HDBC, SQL_NULL_HSTMT로할당한다. 반환코드 반환코드 SQL_SUCCESS 가성공적으로완료된상태 SQL_SUCCESS_WITH_INFO SQL_INVALID_HANDLE SQL_ERROR 가성공적으로완료되었으나, 경고메시지가있는상태 입력파라미터에주어진핸들이유효하지않은상태 치명적인에러가발생한상태 HY000 HY001 일반적인경고데이터베이스연결이존재하지않는경우일반적인에러메모리할당에러 14 Tibero tbcli 안내서
33 HY009 HY010 HY013 HY014 HY092 HYC00 HYT01 IM001 NULL 포인터를잘못사용한경우시퀀스에러메모리관리에러한정된범위의핸들개수를초과한경우잘못된속성및옵션식별자선택적인기능 (Optional feature) 이구현되지않은경우데이터베이스연결제한시간을초과한경우드라이버가 SQLAllocHandle 를지원하지않는경우 관련 SQLAllocHandle 는 SQLAllocConnect, SQLAllocEnv, SQLAllocstmt를대체하는다. ODBC 2.x 드라이버를사용하는애플리케이션프로그램이올바르게동작하기위해서는 SQLAllocHan dle 를 SQLAllocConnect, SQLAllocEnv, SQLAllocstmt 로적절하게대체해야한다 SQLAllocStmt (Deprecated) tbcli에서자, 결과값, 커서정보, 상태정보를처리하기위해사용하는문장핸들을할당받는이다. 이를호출하면문장을위한메모리를할당하고초기화한다. 하나의데이터베이스연결에 1,024 개의문장을할당할수있다. 관련 SQLAllocStmt 는 ODBC 3.x에서 SQLAllocHandle 로대체된다 SQLBindCol ISO 92 CLI/ODBC 1.0에서지원하며, 결과집합의컬럼을받아올버퍼와데이터타입을설정하는이다. 모든데이터타입에대해결과집합의컬럼을애플리케이션프로그램변수에연관시킨다. 이에의해참조된위치는 SQLFetch 를호출하기전까지갱신되지않으며유효한상태로남아있는다. SQLFetch 가호출되면데이터가데이터베이스서버에서애플리케이션프로그램으로전송된다. 따라서 SQLFetch 를사용하기전에이를호출해야한다. 제 3 장 tbcli 15
34 SQLBindCol 의세부내용은다음과같다. 문법 SQLRETURN SQLBindCol (SQLHSTMT SQLUSMALLINT SQLSMALLINT SQLPOINTER SQLINTEGER SQLINTEGER * StatementHandle, ColumnNumber, TargetType, TargetValue, BufferLength, StrLen_or_Ind); 파라미터 파라미터 StatementHandle ColumnNumber TargetType TargetValue BufferLength StrLen_or_Ind 용도입력입력입력입 / 출력입력입 / 출력 문장핸들컬럼번호 C의데이터타입컬럼을받아올버퍼의포인터 byte 단위의버퍼크기버퍼에저장된데이터의길이 반환코드 반환코드 SQL_SUCCESS 가성공적으로완료된상태 SQL_SUCCESS_WITH_INFO SQL_INVALID_HANDLE SQL_ERROR 가성공적으로완료되었으나, 경고메시지가있는상태 입력파라미터에주어진핸들이유효하지않은상태 치명적인에러가발생한상태 HY000 HY001 HY003 HY010 일반적인경고제한된데이터타입의속성에위배되는경우잘못된서술자인덱스일반적인에러메모리할당에러잘못된애플리케이션의버퍼타입시퀀스에러 16 Tibero tbcli 안내서
35 HY013 HY090 HYC00 HYT01 IM001 메모리관리에러잘못된문자열또는버퍼길이선택적인기능이구현되지않은경우데이터베이스연결제한시간이만료된경우데이터베이스연결제한시간을초과한경우 SQLBindParameter ISO 92 CLI/ODBC 2.0 에서지원하며, SQL 문장에파라미터를바인드하는이다. 즉 SQL 문장의파라 미터를애플리케이션프로그램의변수에바인드한다. SQLBindParameter 의세부내용은다음과같다. 문법 SQLRETURN SQLBindParameter (SQLHSTMT SQLUSMALLINT SQLSMALLINT SQLSMALLINT SQLSMALLINT SQLULEN SQLSMALLINT SQLPOINTER SQLLEN SQLLEN * StatementHandle ParameterNumber, InputOutputType, ValueType, ParameterType, ColumnSize, DecimalDigits, ParameterValue, BufferLength, StrLen_or_Ind); 파라미터 파라미터 StatementHandle ParameterNumber InputOutputType ValueType ParameterType ColumnSize 용도입력입력입력입력입력입력 문장핸들파라미터의위치파라미터의종류 C의데이터타입 SQL의데이터타입정밀도데이터타입이다른경우 - SQL_CHAR: 최대길이 제 3 장 tbcli 17
36 파라미터 용도 - SQL_NUMERIC: 최대십진정밀도 DecimalDigits ParameterValue BufferLength StrLen_or_Ind 입력입 / 출력입력입 / 출력 SQL_NUMERIC인경우소수점아래의자릿수파라미터의포인터버퍼의최대크기입 / 출력된데이터의크기 반환코드 반환코드 SQL_SUCCESS 가성공적으로완료된상태 SQL_SUCCESS_WITH_INFO SQL_INVALID_HANDLE SQL_ERROR 가성공적으로완료되었으나, 경고메시지가있는상태 입력파라미터에주어진핸들이유효하지않은상태 치명적인에러가발생한상태 HY000 HY001 HY003 HY004 HY009 HY010 HY013 HY021 HY090 HY104 HY105 HYC00 HYT01 IM001 일반적인경고제한된데이터타입의속성에위배되는경우잘못된서술자인덱스일반적인에러메모리할당에러잘못된애플리케이션의버퍼타입잘못된 SQL의데이터타입 NULL 포인터를잘못사용한경우시퀀스에러메모리관리에러모순이있는 (inconsistent) 서술자정보잘못된문자열또는버퍼길이잘못된정밀도또는스케일값잘못된파라미터의타입선택적인기능이구현되지않은경우데이터베이스연결제한시간을초과한경우드라이버가 SQLBindParameter 를지원하지않는경우 18 Tibero tbcli 안내서
37 SQLCancel ISO 92 CLI/ODBC 3.0 에서지원하며, 현재실행중인 SQL 문장의수행을취소시키는이다. SQLCancel 의세부내용은다음과같다. 문법 SQLRETURN SQLCancel (SQLHSTMT StatementHandle); 파라미터 파라미터 StatementHandle 용도 입력 문장핸들 반환코드 반환코드 SQL_SUCCESS 가성공적으로완료된상태 SQL_SUCCESS_WITH_INFO SQL_INVALID_HANDLE SQL_ERROR 가성공적으로완료되었으나, 경고메시지가있는상태 입력파라미터에주어진핸들이유효하지않은상태 치명적인에러가발생한상태 HY000 HY001 HY010 HY013 HY018 HYT01 IM001 일반적인경고일반적인에러메모리할당에러시퀀스에러메모리관리에러서버에취소요청이받아들여지지않은경우데이터베이스연결제한시간을초과한경우드라이버가 SQLCancel 를지원하지않는경우 제 3 장 tbcli 19
38 SQLCloseCursor ISO 92 CLI/ODBC 3.0 에서지원하며, 커서를해제하는이다. 즉현재실행중인 SQL 문장의커서를 닫고결과를해제한다. SQLCloseCursor 의세부내용은다음과같다. 문법 SQLRETURN SQLCloseCursor (SQLHSTMT StatementHandle); 파라미터 파라미터 StatementHandle 용도 입력 문장핸들 반환코드 반환코드 SQL_SUCCESS 가성공적으로완료된상태 SQL_SUCCESS_WITH_INFO SQL_INVALID_HANDLE SQL_ERROR 가성공적으로완료되었으나, 경고메시지가있는상태 입력파라미터에주어진핸들이유효하지않은상태 치명적인에러가발생한상태 HY000 HY001 HY010 HY013 HYT01 IM001 일반적인경고잘못된커서상태인경우일반적인에러메모리할당에러시퀀스에러메모리관리에러데이터베이스연결제한시간을초과한경우드라이버가 SQLCloseCursor 를지원하지않는경우 20 Tibero tbcli 안내서
39 SQLColAttribute ISO 92 CLI/ODBC 3.0에서지원하며, 결과집합의특정컬럼에속성을설정하여해당정보를확인하는이다. 확인할정보가문자열이면 CharacterAttribute 파라미터에반환되고, 숫자이면 NumericAttribute 파라미터에반환된다. 이를호출하기전에 SQLPrepare 또는 SQLExecDirect 를호출해야한다. SQLColAttribute 의세부내용은다음과같다. 문법 SQLRETURN SQLColAttribute (SQLHSTMT StatementHandle, SQLUSMALLINT ColumnNumber, SQLUSMALLINT FieldIdentifier, SQLPOINTER CharacterAttribute, SQLSMALLINT BufferLength, SQLSMALLINT * StringLength, SQLPOINTER NumericAttribute); 파라미터 파라미터 StatementHandle ColumnNumber FieldIdentifier CharacterAttribute BufferLength StringLength NumericAttribute 용도입력입력입력출력입력출력출력 문장핸들컬럼의위치확인할정보버퍼의포인터버퍼의최대크기반환되는문자열의길이반환되는숫자 반환코드 반환코드 SQL_SUCCESS 가성공적으로완료된상태 SQL_SUCCESS_WITH_INFO SQL_INVALID_HANDLE SQL_STILL_EXECUTING SQL_ERROR 가성공적으로완료되었으나, 경고메시지가있는상태입력파라미터에주어진핸들이유효하지않은상태이전에실행한 SQL 문장이완료되지않은상태치명적인에러가발생한상태 제 3 장 tbcli 21
40 HY000 HY001 HY008 HY010 HY013 HY090 HY091 HYC00 HYT01 IM001 일반적인경고문자열데이터가오른쪽에서잘린경우커서의범위가아닌준비된문장인경우잘못된서술자인덱스인경우일반적인에러메모리할당에러연산이취소된경우시퀀스에러메모리관리에러잘못된문자열또는버퍼길이잘못된서술자의필드식별자선택적인기능이구현되지않은경우데이터베이스연결제한시간을초과한경우드라이버가 SQLColAttribute 를지원하지않는경우 SQLColAttributes (Deprecated) SQLColAttributes 는 ODBC 3.x 에서 SQLColAttribute 로대체된다 SQLColumnPrivileges ISO 92 CLI/ODBC 1.0 에서지원하며특정테이블의컬럼리스트와관련된권한을검색하거나반환하는 이다. 이때반환된정보는결과집합의형태로나타난다. SQLColumnPrivileges 의세부내용은다음과같다. 문법 SQLRETURN SQLColumnPrivileges (SQLHSTMT SQLCHAR * SQLSMALLINT SQLCHAR * SQLSMALLINT SQLCHAR * SQLSMALLINT SQLCHAR * SQLSMALLINT StatementHandle, CatalogName, NameLength1, SchemaName, NameLength2, TableName, NameLength3, ColumnName, NameLength4); 22 Tibero tbcli 안내서
41 파라미터 파라미터 StatementHandle CatalogName NameLength1 SchemaName NameLength2 TableName NameLength3 ColumnName NameLength4 용도입력입력입력입력입력입력입력입력입력 문장핸들카탈로그이름카탈로그이름의길이스키마이름스키마이름의길이테이블이름테이블이름의길이컬럼이름컬럼이름의길이 반환코드 반환코드 SQL_SUCCESS 가성공적으로완료된상태 SQL_SUCCESS_WITH_INFO SQL_INVALID_HANDLE SQL_STILL_EXECUTING SQL_ERROR 가성공적으로완료되었으나, 경고메시지가있는상태입력파라미터에주어진핸들이유효하지않은상태이전에실행한 SQL 문장이완료되지않은상태치명적인에러가발생한상태 S HY000 HY001 HY008 HY009 HY010 HY013 일반적인경고서버와의통신연결에실패한경우잘못된커서상태인경우직렬화에실패한경우실행이완료되지않았고트랜잭션의상태를알수없는경우일반적인에러메모리할당에러연산이취소된경우 NULL 포인터를잘못사용한경우시퀀스에러메모리관리에러 제 3 장 tbcli 23
42 HY090 HYC00 HYT00 HYT01 IM001 잘못된문자열또는버퍼길이선택적인기능이구현되지않은경우제한시간을초과한경우데이터베이스연결제한시간을초과한경우드라이버가 SQLColumnPrivileges 를지원하지않는경우 SQLColumns XopenCLI/ISO 92 CLI/ODBC 1.0 에서지원하며, 특정테이블의컬럼이나리스트에대한정보를검색하고 결과집합을반환하는이다. SQLColumns 의세부내용은다음과같다. 문법 SQLRETURN SQLColumns (SQLHSTMT SQLCHAR * SQLSMALLINT SQLCHAR * SQLSMALLINT SQLCHAR * SQLSMALLINT SQLCHAR * SQLSMALLINT StatementHandle, CatalogName, NameLength1, SchemaName, NameLength2, TableName, NameLength3, ColumnName, NameLength4); 파라미터 파라미터 StatementHandle CatalogName NameLength1 SchemaName NameLength2 TableName NameLength3 ColumnName NameLength4 용도입력입력입력입력입력입력입력입력입력 문장핸들카탈로그이름카탈로그이름의길이검색할스키마의이름스키마이름의길이검색할테이블의이름테이블이름의길이검색할컬럼의 ID 검색할컬럼 ID의길이 24 Tibero tbcli 안내서
43 반환컬럼 다음은 SQLColumns 에의해반환되는컬럼이다. 컬럼번호 컬럼이름 데이터타입 1 TABLE_CAT VARCHAR 카탈로그의이름 2 TABLE_SCHEM VARCHAR 스키마의이름 3 TABLE_NAME VARCHAR(NOT NULL) 테이블이나뷰의이름 4 COLUMN_NAME VARCHAR(NOT NULL) 컬럼의 ID 5 DATA_TYPE NUMERIC(NOT NULL) 컬럼에대한 SQL 의데이터타입 6 TYPE_NAME VARCHAR(NOT NULL) DATA_TYPE 컬럼을나타내는문자열 7 COLUMN_SIZE NUMERIC 컬럼의최대크기 8 BUFFER_LENGTH NUMERIC 데이터를저장할수있는최대크기 9 DECIMAL_DIGITS NUMERIC 컬럼의소수자릿수 10 NUM_PREC_RADIX NUMERIC 10, 2, NULL 중의하나의값 - DATA_TYPE 컬럼이숫자형인경우 : 2 - COLUMN_SIZE 컬럼 : 삽입이허용되는 비트의수 11 NULLABLE NUMERIC(NOT NULL) NULL 값이가능한지여부 12 REMARKS VARCHAR 컬럼의 13 COLUMN_DEF VARCHAR 컬럼의디폴트값 14 SQL_DATA_TYPE NUMERIC(NOT NULL) SQL 의데이터타입 15 SQL_DATETIME_SUB NUMERIC 내부데이터타입 16 CHAR_OCTET_LENGTH NUMERIC 컬럼의최대자릿수 17 ORDINAL_POSITION NUMERIC(NOT NULL) 테이블컬럼의원래위치 18 IS_NULLABLE VARCHAR 로우가 NULL 를포함하는지여부 반환코드 반환코드 SQL_SUCCESS SQL_SUCCESS_WITH_INFO SQL_INVALID_HANDLE SQL_STILL_EXECUTING SQL_ERROR 가성공적으로완료된상태가성공적으로완료되었으나, 경고메시지가있는상태입력파라미터에주어진핸들이유효하지않은상태이전에실행한 SQL 문장이완료되지않은상태치명적인에러가발생한상태 제 3 장 tbcli 25
44 S HY000 HY001 HY008 HY009 HY010 HY013 HY090 HYC00 HYT00 HYT01 IM001 일반적인경고서버와의통신연결에실패한경우잘못된커서상태인경우직렬화에실패한경우실행이완료되지않았고트랜잭션의상태를알수없는경우일반적인에러메모리할당에러연산이취소된경우 NULL 포인터를잘못사용한경우시퀀스에러메모리관리에러잘못된문자열또는버퍼길이선택적인기능이구현되지않은경우제한시간을초과한경우데이터베이스연결제한시간을초과한경우드라이버가 SQLColumns 를지원하지않는경우 SQLConnect ISO 92 CLI/ODBC 1.0에서지원하며, 연결할대상이되는데이터베이스를설정하는이다. 애플리케이션프로그램은연결대상인데이터베이스에 SQL를제공하고, 선택적으로권한및인증과관련된정보를제공할수있다. 이를호출하기전에 SQLAllocConnect 를호출해야한다. SQLConnect 의세부내용은다음과같다. 문법 SQLRETURN SQLConnect(SQLHDBC SQLCHAR * SQLSMALLINT SQLCHAR * SQLSMALLINT ConnectionHandle, ServerName, NameLength1, UserName, NameLength2, 26 Tibero tbcli 안내서
45 SQLCHAR * SQLSMALLINT Authentication, NameLength3); 파라미터 파라미터 ConnectionHandle ServerName NameLength1 UserName NameLength2 Authentication NameLength3 용도입력입력입력입력입력입력입력 연결핸들데이터베이스이름의포인터데이터베이스이름의길이사용자 ID의포인터사용자 ID의길이인증과관련된패스워드의포인터인증과관련된패스워드의길이 반환코드 반환코드 SQL_SUCCESS 가성공적으로완료된상태 SQL_SUCCESS_WITH_INFO SQL_INVALID_HANDLE SQL_ERROR 가성공적으로완료되었으나, 경고메시지가있는상태 입력파라미터에주어진핸들이유효하지않은상태 치명적인에러가발생한상태 S S HY000 HY001 HY013 HY090 일반적인경고옵션의값이바뀐경우클라이언트가서버에연결하는것이불가능한경우이미사용중인데이터베이스연결의이름인경우서버가연결을거부한경우서버와의통신연결에실패한경우잘못된권한을설정한경우일반적인에러메모리할당에러메모리관리에러잘못된문자열또는버퍼길이 제 3 장 tbcli 27
46 HYT00 HYT01 IM001 IM002 IM003 IM004 IM005 IM006 IM009 IM010 제한시간을초과한경우데이터베이스연결제한시간을초과한경우드라이버가 SQLConnect 를지원하지않는경우데이터소스의이름을찾을수없거나, 디폴트드라이버가존재하지않는경우설정한드라이버를로드할수없는경우해당드라이버에 SQLAllocHandle 를이용한환경핸들할당에실패한경우해당드라이버에 SQLAllocHandle 를이용한연결핸들할당에실패한경우드라이버에 SQLSetConnectAttr 를이용한데이터베이스연결속성설정에실패한경우 Translation DLL에연결하는것이불가능한경우데이터소스의이름이 SQL_MAX_DSN_LENGTH 파라미터에설정된값보다긴경우 SQLCopyDesc ISO 92 CLI/ODBC 3.0 에서지원하며다른서술자핸들에서술자정보를복사하는이다. SQLCopyDesc 의세부내용은다음과같다. 문법 SQLRETURN SQLCopyDesc (SQLHDESC SQLHDESC SourceDescHandle, TargetDescHandle); 파라미터 파라미터 SourceDescHandle TargetDescHandle 용도 입력 입력 원본서술자의핸들 대상서술자의핸들 반환코드 반환코드 SQL_SUCCESS 가성공적으로완료된상태 28 Tibero tbcli 안내서
47 반환코드 SQL_SUCCESS_WITH_INFO SQL_INVALID_HANDLE SQL_ERROR 가성공적으로완료되었으나, 경고메시지가있는상태입력파라미터에주어진핸들이유효하지않은상태치명적인에러가발생한상태 S S HY000 HY001 HY013 HY090 HYT00 HYT01 IM001 IM002 IM003 IM004 IM005 IM006 IM009 일반적인경고옵션의값이바뀐경우클라이언트가서버에연결하는것이불가능한경우이미사용중인데이터베이스연결의이름인경우서버가연결을거부한경우서버와의통신연결에실패한경우잘못된권한을설정한경우일반적인에러메모리할당에러메모리관리에러잘못된문자열또는버퍼길이제한시간을초과한경우데이터베이스연결제한시간을초과한경우드라이버가 SQLCopyDesc 를지원하지않는경우데이터소스의이름을찾을수없거나, 디폴트드라이버가존재하지않는경우설정한드라이버를로드할수없는경우해당드라이버에 SQLAllocHandle 를이용한환경핸들의할당에실패한경우해당드라이버에 SQLAllocHandle 를이용한연결핸들의할당에실패한경우드라이버에 SQLSetConnectAttr 를이용한데이터베이스연결속성의설정에실패한경우 Translation DLL에연결하는것이불가능한경우 제 3 장 tbcli 29
48 SQLDescribeCol ISO 92 CLI/ODBC 1.0에서지원하며, 결과집합에서특정컬럼의이름, 데이터타입, 정밀도, 스케일, NULL 의허용여부등의정보를확인하는이다. 이를호출하기전에 SQLPrepare 또는 SQLExecDirect 를호출해야한다. SQLDescribeCol 의세부내용은다음과같다. 문법 SQLRETURN SQLDescribeCol (SQLHSTMT SQLUSMALLINT SQLCHAR * SQLSMALLINT SQLSMALLINT * SQLSMALLINT * SQLUINTEGER * SQLSMALLINT * SQLSMALLINT * StatementHandle, ColumnNumber, ColumnName, BufferLength, NameLength, DataType, ColumnSize, DecimalDigits, Nullable); 파라미터 파라미터 StatementHandle ColumnNumber ColumnName BufferLength NameLength DataType ColumnSize DecimalDigits Nullable 용도입력입력출력입력출력출력출력출력출력 문장핸들컬럼의위치컬럼이름의포인터컬럼이름을저장하기위한버퍼의크기컬럼이름의길이컬럼의데이터타입컬럼의정밀도컬럼의스케일컬럼에대한 NULL의허용여부 반환코드 반환코드 SQL_SUCCESS 가성공적으로완료된상태 SQL_SUCCESS_WITH_INFO SQL_INVALID_HANDLE SQL_STILL_EXECUTING 가성공적으로완료되었으나, 경고메시지가있는상태 입력파라미터에주어진핸들이유효하지않은상태 이전에실행한 SQL 문장이완료되지않은상태 30 Tibero tbcli 안내서
49 반환코드 SQL_ERROR 치명적인에러가발생한상태 S01 HY000 HY001 HY008 HY010 HY013 HY090 HYT01 IM001 일반적인경고문자열데이터가오른쪽에서잘린경우커서의범위가아닌준비된문장인경우잘못된서술자인덱스서버와의통신연결에실패한경우일반적인에러메모리할당에러연산이취소된경우시퀀스에러메모리관리에러잘못된문자열또는버퍼길이데이터베이스연결제한시간을초과한경우드라이버가 SQLDescribeCol 를지원하지않는경우 SQLDescribeParam ODBC 1.0 에서지원하며, 준비된 SQL 문장과관련된파라미터기호의서술자를반환하는이다. SQLDescribeParam 의세부내용은다음과같다. 문법 SQLRETURN SQLDescribeParam (SQLHSTMT SQLUSMALLINT SQLSMALLINT * SQLUINTEGER * SQLSMALLINT * SQLSMALLINT * StatementHandle, ParameterNumber, DataType, ParameterSize, DecimalDigits, Nullable); 파라미터 제 3 장 tbcli 31
50 파라미터 StatementHandle ParameterNumber DataType ParameterSize DecimalDigits Nullable 용도입력입력출력출력출력출력 문장핸들이다. 파라미터기호의번호이다. 파라미터에대한 SQL의데이터타입이다. 컬럼의크기가반환될버퍼의포인터이다. 컬럼의정밀도가반환될버퍼의포인터이다. 해당파라미터에대한 NULL의허용여부가반환될버퍼의포인터이다. 다음중에하나의값을갖는다. - SQL_NO_NULLS: NULL을허용하지않는다. - SQL_NULLABLE: NULL을허용한다. - SQL_NULLABLE_UNKNOWN: NULL을허용할것인지를결정할수없다. 반환코드 반환코드 SQL_SUCCESS 가성공적으로완료된상태 SQL_SUCCESS_WITH_INFO SQL_INVALID_HANDLE SQL_STILL_EXECUTING SQL_ERROR 가성공적으로완료되었으나, 경고메시지가있는상태입력파라미터에주어진핸들이유효하지않은상태이전에실행한 SQL 문장이완료되지않은상태치명적인에러가발생한상태 S01 21S01 HY000 HY001 HY008 HY010 HY013 일반적인경고잘못된서술자인덱스서버와의통신연결에실패한경우삽입될값의리스트가컬럼과일치하지않은경우일반적인에러메모리할당에러연산이취소된경우시퀀스에러메모리관리에러 32 Tibero tbcli 안내서
51 HYT01 IM001 데이터베이스연결제한시간을초과한경우 드라이버가 SQLDescribeParam 를지원하지않는경우 SQLDisconnect ISO 92 CLI/ODBC 1.0에서지원하며, 연결핸들과관련된데이터베이스연결을종료하는이다. 이가호출되면데이터베이스의연결을종료한후핸들을해제한다. 성공적으로핸들이해제되고나서 SQLConnect 를호출하는경우애플리케이션프로그램은연결핸들을다시사용할수있다. 이를호출한후다른데이터베이스에연결하려면 SQLConnect나 SQLFreeConnect 를사용해야한다. SQLDisconnect 의세부내용은다음과같다. 문법 SQLRETURN SQLDisconnect (SQLHDBC ConnectionHandle); 파라미터 파라미터 ConnectionHandle 용도 입력 연결핸들 반환코드 반환코드 SQL_SUCCESS 가성공적으로완료된상태 SQL_SUCCESS_WITH_INFO SQL_INVALID_HANDLE SQL_ERROR 가성공적으로완료되었으나, 경고메시지가있는상태 입력파라미터에주어진핸들이유효하지않은상태 치명적인에러가발생한상태 일반적인경고데이터베이스연결을해제하는중에에러가발생한경우데이터베이스연결이존재하지않는경우잘못된트랜잭션상태인경우 제 3 장 tbcli 33
52 HY000 HY001 HY010 HY013 HYT01 IM001 일반적인에러메모리할당에러시퀀스에러메모리관리에러데이터베이스연결제한시간을초과한경우드라이버가 SQLDisconnect 를지원하지않는경우 SQLDriverConnect CLI/ODBC 1.0에서지원하며, 연결할대상이되는데이터베이스를설정하는이다. 이는 SQLCon nect 에서제공하는 3개의파라미터보다더많은연결정보를필요로하는데이터소스를지원한다. 이를호출하기전에 SQLAllocConnect 를호출해야한다. SQLDriverConnect 의세부내용은다음과같다. 문법 SQLRETURN SQLDriverConnect (SQLHDBC SQLHWND SQLCHAR SQLSMALLINT SQLCHAR SQLSMALLINT SQLSMALLINT SQLUSMALLINT ConnectionHandle, WindowHandle, *InConnectionString, StringLength1, *OutConnectionString, BufferLength, *StringLength2Ptr, DriverCompletion); 파라미터 파라미터 ConnectionHandle WindowHandle InConnectionString 용도입력입력입력 연결핸들사용하지않음 (NULL 입력 ) 연결문자열연결문자열은 keyword=value들로구성되며 ; 로구분한다. Windows는 keyword로 DSN, DESC(=Description), UID(=User), PWD(=Password), Server, Port, DB(=Database), SID, Connection Method, Option를제공한다. 34 Tibero tbcli 안내서
53 파라미터 용도 Unix 계열은 Keyword 로 DSN, DESC(=Description), UID(=User), PWD(=Password), SID, Option 을제공한다. StringLength1 OutConnection String 입력 출력 연결문자열길이완성된연결문자열을저장할포인터최소 1024 byte 크기의버퍼를주어야하며, 여기에 NULL을입력하면 BufferLength, StringLength2Ptr도무시된다. BufferLength StringLength2Ptr DriverCompletion 입력 출력 입력 버퍼의 byte 크기 버퍼에저장된데이터의길이 사용하지않음 (SQL_DRIVER_NOPROMPT 입력 ) 반환코드 반환코드 SQL_SUCCESS 가성공적으로완료된상태 SQL_SUCCESS_WITH_INFO SQL_INVALID_HANDLE SQL_ERROR 가성공적으로완료되었으나, 경고메시지가있는상태 입력파라미터에주어진핸들이유효하지않은상태 치명적인에러가발생한상태 S S HY000 HY001 HY013 HY090 HYT00 일반적인경고문자열데이터가오른쪽에서잘린경우옵션의값이바뀐경우클라이언트가서버에연결하는것이불가능한경우이미사용중인데이터베이스연결의이름인경우서버가연결을거부한경우서버와의통신연결에실패한경우잘못된권한을설정한경우일반적인에러메모리할당에러메모리관리에러잘못된문자열또는버퍼길이제한시간을초과한경우 제 3 장 tbcli 35
54 HYT01 IM001 IM002 IM003 IM004 IM005 IM006 IM009 IM010 데이터베이스연결제한시간을초과한경우드라이버가 SQLDriverConnect 를지원하지않는경우데이터소스의이름을찾을수없거나, 디폴트드라이버가존재하지않는경우설정한드라이버를로드할수없는경우해당드라이버에 SQLAllocHandle 를이용한환경핸들할당에실패한경우해당드라이버에 SQLAllocHandle 를이용한연결핸들할당에실패한경우드라이버에 SQLSetConnectAttr 를이용한데이터베이스연결속성설정에실패한경우 Translation DLL에연결하는것이불가능한경우데이터소스의이름이 SQL_MAX_DSN_LENGTH 파라미터에설정된값보다긴경우 SQLEndTran ISO 92 CLI/ODBC 3.0에서지원하며, 현재트랜잭션을커밋하거나롤백하는이다. 커밋과롤백중어떤동작을실행할것인지는 SQLEndTran 의 CompletionType 파라미터로결정된다. 만약, 현재동작중인트랜잭션이없는경우에는데이터베이스서버에영향을주지않고, SQL_SUCCESS 를반환한다. SQLEndTran 의세부내용은다음과같다. 문법 SQLRETURN SQLEndTran (SQLSMALLINT SQLHANDLE SQLSMALLINT HandleType, Handle, CompletionType); 파라미터 파라미터 HandleType 용도 입력 할당받을핸들의타입이다. 아래타입중하나의값을갖는다. - SQL_HANDLE_ENV 36 Tibero tbcli 안내서
55 파라미터 용도 - SQL_HANDLE_DBC Handle CompletionType 입력 입력 핸들의포인터이다. 커밋또는롤백여부를나타내는타입이다. 아래타입중하나의값을갖는다. - SQL_COMMIT - SQL_ROLLBACK 반환코드 반환코드 SQL_SUCCESS 가성공적으로완료된상태 SQL_SUCCESS_WITH_INFO SQL_INVALID_HANDLE SQL_ERROR 가성공적으로완료되었으나, 경고메시지가있는상태 입력파라미터에주어진핸들이유효하지않은상태 치명적인에러가발생한상태 S01 25S02 25S HY000 HY001 HY010 HY012 HY013 HY092 HYC00 일반적인경고데이터베이스연결이존재하지않는경우트랜잭션을수행하는중에데이터베이스연결에실패한경우트랜잭션의상태트랜잭션이아직활성화되지않은경우트랜잭션이롤백된경우직렬화에실패한경우무결성제약조건에위배되는경우일반적인에러메모리할당에러시퀀스에러잘못된트랜잭션의연산코드인경우메모리관리에러잘못된속성및옵션식별자선택적인기능이구현되지않은경우 제 3 장 tbcli 37
56 HYT01 IM001 데이터베이스연결제한시간을초과한경우 드라이버가 SQLEndTran 를지원하지않는경우 SQLError (Deprecated) 특정명령문및데이터베이스연결또는환경핸들에대해가장최근에호출된의에러와상태정보를반환하는이다. 관련 SQLError 는 ODBC 3.x에서 SQLGetDiagRec 로대체된다 SQLExecDirect ISO 92 CLI/ODBC 1.0에서지원하며, 커밋이나롤백등의트랜잭션과관련된문장을제외한나머지 SQL 문장을직접실행하는이다. 커밋이나롤백을실행하기위해서는 SQLTransact 를호출해야한다. SQLExecDirect 를호출하기전에모든파라미터는바인드되어야하며, 연결할데이터베이스서버는 SQL 문장을미리준비해야한다. 이때 SQL 문장은한번만실행된다. SQLExecDirect 의세부내용은다음과같다. 문법 SQLRETURN SQLExecDirect (SQLHSTMT SQLCHAR * SQLINTEGER StatementHandle, StatementText, TextLength); 파라미터 파라미터 StatementHandle StatementText TextLength 용도입력입력입력 문장핸들 SQL 문장 SQL 문장의텍스트길이 반환코드 반환코드 SQL_SUCCESS 가성공적으로완료된상태 38 Tibero tbcli 안내서
57 반환코드 SQL_SUCCESS_WITH_INFO SQL_NO_DATA 가성공적으로완료되었으나, 경고메시지가있는상태 가성공적으로완료되었으나, 관련된데이터를찾을수없는상태 ( 예 : 주어진 SQL 문장에의해갱신된로우가없는경우 ) SQL_INVALID_HANDLE SQL_NEED_DATA 입력파라미터에주어진핸들이유효하지않은상태 SQL 문장을실행하기위해데이터가더필요한상태 ( 예 : 파라미터 ) SQL_STILL_EXECUTING SQL_ERROR 이전에실행한 SQL 문장이완료되지않은상태 치명적인에러가발생한상태 S02 01S S01 08S01 21S01 21S 일반적인경고커서연산이충돌된경우설정된에서 NULL 값을제거한경우문자열데이터가오른쪽에서잘린경우회수되지않은특권부여되지않은특권옵션의값이바뀐경우숫자타입이나날짜타입의일부정보가잘린경우 COUNT 필드에오류가있는경우제한된데이터타입의속성에위배되는경우디폴트파라미터를잘못사용한경우서버와의통신연결에실패한경우삽입될값의리스트가컬럼과일치하지않은경우테이블의 degree가컬럼과일치하지않은경우문자열데이터가오른쪽에서잘린경우지시자변수가요구되었으나제공되지않은경우한정된범위를초과한숫자값인경우잘못된 DATETIME 타입의포맷인경우 DATETIME 필드에오버플로우가발생한경우 0으로나눈경우 제 3 장 tbcli 39
58 D000 3F S01 42S02 42S11 42S12 42S21 42S HY000 HY001 HY008 HY009 HY010 HY013 HY090 HY105 HY109 HYC00 HYT00 HYT01 IM001 INTERVAL 필드에오버플로우가발생한경우캐스트설정을위한문자값이잘못된경우잘못된이스케이프문자잘못된이스케이프시퀀스무결성제약조건에위배되는경우잘못된커서상태인경우잘못된커서이름잘못된카탈로그이름잘못된스키마이름직렬화에실패한경우실행이완료되지않았고트랜잭션의상태를알수없는경우문법에러또는접근위배가발생한경우기반테이블또는뷰가이미존재하는경우기반테이블또는뷰를찾을수없는경우인덱스가이미존재하는경우인덱스를찾을수없는경우컬럼이이미존재하는경우컬럼을찾을수없는경우 WITH CHECK OPTION에위배되는경우일반적인에러메모리할당에러연산이취소된경우 NULL 포인터를잘못사용한경우시퀀스에러메모리관리에러잘못된문자열또는버퍼길이잘못된파라미터타입잘못된커서위치선택적인기능이구현되지않은경우제한시간을초과한경우데이터베이스연결제한시간을초과한경우드라이버가 SQLExecDirect 를지원하지않는경우 40 Tibero tbcli 안내서
59 SQLExecute ISO 92 CLI/ODBC 1.0에서지원하며, 준비된 SQL 문장을한번또는여러번실행하는이다. SQL 문장은 SQLBindParameter 를사용하여파라미터마커 (parameter maker) 에바인드된애플리케이션프로그램의변수에현재값을적용하여실행된다. 애플리케이션프로그램이 SQLExecute 를사용하여호출결과를처리하면, 애플리케이션프로그램의변수에새로운값을대입하여 SQL 문장을다시실행할수있다. SQLExecute 의세부내용은다음과같다. 문법 SQLRETURN SQLExecute (SQLHSTMT StatementHandle); 파라미터 파라미터 StatementHandle 용도 입력 문장핸들 반환코드 반환코드 SQL_SUCCESS 가성공적으로완료된상태 SQL_SUCCESS_WITH_INFO SQL_NO_DATA 가성공적으로완료되었으나, 경고메시지가있는상태 가성공적으로완료되었으나, 관련된데이터를찾을수없는상태 ( 예 : 주어진 SQL 문장에의해갱신된로우가없는경우 ) SQL_INVALID_HANDLE SQL_NEED_DATA 입력파라미터에주어진핸들이유효하지않은상태 SQL 문장을실행하기위해데이터가더필요한상태 ( 예 : 파라미터 ) SQL_STILL_EXECUTING SQL_ERROR 이전에실행한 SQL 문장이완료되지않은상태 치명적인에러가발생한상태 일반적인경고커서연산이충돌된경우설정된에서 NULL 값을제거한경우 제 3 장 tbcli 41
60 S02 01S S01 08S01 21S01 21S HY000 HY001 HY008 HY010 HY013 문자열데이터가오른쪽에서잘린경우회수되지않은특권부여되지않은특권옵션의값이바뀐경우숫자타입이나날짜타입의일부정보가잘린경우 COUNT 필드에오류가있는경우제한된데이터타입의속성에위배되는경우디폴트파라미터를잘못사용한경우서버와의통신연결에실패한경우삽입될값의리스트가컬럼과일치하지않은경우테이블의 degree가컬럼과일치하지않은경우문자열데이터가오른쪽에서잘린경우지시자변수가요구되었으나제공되지않은경우한정된범위를초과한숫자값인경우잘못된 DATETIME 타입의포맷인경우 DATETIME 필드에오버플로우가발생한경우 0으로나눈경우 INTERVAL 필드에오버플로우가발생한경우캐스트설정을위한문자값이잘못된경우잘못된이스케이프문자잘못된이스케이프시퀀스무결성제약조건에위배되는경우잘못된커서상태인경우직렬화에실패한경우실행이완료되지않았고트랜잭션의상태를알수없는경우문법에러또는접근위배가발생한경우 WITH CHECK OPTION에위배되는경우일반적인에러메모리할당에러연산이취소된경우시퀀스에러메모리관리에러 42 Tibero tbcli 안내서
61 HY090 HY105 HY109 HYC00 HYT00 HYT01 IM001 잘못된문자열또는버퍼길이잘못된파라미터타입잘못된커서위치선택적인기능이구현되지않은경우제한시간을초과한경우데이터베이스연결제한시간을초과한경우드라이버가 SQLExecute 를지원하지않는경우 SQLExtendedFetch (Deprecated) SQLExtendedFetch 는 ODBC 3.x 에서 SQLFetchScroll 로대체된다 SQLFetch ISO 92 CLI/ODBC 1.0에서지원하며, SQL 문장의실행결과에대해페치 (fetch) 를실행하고선택된모든컬럼의데이터를반환하는이다. 즉, 결과집합내에서다음행으로커서를이동하고바인드된컬럼을가져온다. 바인드되는컬럼이없는경우, 애플리케이션프로그램으로반환되는데이터는없으며커서만다음행으로이동된다. 그리고커서가이동한후바인드되지않은컬럼의데이터는삭제된다. SQLFetch 는가장최근에실행된 SQL 문장이 SELECT 문일때만호출할수있다. SQLFetch 의세부내용은다음과같다. 문법 SQLRETURN SQLFetch (SQLHSTMT StatementHandle); 파라미터 파라미터 StatementHandle 용도 입력 문장핸들 반환코드 반환코드 SQL_SUCCESS 가성공적으로완료된상태 SQL_SUCCESS_WITH_INFO 가성공적으로완료되었으나, 경고메시지가있는상태 제 3 장 tbcli 43
62 반환코드 SQL_NO_DATA 가성공적으로완료되었으나, 관련된데이터를찾을수없는상태 ( 예 : 주어진 SQL 문장에의해갱신된로우가없는경우 ) SQL_INVALID_HANDLE SQL_STILL_EXECUTING SQL_ERROR 입력파라미터에주어진핸들이유효하지않은상태 이전에실행한 SQL 문장이완료되지않은상태 치명적인에러가발생한상태 S01 01S S HY000 HY001 HY008 HY010 HY013 HY090 HY107 일반적인경고문자열데이터가오른쪽에서잘린경우로우에에러가있는경우숫자타입이나날짜타입의일부정보가잘린경우제한된데이터타입의속성에위배되는경우잘못된서술자인덱스서버와의통신연결에실패한경우문자열데이터가오른쪽에서잘린경우지시자변수가요구되었으나제공되지않은경우한정된범위를초과한숫자값인경우잘못된 DATETIME 타입의포맷인경우 0으로나눈경우 INTERVAL 필드에오버플로우가발생한경우캐스트설정을위한문자값이잘못된경우잘못된커서상태인경우직렬화에실패한경우실행이완료되지않았고트랜잭션의상태를알수없는경우일반적인에러메모리할당에러연산이취소된경우시퀀스에러메모리관리에러잘못된문자열또는버퍼길이결과집합영역내에서존재하지않는로우번호를참조하려는경우 44 Tibero tbcli 안내서
63 HYC00 HYT01 IM001 선택적인기능이구현되지않은경우데이터베이스연결제한시간을초과한경우드라이버가 SQLFetch 를지원하지않는경우 SQLFetchScroll ISO 92 CLI/ODBC 3.0 에서지원하며, 결과집합내의특정로우의집합을페치하고선택된모든컬럼을 반환하는이다. 로우의집합은절대적위치또는상대적위치에내용이삽입된다. SQLFetchScroll 의세부내용은다음과같다. 문법 SQLRETURN SQLFetchScroll (SQLHSTMT SQLSMALLINT SQLINTEGER StatementHandle, FetchOrientation, FetchOffset); 파라미터 파라미터 StatementHandle FetchOrientation 용도 입력 입력 문장핸들스크롤타입 - SQL_FETCH_NEXT: 다음행 - SQL_FETCH_PRIOR: 이전행 - SQL_FETCH_FIRST: 첫번째행 - SQL_FETCH_LAST: 마지막행 - SQL_FETCH_ABSOLUTE: 시작점을기준으로 FetchOffset 번째행 - SQL_FETCH_RELATIVE: 현재행을기준으로 FetchOffset 번째행 FetchOffset 입력 페치될행의번호 반환코드 반환코드 SQL_SUCCESS 가성공적으로완료된상태 SQL_SUCCESS_WITH_INFO 가성공적으로완료되었으나, 경고메시지가있는상태 제 3 장 tbcli 45
64 반환코드 SQL_NO_DATA 가성공적으로완료되었으나, 관련된데이터를찾을수없는상태 ( 예 : 주어진 SQL 문장에의해갱신된로우가없는경우 ) SQL_INVALID_HANDLE SQL_STILL_EXECUTING SQL_ERROR 입력파라미터에주어진핸들이유효하지않은상태 이전에실행한 SQL 문장이완료되지않은상태 치명적인에러가발생한상태 S01 01S06 01S S HY000 HY001 HY008 HY010 HY013 HY090 일반적인경고문자열데이터가오른쪽에서잘린경우로우에에러가있는경우결과집합이첫번째행의집합을반환하기전에페치를시도한경우숫자타입이나날짜타입의일부정보가잘린경우제한된데이터타입의속성에위배되는경우잘못된서술자인덱스서버와의통신연결에실패한경우문자열데이터가오른쪽에서잘린경우지시자변수가요구되었으나제공되지않은경우한정된범위를초과한숫자값인경우잘못된 DATETIME 타입의포맷인경우 0으로나눈경우 INTERVAL 필드에오버플로우가발생한경우캐스트설정을위한문자값이잘못된경우잘못된커서상태인경우직렬화에실패한경우실행이완료되지않았고트랜잭션의상태를알수없는경우일반적인에러메모리할당에러연산이취소된경우시퀀스에러메모리관리에러잘못된문자열또는버퍼길이 46 Tibero tbcli 안내서
65 HY106 HY107 HY111 HYC00 HYT01 IM001 영역밖의페치타입인경우결과집합영역내에서존재하지않는로우번호를참조하려는경우잘못된북마크값인경우선택적인기능이구현되지않은경우데이터베이스연결제한시간을초과한경우드라이버가 SQLFetchScroll 를지원하지않는경우 SQLForeignKeys ISO 92 CLI/ODBC 1.0에서지원하며, 테이블의외래키에대한정보를검색하는이다. 즉다른테이블내의기본키를참조하는해당테이블의컬럼과해당테이블의기본키를참조하는다른테이블의외래키의목록을검색한다. SQLForeignKeys 의세부내용은다음과같다. 문법 SQLRETURN SQLForeignKeys (SQLHSTMT SQLCHAR * SQLSMALLINT SQLCHAR * SQLSMALLINT SQLCHAR * SQLSMALLINT SQLCHAR * SQLSMALLINT SQLCHAR * SQLSMALLINT SQLCHAR * SQLSMALLINT StatementHandle, PKCatalogName, NameLength1, PKSchemaName, NameLength2, PKTableName, NameLength3, FKCatalogName, NameLength4, FKSchemaName, NameLength5, FKTableName, NameLength6); 파라미터 파라미터 StatementHandle PKCatalogName NameLength1 PKSchemaName NameLength2 용도입력입력입력입력입력 문장핸들기본키의카탈로그이름기본키의카탈로그이름의길이기본키의스키마이름기본키의스키마이름의길이 제 3 장 tbcli 47
66 파라미터 PKTableName NameLength3 FKCatalogName NameLength4 FKSchemaName NameLength5 FKTableName NameLength6 용도입력입력입력입력입력입력입력입력 기본키의테이블이름기본키의테이블이름의길이외래키의카탈로그이름외래키의카탈로그이름의길이외래키의스키마이름외래키의스키마이름의길이외래키의테이블이름외래키의테이블이름의길이 반환코드 반환코드 SQL_SUCCESS 가성공적으로완료된상태 SQL_SUCCESS_WITH_INFO SQL_INVALID_HANDLE SQL_STILL_EXECUTING SQL_ERROR 가성공적으로완료되었으나, 경고메시지가있는상태입력파라미터에주어진핸들이유효하지않은상태이전에실행한 SQL 문장이완료되지않은상태치명적인에러가발생한상태 S HY000 HY001 HY008 HY009 HY010 HY013 HY090 HYC00 일반적인경고서버와의통신연결에실패한경우잘못된커서상태인경우직렬화에실패한경우실행이완료되지않았고트랜잭션의상태를알수없는경우일반적인에러메모리할당에러연산이취소된경우 NULL 포인터를잘못사용한경우시퀀스에러메모리관리에러잘못된문자열또는버퍼길이선택적인기능이구현되지않은경우 48 Tibero tbcli 안내서
67 HYT00 HYT01 IM001 제한시간을초과한경우데이터베이스연결제한시간을초과한경우드라이버가 SQLForeignKeys 를지원하지않는경우 SQLFreeConnect (Deprecated) 연결핸들을무효화하고이와관련된모든자원을해제하는이다. 만약데이터베이스연결이유지된상태에서 SQLFreeConnect 를호출하면, SQL_ERROR가반환되고연결핸들은유효해진다. 관련 SQLFreeConnect 는 ODBC 3.x에서 SQLDisconnect 로대체된다 SQLFreeEnv (Deprecated) 환경핸들을무효화하고이와관련된모든자원을해제하는이다. 만약연결핸들이유효한상태에서 SQLFreeEnv 를호출하면, SQL_ERROR가반환되고환경핸들은유효해진다. 이를호출하기전에 SQLFreeConnect 를호출해야한다. 관련 SQLFreeEnv 는 ODBC 3.x에서 SQLFreeHandle 로대체된다 SQLFreeHandle ISO 92 CLI/ODBC 3.0 에서지원하며, 연결, 핸들, 명령문에할당된메모리를해제하는이다. SQLFreeHandle 의세부내용은다음과같다. 문법 SQLRETURN SQLFreeHandle (SQLSMALLINT SQLHANDLE HandleType, Handle); 파라미터 파라미터 HandleType 용도 입력 해제될핸들의타입이다. 제 3 장 tbcli 49
68 파라미터 용도 아래타입중하나의값을갖는다. - SQL_HANDLE_ENV - SQL_HANDLE_DBC - SQL_HANDLE_STMT Handle 입력 해제될핸들이다. 반환코드 반환코드 SQL_SUCCESS 가성공적으로완료된상태 SQL_INVALID_HANDLE SQL_ERROR 입력파라미터에주어진핸들이유효하지않은상태 치명적인에러가발생한상태 HY000 HY001 HY010 HY013 HY017 HYT01 IM001 일반적인에러메모리할당에러시퀀스에러메모리관리에러자동으로할당된서술자핸들을잘못사용한경우데이터베이스연결제한시간을초과한경우드라이버가 SQLFreeHandle 를지원하지않는경우 SQLFreeStmt ISO 92 CLI/ODBC 1.0에서지원하며, 명령문에할당된메모리를해제하는이다. SQL 문장을실행한후결과를처리하고나서 SQLFreeStmt 를호출한다. 이는열려있는커서를닫고, 파라미터를재설정한다. 또한컬럼의바인드를해제하고문장핸들을무효화하며핸들과관련된자원을해제한다. 이때 Option 파라미터에의해핸들을해제하는방식을설정할수있다. SQLFreeStmt 의세부내용은다음과같다. 문법 50 Tibero tbcli 안내서
69 SQLRETURN SQLFreeStmt (SQLHSTMT SQLUSMALLINT StatementHandle, Option); 파라미터 파라미터 StatementHandle Option 용도 입력 입력 문장핸들 핸들을해제하는방식 반환코드 반환코드 SQL_SUCCESS 가성공적으로완료된상태 SQL_SUCCESS_WITH_INFO SQL_INVALID_HANDLE SQL_ERROR 가성공적으로완료되었으나, 경고메시지가있는상태 입력파라미터에주어진핸들이유효하지않은상태 치명적인에러가발생한상태 HY000 HY001 HY010 HY013 HY092 HYT01 IM001 일반적인경고일반적인에러메모리할당에러시퀀스에러메모리관리에러잘못된속성및옵션식별자데이터베이스연결제한시간을초과한경우드라이버가 SQLFreeStmt 를지원하지않는경우 SQLGetConnectAttr ISO 92 CLI/ODBC 3.0 에서지원하며, 현재설정된데이터베이스연결의속성을반환하는이다. SQLGetConnectAttr 의세부내용은다음과같다. 문법 제 3 장 tbcli 51
70 SQLRETURN SQLGetConnectAttr (SQLHDBC SQLINTEGER SQLPOINTER SQLINTEGER SQLINTEGER * ConnectionHandle, Attribute, Value, BufferLength, StringLength); 파라미터 파라미터 ConnectionHandle Attribute Value BufferLength StringLength 용도입력입력출력입력출력 연결핸들이다. 검색할컬럼이다. 컬럼의현재값을저장한메모리의포인터이다. 실행결과를저장할버퍼의크기이다. Value 파라미터의길이이다. - NULL 포인터인경우길이를반환하지않는다. 반환코드 반환코드 SQL_SUCCESS 가성공적으로완료된상태 SQL_SUCCESS_WITH_INFO SQL_NO_DATA 가성공적으로완료되었으나, 경고메시지가있는상태 가성공적으로완료되었으나, 관련된데이터를찾을수없는상태 ( 예 : 주어진 SQL 문장에의해갱신된로우가없는경우 ) SQL_INVALID_HANDLE SQL_ERROR 입력파라미터에주어진핸들이유효하지않은상태 치명적인에러가발생한상태 S01 HY000 HY001 HY010 일반적인경고문자열데이터가오른쪽에서잘린경우데이터베이스연결이존재하지않는경우서버와의통신연결에실패한경우일반적인에러메모리할당에러시퀀스에러 52 Tibero tbcli 안내서
71 HY013 HY090 HY092 HYC00 HYT01 IM001 메모리관리에러잘못된문자열또는버퍼길이잘못된속성및옵션식별자선택적인기능이구현되지않은경우데이터베이스연결제한시간을초과한경우드라이버가 SQLGetConnectAttr 를지원하지않는경우 SQLGetConnectOption (Deprecated) SQLGetConnectOption 는 ODBC 3.x 에서 SQLGetConnectAttr 로대체된다 SQLGetCursorName ISO 92 CLI/ODBC 1.0 에서지원하며, 명시된문장과관련된커서의이름을반환하는이다. SQLGetCursorName 의세부내용은다음과같다. 문법 SQLRETURN SQLGetCursorName (SQLHSTMT SQLCHAR * SQLSMALLINT SQLSMALLINT * StatementHandle, CursorName, BufferLength, NameLength); 파라미터 파라미터 StatementHandle CursorName BufferLength NameLength 용도입력출력입력출력 문장핸들커서이름을저장한버퍼의포인터실행결과를저장할버퍼의크기커서이름의길이 반환코드 반환코드 SQL_SUCCESS 가성공적으로완료된상태 SQL_SUCCESS_WITH_INFO 가성공적으로완료되었으나, 경고메시지가있는상태 제 3 장 tbcli 53
72 반환코드 SQL_INVALID_HANDLE SQL_ERROR 입력파라미터에주어진핸들이유효하지않은상태 치명적인에러가발생한상태 HY000 HY001 HY010 HY013 HY015 HY090 HYT01 IM001 일반적인경고문자열데이터가오른쪽에서잘린경우일반적인에러메모리할당에러시퀀스에러메모리관리에러사용할수있는커서의이름이없는경우잘못된문자열또는버퍼길이데이터베이스연결제한시간을초과한경우드라이버가 SQLGetCursorName 를지원하지않는경우 SQLGetData ISO 92 CLI/ODBC 1.0에서지원하며, 결과집합의현재로우에서단일컬럼에대한데이터를검색하는이다. SQLFetch 를호출하여애플리케이션프로그램의변수로직접데이터를전달하는 SQLBinCol 대신이를사용할수있다. SQLGetData 의세부내용은다음과같다. 문법 SQLRETURN SQLGetData (SQLHSTMT SQLUSMALLINT SQLSMALLINT SQLPOINTER SQLINTEGER SQLINTEGER * StatementHandle, ColumnNumber, TargetType, TargetValue, BufferLength, StrLen_or_Ind); 파라미터 파라미터 StatementHandle 용도 입력 문장핸들 54 Tibero tbcli 안내서
73 파라미터 ColumnNumber TargetType TargetValue BufferLength StrLen_or_Ind 용도입력입력출력입력출력 검색할컬럼의위치검색된데이터가삽입될버퍼의 C의타입검색된데이터가삽입될버퍼의포인터버퍼의길이검색된데이터의길이나지시자 반환코드 반환코드 SQL_SUCCESS 가성공적으로완료된상태 SQL_SUCCESS_WITH_INFO SQL_NO_DATA 가성공적으로완료되었으나, 경고메시지가있는상태 가성공적으로완료되었으나, 관련된데이터를찾을수없는상태 ( 예 : 주어진 SQL 문장에의해갱신된로우가없는경우 ) SQL_INVALID_HANDLE SQL_STILL_EXECUTING SQL_ERROR 입력파라미터에주어진핸들이유효하지않은상태 이전에실행한 SQL 문장이완료되지않은상태 치명적인에러가발생한상태 S S HY000 일반적인경고문자열데이터가오른쪽에서잘린경우숫자타입이나날짜타입의일부정보가잘린경우제한된데이터타입의속성에위배되는경우잘못된서술자인덱스서버와의통신연결에실패한경우지시자변수가요구되었으나제공되지않은경우한정된범위를초과한숫자값인경우잘못된 DATETIME 타입의포맷인경우 0으로나눈경우 INTERVAL 필드에오버플로우가발생한경우캐스트설정을위한문자값이잘못된경우잘못된커서상태인경우일반적인에러 제 3 장 tbcli 55
74 HY001 HY003 HY008 HY009 HY010 HY013 HY090 HY109 HYC00 HYT01 IM001 메모리할당에러잘못된애플리케이션버퍼의타입연산이취소된경우 NULL 포인터를잘못사용한경우시퀀스에러메모리관리에러잘못된문자열또는버퍼길이잘못된커서위치선택적인기능이구현되지않은경우데이터베이스연결제한시간을초과한경우드라이버가 SQLGetData 를지원하지않는경우 SQLGetDescField ISO 92 CLI/ODBC 3.0 에서지원하며, 서술자레코드의컬럼값또는현재설정된내용을반환하는이 다. SQLGetDescField 의세부내용은다음과같다. 문법 SQLRETURN SQLGetDescField (SQLHDESC SQLSMALLINT SQLSMALLINT SQLPOINTER SQLINTEGER SQLINTEGER * DescriptorHandle, RecNumber, FieldIdentifier, Value, BufferLength, StringLength); 파라미터 파라미터 DescriptorHandle RecNumber FieldIdentifier Value BufferLength StringLength 용도입력입력입력출력입력출력 서술자핸들서술자레코드서술자값의컬럼서술자정보를저장한버퍼의포인터서술자정보를저장할버퍼의크기실행결과정보의길이 56 Tibero tbcli 안내서
75 반환코드 반환코드 SQL_SUCCESS SQL_SUCCESS_WITH_INFO SQL_NO_DATA 가성공적으로완료된상태가성공적으로완료되었으나, 경고메시지가있는상태가성공적으로완료되었으나, 관련된데이터를찾을수없는상태 ( 예 : RecNumber 파라미터가서술자레코드의현재숫자보다큰경우 또는, 서술자핸들이 IRD 인데해당커서가열리지않은경우 ) SQL_INVALID_HANDLE SQL_ERROR 입력파라미터에주어진핸들이유효하지않은상태 치명적인에러가발생한상태 S01 HY000 HY001 HY007 HY010 HY013 HY021 HY090 HY091 HYT01 IM001 일반적인경고문자열데이터가오른쪽에서잘린경우잘못된서술자인덱스서버와의통신연결에실패한경우일반적인에러메모리할당에러 SQL 문장이준비되지않은경우시퀀스에러메모리관리에러모순이있는서술자정보잘못된문자열또는버퍼길이잘못된서술자의필드식별자데이터베이스연결제한시간을초과한경우드라이버가 SQLGetDescField 를지원하지않는경우 SQLGetDescRec ISO 92 CLI/ODBC 3.0에서지원하며, 서술자레코드의여러개의컬럼값또는현재설정된내용을반환하는이다. 이때컬럼은명시된이름, 데이터타입그리고컬럼및파라미터의데이터를저장하는공간을반환한다. 제 3 장 tbcli 57
76 SQLGetDescRec 의세부내용은다음과같다. 문법 SQLRETURN SQLGetDescRec (SQLHDESC SQLSMALLINT SQLCHAR * SQLSMALLINT SQLSMALLINT * SQLSMALLINT * SQLSMALLINT * SQLINTEGER * SQLSMALLINT * SQLSMALLINT * SQLSMALLINT * DescriptorHandle, RecNumber, Name, BufferLength, StringLength, Type, SubType, Length, Precision, Scale, Nullable); 파라미터 파라미터 DescriptorHandle RecNumber Name BufferLength StringLength Type SubType Length Precision Scale Nullable 용도입력입력출력입력출력출력출력출력출력출력출력 서술자핸들서술자레코드 SQL_DESC_NAME 컬럼을저장한버퍼의포인터 Name 파라미터의버퍼길이반환된 SQL_DESC_NAME 컬럼의길이 SQL_DESC_TYPE 컬럼을저장한버퍼의포인터 SQL_DATETIME 타입인레코드에대해 SQL_DESC_DATETIME_INTER VAL_CODE 필드의값이반환될버퍼의포인터서술자레코드의길이정보서술자레코드의정밀도정보서술자레코드의스케일정보서술자레코드의 NULL 허용여부정보 반환코드 반환코드 SQL_SUCCESS 가성공적으로완료된상태 SQL_SUCCESS_WITH_INFO SQL_NO_DATA 가성공적으로완료되었으나, 경고메시지가있는상태 가성공적으로완료되었으나, 관련된데이터를찾을수없는상태 ( 예 : RecNumber 파라미터가서술자레코드의현재숫자보다큰경우 58 Tibero tbcli 안내서
77 반환코드 또는, 서술자핸들이 IRD 인데해당커서가열리지않은경우 ) SQL_INVALID_HANDLE SQL_ERROR 입력파라미터에주어진핸들이유효하지않은상태 치명적인에러가발생한상태 S01 HY000 HY001 HY007 HY010 HY013 HYT01 IM001 일반적인경고문자열데이터가오른쪽에서잘린경우잘못된서술자인덱스서버와의통신연결에실패한경우일반적인에러메모리할당에러 SQL 문장이준비되지않은경우시퀀스에러메모리관리에러데이터베이스연결제한시간을초과한경우드라이버가 SQLGetDescRec 를지원하지않는경우 SQLGetDiagField ISO 92 CLI/ODBC 3.0 에서지원하며, 특정핸들과관련된에러, 경고, 상태정보를포함하는진단의데이 터구조내임의의필드의현재값을반환하는이다. SQLGetDiagField 의세부내용은다음과같다. 문법 SQLRETURN SQLGetDiagField (SQLSMALLINT SQLHANDLE SQLSMALLINT SQLSMALLINT SQLPOINTER SQLSMALLINT SQLSMALLINT * HandleType, Handle, RecNumber, DiagIdentifier, DiagInfo, BufferLength, StringLength); 파라미터 제 3 장 tbcli 59
78 파라미터 HandleType Handle RecNumber DiagIdentifier DiagInfo BufferLength StringLength 용도입력입력입력입력출력입력출력 핸들의타입핸들상태레코드반환될값의진단컬럼진단정보를저장한버퍼의포인터버퍼의길이실행결과정보의길이 반환코드 반환코드 SQL_SUCCESS 가성공적으로완료된상태 SQL_SUCCESS_WITH_INFO SQL_NO_DATA 가성공적으로완료되었으나, 경고메시지가있는상태 가성공적으로완료되었으나, 관련된데이터를찾을수없는상태 ( 예 : 주어진 SQL 문장에의해갱신된로우가없는경우 ) SQL_INVALID_HANDLE SQL_ERROR 입력파라미터에주어진핸들이유효하지않은상태 치명적인에러가발생한상태 HY009 HY001 NULL 포인터를잘못사용한경우 메모리할당에러 SQLGetDiagRec ISO 92 CLI/ODBC 3.0에서지원하며, 특정핸들과관련된에러, 경고, 상태정보를포함하는진단레코드내의여러필드의현재값을반환하는이다. 이는하나의열을반환하는 SQLGetDiagField 와는다르게, 에러코드, 진단메시지의텍스트등을반환한다. SQLGetDiagRec 의세부내용은다음과같다. 문법 SQLRETURN SQLGetDiagRec (SQLSMALLINT SQLHANDLE HandleType, Handle, 60 Tibero tbcli 안내서
79 SQLSMALLINT SQLCHAR * SQLINTEGER * SQLCHAR * SQLSMALLINT SQLSMALLINT * RecNumber, Sqlstate, NativeError, MessageText, BufferLength, TextLength); 파라미터 파라미터 HandleType Handle RecNumber Sqlstate NativeError MessageText BufferLength TextLength 용도입력입력입력출력출력출력입력출력 핸들의타입핸들상태레코드 코드디폴트에러코드진단메시지의텍스트문자열진단메시지의텍스트문자열을저장할버퍼길이진단메시지의텍스트문자열의길이 반환코드 반환코드 SQL_SUCCESS 가성공적으로완료된상태 SQL_SUCCESS_WITH_INFO SQL_INVALID_HANDLE SQL_ERROR 가성공적으로완료되었으나, 경고메시지가있는상태 입력파라미터에주어진핸들이유효하지않은상태 가성공적으로완료되었으나, 관련된데이터를찾을수없는상태 ( 예 : RecNumber 파라미터가 0 이거나음수인경우 또는, 버퍼의길이가 0 보다작은경우 ) HY009 HY001 NULL 포인터를잘못사용한경우 메모리할당에러 제 3 장 tbcli 61
80 SQLGetEnvAttr ISO 92 CLI/ODBC 3.0 에서지원하며, 환경핸들과관련된컬럼의현재값을반환하는이다. SQLGetEnvAttr 의세부내용은다음과같다. 문법 SQLRETURN SQLGetEnvAttr (SQLHENV SQLINTEGER SQLPOINTER SQLINTEGER SQLINTEGER * EnvironmentHandle, Attribute, Value, BufferLength, StringLength); 파라미터 파라미터 Environmen thandle Attribute Value BufferLength StringLength 용도입력입력출력입력출력 환경핸들검색할컬럼컬럼의현재값 Value 파라미터가문자열인경우최대길이실행결과정보의길이 반환코드 반환코드 SQL_SUCCESS 가성공적으로완료된상태 SQL_SUCCESS_WITH_INFO SQL_NO_DATA 가성공적으로완료되었으나, 경고메시지가있는상태 가성공적으로완료되었으나, 관련된데이터를찾을수없는상태 ( 예 : 주어진 SQL 문장에의해갱신된로우가없는경우 ) SQL_INVALID_HANDLE SQL_ERROR 입력파라미터에주어진핸들이유효하지않은상태 치명적인에러가발생한상태 일반적인경고 문자열데이터가오른쪽에서잘린경우 62 Tibero tbcli 안내서
81 HY000 HY001 HY013 HY092 HYC00 IM001 일반적인에러메모리할당에러메모리관리에러잘못된속성및옵션식별자선택적인기능이구현되지않은경우드라이버가 SQLGetEnvAttr 를지원하지않은경우 SQLGetFunctions ISO 92 CLI/ODBC 1.0에서지원하며, 드라이버가특정를지원하는지의여부를알기위해사용하는이다. 이는드라이버관리자내에서사용할수있으며, 드라이버내에도사용할수있다. 만약드라이버내에서이를사용하는경우, 드라이버관리자는드라이버내의를호출하게된다. SQLGetFunctions 의세부내용은다음과같다. 문법 SQLRETURN SQLGetFunctions (SQLHDBC SQLUSMALLINT SQLUSMALLINT * ConnectionHandle, FunctionId, Supported); 파라미터 파라미터 ConnectionHandle FunctionId Supported 용도입력입력출력 연결핸들 ODBC 를호출할미리정의된값질의한가지원되는지의여부가저장될버퍼의포인터 - SQL_TRUE - SQL_FALSE 반환코드 반환코드 SQL_SUCCESS 가성공적으로완료된상태 SQL_SUCCESS_WITH_INFO SQL_INVALID_HANDLE 가성공적으로완료되었으나, 경고메시지가있는상태 입력파라미터에주어진핸들이유효하지않은상태 제 3 장 tbcli 63
82 반환코드 SQL_ERROR 치명적인에러가발생한상태 S01 HY000 HY001 HY010 HY013 HY095 HYT01 일반적인경고서버와의통신연결에실패한경우일반적인에러메모리할당에러시퀀스에러메모리관리에러영역밖의타입인경우데이터베이스연결제한시간을초과한경우 SQLGetInfo ISO 92 CLI/ODBC 1.0 에서지원하며, 드라이버의연결과관련된데이터소스의일반적인정보를반환하 는이다. SQLGetInfo 의세부내용은다음과같다. 문법 SQLRETURN SQLGetInfo (SQLHDBC SQLUSMALLINT SQLPOINTER SQLSMALLINT SQLSMALLINT * ConnectionHandle, InfoType, InfoValue, BufferLength, StringLength); 파라미터 파라미터 ConnectionHandle InfoType InfoValue BufferLength StringLength 용도입력입력출력입력출력 연결핸들정보의타입정보를저장할버퍼의포인터버퍼의길이반환된정보의길이 64 Tibero tbcli 안내서
83 반환코드 반환코드 SQL_SUCCESS SQL_SUCCESS_WITH_INFO SQL_INVALID_HANDLE SQL_ERROR 가성공적으로완료된상태가성공적으로완료되었으나, 경고메시지가있는상태입력파라미터에주어진핸들이유효하지않은상태치명적인에러가발생한상태 S01 HY000 HY001 HY013 HY024 HY090 HY096 HYC00 HYT01 IM001 일반적인경고문자열데이터가오른쪽에서잘린경우데이터베이스연결이존재하지않는경우서버와의통신연결에실패한경우일반적인에러메모리할당에러메모리관리에러잘못된속성값잘못된문자열또는버퍼길이영역밖의정보타입선택적인기능이구현되지않은경우데이터베이스연결제한시간을초과한경우드라이버가 SQLGetInfo 를지원하지않는경우 SQLGetStmtAttr ISO 92 CLI/ODBC 3.0 에서지원하며, SQL 문장의속성에대한현재값을반환하는이다. SQLGetStmtAttr 의세부내용은다음과같다. 문법 SQLRETURN SQLGetStmtAttr (SQLHSTMT SQLINTEGER SQLPOINTER SQLINTEGER SQLINTEGER * StatementHandle, Attribute, Value, BufferLength, StringLength); 제 3 장 tbcli 65
84 파라미터 파라미터 StatementHandle Attribute Value BufferLength StringLength 용도입력입력출력입력출력 문장핸들검색할속성명시된속성의현재값이반환될버퍼의포인터버퍼의길이반환된결과의길이 반환코드 반환코드 SQL_SUCCESS 가성공적으로완료된상태 SQL_SUCCESS_WITH_INFO SQL_INVALID_HANDLE SQL_ERROR 가성공적으로완료되었으나, 경고메시지가있는상태 입력파라미터에주어진핸들이유효하지않은상태 치명적인에러가발생한상태 HY000 HY001 HY010 HY013 HY090 HY092 HY109 HYC00 HYT01 IM001 일반적인경고문자열데이터가오른쪽에서잘린경우잘못된커서상태인경우일반적인에러메모리할당에러시퀀스에러메모리관리에러잘못된문자열또는버퍼길이잘못된속성및옵션식별자잘못된커서위치선택적인기능이구현되지않은경우데이터베이스연결제한시간을초과한경우드라이버가 SQLGetStmtAttr 를지원하지않는경우 66 Tibero tbcli 안내서
85 SQLGetStmtOption (Deprecated) SQLGetStmtOption 는 ODBC 3.x 에서 SQLGetStmtAttr 로대체된다 SQLGetTypeInfo ISO 92 CLI/ODBC 1.0에서지원하며, 데이터소스가지원하는데이터타입의정보를반환하는이다. 이때정보는 SQL 문장을실행한결과집합의형식으로반환된다. 애플리케이션프로그램은 ALTER TABLE과 CREATE TABLE 문장에이를호출하는경우결과집합의 TYPE_NAME 컬럼으로반환될타입의이름을사용한다. SQLGetTypeInfo 의세부내용은다음과같다. 문법 SQLRETURN SQLGetTypeInfo (SQLHSTMT SQLSMALLINT StatementHandle, DataType); 파라미터 파라미터 StatementHandle DataType 용도 입력 입력 문장핸들 SQL 의데이터타입 반환코드 반환코드 SQL_SUCCESS 가성공적으로완료된상태 SQL_SUCCESS_WITH_INFO SQL_INVALID_HANDLE SQL_STILL_EXECUTING SQL_ERROR 가성공적으로완료되었으나, 경고메시지가있는상태입력파라미터에주어진핸들이유효하지않은상태이전에실행한 SQL 문장이완료되지않은상태치명적인에러가발생한상태 S02 08S01 일반적인경고옵션의값이바뀐경우서버와의통신연결에실패한경우 제 3 장 tbcli 67
86 HY000 HY001 HY004 HY008 HY010 HY013 HYC00 HYT00 HYT01 IM001 잘못된커서상태인경우직렬화에실패한경우실행이완료되지않았고트랜잭션의상태를알수없는경우일반적인에러메모리할당에러잘못된 SQL의데이터타입연산이취소된경우시퀀스에러메모리관리에러선택적인기능이구현되지않은경우제한시간을초과한경우데이터베이스연결제한시간을초과한경우드라이버가 SQLGetTypeInfo 를지원하지않는경우 SQLMoreResults ISO 92 CLI/ODBC 1.0에서지원하며, SETECT, UPDATE, INSERT, DELETE 문을포함하는 SQL 문장이추가적으로실행결과를사용할것인지의여부를결정하는이다. 만약추가적으로실행결과를사용하는경우에는해당결과를초기화한다. SQLMoreResults 의세부내용은다음과같다. 문법 SQLRETURN SQLMoreResults(SQLHSTMT StatementHandle); 파라미터 파라미터 StatementHandle 용도 입력 문장핸들 반환코드 반환코드 SQL_SUCCESS 가성공적으로완료된상태 SQL_SUCCESS_WITH_INFO 가성공적으로완료되었으나, 경고메시지가있는상태 68 Tibero tbcli 안내서
87 반환코드 SQL_NO_DATA 가성공적으로완료되었으나, 관련된데이터를찾을수없는상태 ( 예 : 주어진 SQL 문장에의해갱신된로우가없는경우 ) SQL_INVALID_HANDLE SQL_STILL_EXECUTING SQL_ERROR 입력파라미터에주어진핸들이유효하지않은상태 이전에실행한 SQL 문장이완료되지않은상태 치명적인에러가발생한상태 S02 08S HY000 HY001 HY008 HY010 HY013 HYT01 IM001 일반적인경고옵션의값이바뀐경우서버와의통신연결에실패한경우직렬화에실패한경우실행이완료되지않았고트랜잭션의상태를알수없는경우일반적인에러메모리할당에러연산이취소된경우시퀀스에러메모리관리에러데이터베이스연결제한시간을초과한경우드라이버가 SQLMoreResults 를지원하지않는경우 SQLNativeSql ODBC 1.0 에서지원하며드라이버에의해변경되는 SQL 문자열을반환하는이다. 이때 SQL 문장은 실행하지않는다. SQLNativeSql 의세부내용은다음과같다. 문법 SQLRETURN SQLNativeSql (SQLHDBC SQLCHAR * SQLINTEGER SQLCHAR * ConnectionHandle, InStatementText, TextLength1, OutStatementText, 제 3 장 tbcli 69
88 SQLINTEGER SQLINTEGER * BufferLength, TextLength2); 파라미터 파라미터 ConnectionHandle InStatementText TextLength1 OutStatementText BufferLength TextLength2 용도입력입력입력출력입력출력 연결핸들변경될 SQL 문자열변경될 SQL 문자열의길이반환된 SQL 문자열반환된 SQL 문자열을저장할버퍼의길이반환결과의길이 반환코드 반환코드 SQL_SUCCESS 가성공적으로완료된상태 SQL_SUCCESS_WITH_INFO SQL_INVALID_HANDLE SQL_ERROR 가성공적으로완료되었으나, 경고메시지가있는상태 입력파라미터에주어진핸들이유효하지않은상태 치명적인에러가발생한상태 S HY000 HY001 HY009 HY013 HY090 HY109 일반적인경고문자열데이터가오른쪽에서잘린경우데이터베이스연결이존재하지않는경우서버와의통신연결에실패한경우잘못된 DATETIME 타입의포맷인경우잘못된커서상태인경우일반적인에러메모리할당에러 NULL 포인터를잘못사용한경우메모리관리에러잘못된문자열또는버퍼길이잘못된커서위치 70 Tibero tbcli 안내서
89 HYT01 IM001 데이터베이스연결제한시간을초과한경우 드라이버가 SQLNativeSql 를지원하지않는경우 SQLNumParams ODBC 1.0 에서지원하며, SQL 문장내의파라미터의개수를반환하는이다. SQLNumParams 의세부내용은다음과같다. 문법 SQLRETURN SQLNumParams (SQLHSTMT SQLSMALLINT * StatementHandle, ParameterCount); 파라미터 파라미터 StatementHandle ParameterCount 용도 입력 출력 문장핸들 반환정보를저장한버퍼의포인터 반환코드 반환코드 SQL_SUCCESS 가성공적으로완료된상태 SQL_SUCCESS_WITH_INFO SQL_INVALID_HANDLE SQL_STILL_EXECUTING SQL_ERROR 가성공적으로완료되었으나, 경고메시지가있는상태입력파라미터에주어진핸들이유효하지않은상태이전에실행한 SQL 문장이완료되지않은상태치명적인에러가발생한상태 S01 HY000 HY001 HY008 일반적인경고서버와의통신연결에실패한경우일반적인에러메모리할당에러연산이취소된경우 제 3 장 tbcli 71
90 HY010 HY013 HYT01 IM001 시퀀스에러메모리관리에러데이터베이스연결제한시간을초과한경우드라이버가 SQLNumParams 를지원하지않는경우 SQLNumResultCols ISO 92 CLI/ODBC 1.0에서지원하며, 입력문장핸들과관련된결과집합의컬럼수를반환하는이다. 가장최근에실행된 SQL 문장이 SELECT 문이아닌경우 0을반환한다. 이를호출하기전에 SQLPrepare 또는 SQLExecDirect 를호출해야한다. SQLNumResultCols 의세부내용은다음과같다. 문법 SQLRETURN SQLNumResultCols (SQLHSTMT SQLSMALLINT * StatementHandle, ColumnCount); 파라미터 파라미터 StatementHandle ColumnCount 용도 입력 출력 문장핸들 결과를저장할포인터 반환코드 반환코드 SQL_SUCCESS 가성공적으로완료된상태 SQL_SUCCESS_WITH_INFO SQL_INVALID_HANDLE SQL_STILL_EXECUTING SQL_ERROR 가성공적으로완료되었으나, 경고메시지가있는상태입력파라미터에주어진핸들이유효하지않은상태이전에실행한 SQL 문장이완료되지않은상태치명적인에러가발생한상태 일반적인경고 72 Tibero tbcli 안내서
91 08S01 HY000 HY001 HY008 HY010 HY013 HYT01 IM001 서버와의통신연결에실패한경우일반적인에러메모리할당에러연산이취소된경우시퀀스에러메모리관리에러데이터베이스연결제한시간을초과한경우드라이버가 SQLNumResultCols 를지원하지않는경우 SQLParamData ISO 92 CLI/ODBC 1.0 에서지원하며, SQL 문장을실행하는시간에파라미터데이터를지원하는이 다. 이는 SQLPutData 와함께사용한다. SQLParamData 의세부내용은다음과같다. 문법 SQLRETURN SQLParamData (SQLHSTMT SQLPOINTER * StatementHandle, Value); 파라미터 파라미터 StatementHandle Value 용도 입력 출력 문장핸들 SQLBindParameter 의 ParameterValue 파라미터나 SQLBindCol 의 TargetValue 파라미터를저장하기위한버퍼의포인터 반환코드 반환코드 SQL_SUCCESS 가성공적으로완료된상태 SQL_SUCCESS_WITH_INFO SQL_NO_DATA 가성공적으로완료되었으나, 경고메시지가있는상태 가성공적으로완료되었으나, 관련된데이터를찾을수없는상태 ( 예 : 주어진 SQL 문장에의해갱신된로우가없는경우 ) SQL_INVALID_HANDLE 입력파라미터에주어진핸들이유효하지않은상태 제 3 장 tbcli 73
92 반환코드 SQL_NEED_DATA SQL 문장을실행하기위해데이터가더필요한상태 ( 예 : 파라미터 ) SQL_STILL_EXECUTING SQL_ERROR 이전에실행한 SQL 문장이완료되지않은상태 치명적인에러가발생한상태 S HY000 HY001 HY008 HY010 HY013 HYT01 IM001 일반적인경고제한된데이터타입의속성에위배되는경우서버와의통신연결에실패한경우잘못된길이를가진문자열데이터직렬화에실패한경우실행이완료되지않았고트랜잭션의상태를알수없는경우일반적인에러메모리할당에러연산이취소된경우시퀀스에러메모리관리에러데이터베이스연결제한시간을초과한경우드라이버가 SQLParamData 를지원하지않는경우 SQLParamOptions (Deprecated) SQLParamOptions 는 ODBC 3.x 에서 SQLSetStmtAttr 로대체된다 SQLPrepare ISO 92 CLI/ODBC 1.0 에서지원하며, 실행할 SQL 문장을준비하는이다. 즉, SQL 문장을입력명령 핸들과연관시키고명령문을준비할데이터베이스서버로전송한다. SQLPrepare 의세부내용은다음과같다. 문법 74 Tibero tbcli 안내서
93 SQLRETURN SQLPrepare (SQLHSTMT SQLCHAR * SQLINTEGER StatementHandle, StatementText, TextLength); 파라미터 파라미터 StatementHandle StatementText TextLength 용도입력입력입력 문장핸들 SQL 문장 SQL 문장의길이 반환코드 반환코드 SQL_SUCCESS 가성공적으로완료된상태 SQL_SUCCESS_WITH_INFO SQL_INVALID_HANDLE SQL_STILL_EXECUTING SQL_ERROR 가성공적으로완료되었으나, 경고메시지가있는상태입력파라미터에주어진핸들이유효하지않은상태이전에실행한 SQL 문장이완료되지않은상태치명적인에러가발생한상태 S02 08S01 21S01 21S D000 3F S01 일반적인경고옵션의값이바뀐경우서버와의통신연결에실패한경우삽입될값의리스트가컬럼과일치하지않은경우테이블의 degree가컬럼과일치하지않은경우캐스트설정을위한문자값이잘못된경우잘못된이스케이프문자잘못된이스케이프시퀀스잘못된커서상태인경우잘못된커서이름잘못된카탈로그이름잘못된스키마이름문법에러또는접근위배가발생한경우기반테이블또는뷰가이미존재하는경우 제 3 장 tbcli 75
94 42S02 42S11 42S12 42S21 42S22 HY000 HY001 HY008 HY009 HY010 HY013 HY090 HYC00 HYT00 HYT01 IM001 기반테이블또는뷰를찾을수없는경우인덱스가이미존재하는경우인덱스를찾을수없는경우컬럼이이미존재하는경우컬럼을찾을수없는경우일반적인에러메모리할당에러연산이취소된경우 NULL 포인터를잘못사용한경우시퀀스에러메모리관리에러잘못된문자열또는버퍼길이선택적인기능이구현되지않은경우제한시간을초과한경우데이터베이스연결제한시간을초과한경우드라이버가 SQLPrepare 를지원하지않는경우 SQLPrimaryKeys ISO 92 CLI/ODBC 1.0 에서지원하며, 특정테이블에대한기본키의정보를리스트형태로반환하는 이다. SQLPrimaryKeys 의세부내용은다음과같다. 문법 SQLRETURN SQLPrimaryKeys (SQLHSTMT SQLCHAR * SQLSMALLINT SQLCHAR * SQLSMALLINT SQLCHAR * SQLSMALLINT StatementHandle, CatalogName, NameLength1, SchemaName, NameLength2, TableName, NameLength3); 파라미터 76 Tibero tbcli 안내서
95 파라미터 StatementHandle CatalogName NameLength1 SchemaName NameLength2 TableName NameLength3 용도입력입력입력입력입력입력입력 문장핸들카탈로그이름카탈로그이름의길이스키마이름스키마이름의길이테이블이름테이블이름의길이 반환코드 반환코드 SQL_SUCCESS 가성공적으로완료된상태 SQL_SUCCESS_WITH_INFO SQL_INVALID_HANDLE SQL_STILL_EXECUTING SQL_ERROR 가성공적으로완료되었으나, 경고메시지가있는상태입력파라미터에주어진핸들이유효하지않은상태이전에실행한 SQL 문장이완료되지않은상태치명적인에러가발생한상태 S HY000 HY001 HY008 HY009 HY010 HY013 HY090 HYC00 HYT00 일반적인경고서버와의통신연결에실패한경우잘못된커서상태인경우직렬화에실패한경우실행이완료되지않았고트랜잭션의상태를알수없는경우일반적인에러메모리할당에러연산이취소된경우 NULL 포인터를잘못사용한경우시퀀스에러메모리관리에러잘못된문자열또는버퍼길이선택적인기능이구현되지않은경우제한시간을초과한경우 제 3 장 tbcli 77
96 HYT01 IM001 데이터베이스연결제한시간을초과한경우 드라이버가 SQLPrimaryKeys 를지원하지않는경우 SQLProcedureColumns ODBC 1.0 에서지원하며, 명시된프로시저의결과집합을구성하는컬럼뿐만아니라, 입 / 출력파라미터 의목록을반환하는이다. 이때정보는명시된문장에대한결과집합의형태로반환한다. SQLProcedureColumns 의세부내용은다음과같다. 문법 SQLRETURN SQLProcedureColumns (SQLHSTMT SQLCHAR * SQLSMALLINT SQLCHAR * SQLSMALLINT SQLCHAR * SQLSMALLINT SQLCHAR * SQLSMALLINT StatementHandle, CatalogName, NameLength1, SchemaName, NameLength2, ProcName, NameLength3, ColumnName, NameLength4); 파라미터 파라미터 StatementHandle CatalogName NameLength1 SchemaName NameLength2 ProcName NameLength3 ColumnName NameLength4 용도입력입력입력입력입력입력입력입력입력 문장핸들카탈로그이름카탈로그이름의길이스키마이름스키마이름의길이프로시저이름프로시저이름의길이컬럼이름컬럼이름의길이 반환코드 78 Tibero tbcli 안내서
97 반환코드 SQL_SUCCESS SQL_SUCCESS_WITH_INFO SQL_INVALID_HANDLE SQL_STILL_EXECUTING SQL_ERROR 가성공적으로완료된상태 가성공적으로완료되었으나, 경고메시지가있는상태입력파라미터에주어진핸들이유효하지않은상태이전에실행한 SQL 문장이완료되지않은상태치명적인에러가발생한상태 S HY000 HY001 HY008 HY009 HY010 HY090 HYC00 HYT00 HYT01 IM001 일반적인경고서버와의통신연결에실패한경우잘못된커서상태인경우직렬화에실패한경우실행이완료되지않았고트랜잭션의상태를알수없는경우일반적인에러메모리할당에러연산이취소된경우 NULL 포인터를잘못사용한경우시퀀스에러잘못된문자열또는버퍼길이선택적인기능이구현되지않은경우제한시간을초과한경우데이터베이스연결제한시간을초과한경우드라이버가 SQLProcedureColumns 를지원하지않는경우 SQLProcedures ODBC 1.0 에서지원하며, 명시된데이터소스내에저장된프로시저이름의목록을반환하는이다. SQLProcedures 의세부내용은다음과같다. 문법 SQLRETURN SQLProcedures (SQLHSTMT SQLCHAR * StatementHandle, CatalogName, 제 3 장 tbcli 79
98 SQLSMALLINT SQLCHAR * SQLSMALLINT SQLCHAR * SQLSMALLINT NameLength1, SchemaName, NameLength2, ProcName, NameLength3); 파라미터 파라미터 StatementHandle CatalogName NameLength1 SchemaName NameLength2 ProcName NameLength3 용도입력입력입력입력입력입력입력 문장핸들카탈로그이름카탈로그이름의길이스키마이름스키마이름의길이프로시저이름프로시저이름의길이 반환코드 반환코드 SQL_SUCCESS 가성공적으로완료된상태 SQL_SUCCESS_WITH_INFO SQL_INVALID_HANDLE SQL_STILL_EXECUTING SQL_ERROR 가성공적으로완료되었으나, 경고메시지가있는상태입력파라미터에주어진핸들이유효하지않은상태이전에실행한 SQL 문장이완료되지않은상태치명적인에러가발생한상태 S HY000 HY001 HY008 일반적인경고서버와의통신연결에실패한경우잘못된커서상태인경우직렬화에실패한경우실행이완료되지않았고트랜잭션의상태를알수없는경우일반적인에러메모리할당에러연산이취소된경우 80 Tibero tbcli 안내서
99 HY009 HY010 HY013 HY090 HYC00 HYT00 HYT01 IM001 NULL 포인터를잘못사용한경우시퀀스에러메모리관리에러잘못된문자열또는버퍼길이선택적인기능이구현되지않은경우제한시간을초과한경우데이터베이스연결제한시간을초과한경우드라이버가 SQLProcedures 를지원하지않는경우 SQLPutData ISO 92 CLI/ODBC 1.0에서지원하며, 애플리케이션프로그램이 SQL 문장이실행되는시간에파라미터또는컬럼의데이터를드라이버로보내는것을허용하는이다. 이는문자, 바이너리또는특정데이터소스에서사용하는데이터타입등을갖는컬럼내의문자또는바이너리데이터의값을보내는데사용한다. 현재드라이버가유니코드데이터를지원하지않아도, 유니코드 C의데이터타입을바인드할수있도록지원한다. SQLPutData 의세부내용은다음과같다. 문법 SQLRETURN SQLPutData (SQLHSTMT SQLPOINTER SQLINTEGER StatementHandle, Data, StrLen_or_Ind); 파라미터 파라미터 StatementHandle Data StrLen_or_Ind 용도입력입력입력 문장핸들파라미터나컬럼의실제데이터를저장하는버퍼의포인터데이터의길이 반환코드 반환코드 SQL_SUCCESS 가성공적으로완료된상태 제 3 장 tbcli 81
100 반환코드 SQL_SUCCESS_WITH_INFO SQL_INVALID_HANDLE SQL_STILL_EXECUTING SQL_ERROR 가성공적으로완료되었으나, 경고메시지가있는상태입력파라미터에주어진핸들이유효하지않은상태이전에실행한 SQL 문장이완료되지않은상태치명적인에러가발생한상태 S01 08S HY000 HY001 HY008 HY009 HY010 HY013 HY019 HY020 HY090 HYT01 IM001 일반적인경고문자열데이터가오른쪽에서잘린경우제한된데이터타입의속성에위배되는경우디폴트파라미터가잘못사용된경우서버와의통신연결에실패한경우문자열데이터가오른쪽에서잘린경우한정된범위를초과한숫자값인경우잘못된 DATETIME 타입의포맷인경우 DATETIME 필드에오버플로우가발생한경우 0으로나눈경우 INTERVAL 필드에오버플로우가발생한경우캐스트설정을위한문자값이잘못된경우일반적인에러메모리할당에러연산이취소된경우 NULL 포인터를잘못사용한경우시퀀스에러메모리관리에러문자및바이너리가아닌데이터를나누어보낸경우 NULL 값을접합 (union) 하려고시도하는경우잘못된문자열또는버퍼길이데이터베이스연결제한시간을초과한경우드라이버가 SQLPutData 를지원하지않는경우 82 Tibero tbcli 안내서
101 SQLRowCount ISO 92 CLI/ODBC 1.0에서지원하며, UPDATE, INSERT, DELETE 문에의해영향을받는테이블또는테이블과관련된뷰의로우수를반환하는이다. 이는가장최근에실행된 SQL 문장이 UPDATE, INSERT, DELETE 문이아니거나실행에실패한경우 0을반환한다. 이를호출하기전에 SQLExecute 또는 SQLExecDirect 를호출해야한다. SQLRowCount 의세부내용은다음과같다. 문법 SQLRETURN SQLRowCount (SQLHSTMT SQINTEGER * StatementHandle, RowCount); 파라미터 파라미터 StatementHandle RowCount 용도 입력 출력 문장핸들 실행결과의로우를저장할포인터 반환코드 반환코드 SQL_SUCCESS 가성공적으로완료된상태 SQL_SUCCESS_WITH_INFO SQL_INVALID_HANDLE SQL_ERROR 가성공적으로완료되었으나, 경고메시지가있는상태 입력파라미터에주어진핸들이유효하지않은상태 치명적인에러가발생한상태 HY000 HY001 HY010 HY013 HYT01 IM001 일반적인경고일반적인에러메모리할당에러시퀀스에러메모리관리에러데이터베이스연결제한시간을초과한경우드라이버가 SQLRowCount 를지원하지않는경우 제 3 장 tbcli 83
102 SQLSetConnectAttr ISO 92 CLI/ODBC 3.0에서지원하며, 특정데이터베이스연결에대한연결속성의값을설정하는이다. 설정된모든데이터베이스연결과명령문의옵션은 SQLFreeConnect 가호출되거나 SQLSet ConnectAttr 에의해재설정이될때까지유지된다. SQLSetConnectAttr 의세부내용은다음과같다. 문법 SQLRETURN SQLSetConnectAttr (SQLHDBC SQLINTEGER SQLPOINTER SQLINTEGER ConnectionHandle, Attribute, Value, StringLength); 파라미터 파라미터 ConnectionHandle Attribute Value StringLength 용도입력입력입력입력 연결핸들설정할속성설정할속성의값이들어있는버퍼의포인터버퍼의길이 반환코드 반환코드 SQL_SUCCESS 가성공적으로완료된상태 SQL_SUCCESS_WITH_INFO SQL_INVALID_HANDLE SQL_ERROR 가성공적으로완료되었으나, 경고메시지가있는상태 입력파라미터에주어진핸들이유효하지않은상태 치명적인에러가발생한상태 S S 일반적인경고옵션의값이바뀐경우이미사용중인데이터베이스연결의이름인경우데이터베이스연결이존재하지않는경우서버와의통신연결에실패한경우잘못된커서상태인경우 84 Tibero tbcli 안내서
103 3D000 HY000 HY001 HY009 HY010 HY011 HY013 HY024 HY090 HY092 HYC00 HYT01 IM001 IM009 잘못된카탈로그이름일반적인에러메모리할당에러 NULL 포인터를잘못사용한경우시퀀스에러현재설정될수없는속성인경우메모리관리에러잘못된속성값잘못된문자열또는버퍼길이잘못된속성및옵션식별자선택적인기능이구현되지않은경우데이터베이스연결제한시간을초과한경우드라이버가 SQLSetConnectAttr 를지원하지않는경우 Translation DLL을로드하는것이불가능한경우 SQLSetConnectOption (Deprecated) SQLSetConnectOption 는 ODBC 3.x 에서 SQLSetConnectAttr 로대체된다 SQLSetCursorName ISO 92 CLI/ODBC 1.0에서지원하며, 현재실행중인 SQL 문장을커서이름으로연관시키는이다. 만약애플리케이션프로그램이이를호출하지않으면드라이버가 SQL 문장을실행하는데필요한커서이름을생성한다. SQLSetCursorName 의세부내용은다음과같다. 문법 SQLRETURN SQLSetCursorName (SQLHSTMT SQLCHAR * SQLSMALLINT StatementHandle, CursorName, NameLength); 파라미터 제 3 장 tbcli 85
104 파라미터 StatementHandle CursorName NameLength 용도입력입력입력 문장핸들커서이름커서이름의길이 반환코드 반환코드 SQL_SUCCESS 가성공적으로완료된상태 SQL_SUCCESS_WITH_INFO SQL_INVALID_HANDLE SQL_ERROR 가성공적으로완료되었으나, 경고메시지가있는상태 입력파라미터에주어진핸들이유효하지않은상태 치명적인에러가발생한상태 C000 HY000 HY001 HY009 HY010 HY013 HY090 HYT01 IM001 일반적인경고문자열데이터가오른쪽에서잘린경우잘못된커서상태인경우잘못된커서이름중복된커서이름일반적인에러메모리할당에러 NULL 포인터를잘못사용한경우시퀀스에러메모리관리에러잘못된문자열또는버퍼길이데이터베이스연결제한시간을초과한경우드라이버가 SQLSetCursorName 를지원하지않는경우 SQLSetDescField ISO 92 CLI/ODBC 3.0 에서지원하며, 서술자레코드의한필드의값을설정하는이다. SQLSetDescField 의세부내용은다음과같다. 86 Tibero tbcli 안내서
105 문법 SQLRETURN SQLSetDescField (SQLHDESC SQLSMALLINT SQLSMALLINT SQLPOINTER SQLINTEGER DescriptorHandle, RecNumber, FieldIdentifier, Value, BufferLength); 파라미터 파라미터 DescriptorHandle RecNumber 용도 입력 입력 서술자핸들서술자내에서해당필드의레코드번호 ( 레코드번호는 1부터시작한다.) FieldIdentifier Value BufferLength 입력 입력 입력 설정될필드의식별자 설정할값이들어있는버퍼의포인터 버퍼의길이 반환코드 반환코드 SQL_SUCCESS 가성공적으로완료된상태 SQL_SUCCESS_WITH_INFO SQL_INVALID_HANDLE SQL_ERROR 가성공적으로완료되었으나, 경고메시지가있는상태 입력파라미터에주어진핸들이유효하지않은상태 치명적인에러가발생한상태 S S HY000 HY001 HY010 HY013 일반적인경고옵션의값이바뀐경우잘못된서술자인덱스서버와의통신연결에실패한경우문자열데이터가오른쪽에서잘린경우일반적인에러메모리할당에러시퀀스에러메모리관리에러 제 3 장 tbcli 87
106 HY016 HY021 HY090 HY091 HY092 HY105 HYT01 IM001 구현로우서술자 (implementation row descriptor) 를수정할수없는경우모순이있는서술자정보잘못된문자열또는버퍼길이잘못된서술자의필드식별자잘못된속성및옵션식별자잘못된파라미터타입데이터베이스연결제한시간을초과한경우드라이버가 SQLSetDescField 를지원하지않는경우 SQLSetDescRec ISO 92 CLI/ODBC 3.0 에서지원하며, 컬럼또는파라미터데이터에사용되는버퍼와데이터타입에대해 여러개의서술자컬럼을설정하는이다. SQLSetDescRec 의세부내용은다음과같다. 문법 SQLRETURN SQLSetDescRec (SQLHDESC SQLSMALLINT SQLSMALLINT SQLSMALLINT SQLINTEGER SQLSMALLINT SQLSMALLINT SQLPOINTER SQLINTEGER * SQLINTEGER * DescriptorHandle, RecNumber, Type, SubType, Length, Precision, Scale, Data, StringLength, Indicator); 파라미터 파라미터 DescriptorHandle RecNumber Type SubType Length 용도입력입력입력입력입력 서술자핸들설정할컬럼을포함하는서술자레코드서술자레코드의종류서술자레코드의세부종류서술자레코드의길이컬럼 88 Tibero tbcli 안내서
107 파라미터 Precision Scale Data StringLength Indicator 용도입력입력입출력입출력입출력 서술자레코드의정밀도컬럼서술자레코드의스케일컬럼서술자레코드의데이터포인터컬럼서술자레코드의문자열길이컬럼서술자레코드의지시자포인터컬럼 반환코드 반환코드 SQL_SUCCESS 가성공적으로완료된상태 SQL_SUCCESS_WITH_INFO SQL_INVALID_HANDLE SQL_ERROR 가성공적으로완료되었으나, 경고메시지가있는상태 입력파라미터에주어진핸들이유효하지않은상태 치명적인에러가발생한상태 S01 HY000 HY001 HY010 HY013 HY016 HY021 HY090 HYT01 IM001 일반적인경고잘못된서술자인덱스서버와의통신연결에실패한경우일반적인에러메모리할당에러시퀀스에러메모리관리에러구현로우서술자를수정할수없는경우모순이있는서술자정보잘못된문자열또는버퍼길이데이터베이스연결제한시간을초과한경우드라이버가 SQLSetDescRec 를지원하지않는경우 SQLSetEnvAttr ISO 92 CLI/ODBC 3.0 에서지원하며, 현재환경핸들의속성값을설정하는이다. 제 3 장 tbcli 89
108 SQLSetEnvAttr 의세부내용은다음과같다. 문법 SQLRETURN SQLSetEnvAttr (SQLHENV SQLINTEGER SQLPOINTER SQLINTEGER EnvironmentHandle, Attribute, Value, StringLength); 파라미터 파라미터 EnvironmentHandle Attribute Value StringLength 용도입력입력입력입력 환경핸들설정할환경핸들의속성설정할환경핸들의속성값설정할환경핸들의속성값이문자형일때해당길이 반환코드 반환코드 SQL_SUCCESS 가성공적으로완료된상태 SQL_SUCCESS_WITH_INFO SQL_INVALID_HANDLE SQL_ERROR 가성공적으로완료되었으나, 경고메시지가있는상태 입력파라미터에주어진핸들이유효하지않은상태 치명적인에러가발생한상태 S02 HY000 HY001 HY009 HY010 HY013 HY024 HY090 HY092 일반적인경고옵션의값이바뀐경우일반적인에러메모리할당에러 NULL 포인터를잘못사용한경우시퀀스에러메모리관리에러잘못된속성값잘못된문자열또는버퍼길이잘못된속성및옵션식별자 90 Tibero tbcli 안내서
109 HYC00 선택적인기능이구현되지않은경우 SQLSetParam (Deprecated) SQLSetParam 는 ODBC 3.x 에서 SQLBindParameter 로대체된다 SQLSetPos ODBC 1.0에서지원하며, 로우집합내에서커서의위치를설정하거나애플리케이션프로그램이로우집합내의데이터를리프레시 (Refresh) 하도록허용하는이다. 또한, 이는결과집합내의데이터를갱신또는제거할수있다. SQLSetPos 의세부내용은다음과같다. 문법 SQLRETURN SQLSetPos (SQLHSTMT SQLUSMALLINT SQLUSMALLINT SQLUSMALLINT StatementHandle, RowNumber, Operation, LockType); 파라미터 파라미터 StatementHandle RowNumber Operation LockType 용도입력입력입력입력 문장핸들로우집합내의로우의위치수행할연산연산이수행된후로우에대한잠금의종류 반환코드 반환코드 SQL_SUCCESS 가성공적으로완료된상태 SQL_SUCCESS_WITH_INFO SQL_INVALID_HANDLE SQL_NEED_DATA 가성공적으로완료되었으나, 경고메시지가있는상태 입력파라미터에주어진핸들이유효하지않은상태 SQL 문장을실행하기위해데이터가더필요한상태 ( 예 : 파라미터 ) 제 3 장 tbcli 91
110 반환코드 SQL_STILL_EXECUTING SQL_ERROR 이전에실행한 SQL 문장이완료되지않은상태 치명적인에러가발생한상태 S01 01S S HY000 HY001 HY008 HY010 HY011 HY013 HY090 일반적인경고커서연산이충돌한경우문자열데이터가오른쪽에서잘린경우로우에에러가있는경우숫자타입이나날짜타입의일부정보가잘린경우제한된데이터타입의속성에위배되는경우잘못된서술자인덱스테이블의 degree가컬럼과일치하지않은경우문자열데이터가오른쪽에서잘린경우한정된범위를초과한숫자값인경우잘못된 DATETIME 타입의포맷인경우 DATETIME 필드에오버플로우가발생한경우 INTERVAL 필드에오버플로우가발생한경우캐스트설정을위한문자값이잘못된경우무결성제약조건에위배되는경우잘못된커서상태인경우직렬화에실패한경우실행이완료되지않았고트랜잭션의상태를알수없는경우문법에러또는접근위배가발생한경우 WITH CHECK OPTION에위배되는경우일반적인에러메모리할당에러연산이취소된경우시퀀스에러현재설정될수없는속성인경우메모리관리에러잘못된문자열또는버퍼길이 92 Tibero tbcli 안내서
111 HY092 HY107 HY109 HYC00 HYT00 HYT01 IM001 잘못된속성식별자결과집합영역내에서존재하지않는로우번호를참조하려는경우잘못된커서위치선택적인기능이구현되지않은경우제한시간을초과한경우데이터베이스연결제한시간을초과한경우드라이버가 SQLSetPos 를지원하지않는경우 SQLSetScrollOptions (Deprecated) SQLSetScrollOptions 는 ODBC 3.x 에서 SQLGetInfo 와 SQLSetStmtAttr 로대체된 다 SQLSetStmtAttr ISO 92 CLI/ODBC 3.0 에서지원하며, 특정문장핸들의속성을설정하는이다. 새로운 SQLSetStm tattr 에의해속성이재설정되거나문장핸들이삭제되기전에는기존에설정된속성이유지된다. SQLSetStmtAttr 의세부내용은다음과같다. 문법 SQLRETURN SQLSetStmtAttr (SQLHSTMT SQLINTEGER SQLPOINTER SQLINTEGER StatementHandle, Attribute, Value, StringLength); 파라미터 파라미터 StatementHandle Attribute Value StringLength 용도입력입력입력입력 문장핸들설정할문장핸들의속성설정할문장핸들의속성값설정할문장핸들의속성값이문자형일때해당길이 반환코드 제 3 장 tbcli 93
112 반환코드 SQL_SUCCESS SQL_SUCCESS_WITH_INFO SQL_INVALID_HANDLE SQL_ERROR 가성공적으로완료된상태 가성공적으로완료되었으나, 경고메시지가있는상태입력파라미터에주어진핸들이유효하지않은상태치명적인에러가발생한상태 S02 08S HY000 HY001 HY009 HY010 HY011 HY013 HY017 HY024 HY090 HY092 HYC00 HYT01 IM001 일반적인경고옵션의값이바뀐경우서버와의통신연결에실패한경우잘못된커서상태인경우일반적인에러메모리할당에러 NULL 포인터를잘못사용한경우시퀀스에러현재설정될수없는속성인경우메모리관리에러자동으로할당된서술자핸들을잘못사용한경우잘못된속성값잘못된문자열또는버퍼길이잘못된속성및옵션식별자선택적인기능이구현되지않은경우데이터베이스연결제한시간을초과한경우드라이버가 SQLSetStmtAttr 를지원하지않는경우 SQLSetStmtOption (Deprecated) SQLSetStmtOption 는 ODBC 3.x 에서 SQLSetStmtAttr 로대체된다 SQLSpecialColumns Xopen CLI/ISO 92 CLI/ODBC 1.0 에서지원하며, 테이블의특정컬럼의정보를검색하는이다. 94 Tibero tbcli 안내서
113 검색되는컬럼의정보로는해당테이블내의하나의로우를유일하게설정하는컬럼의최적집합 (optimal set) 그리고트랜잭션이로우의임의의값을변경할때, 자동으로변경되는컬럼이있다. SQLSpecialColumns 의세부내용은다음과같다. 문법 SQLRETURN SQLSpecialColumns (SQLHSTMT SQLUSMALLINT SQLCHAR * SQLSMALLINT SQLCHAR * SQLSMALLINT SQLCHAR * SQLSMALLINT SQLUSMALLINT SQLUSMALLINT StatementHandle, IdentifierType, CatalogName, NameLength1, SchemaName, NameLength2, TableName, NameLength3, Scope, Nullable); 파라미터 파라미터 StatementHandle IdentifierType CatalogName NameLength1 SchemaName NameLength2 TableName NameLength3 Scope Nullable 용도입력입력입력입력입력입력입력입력입력입력 문장핸들반환되는컬럼의타입카탈로그이름카탈로그이름의길이스키마이름스키마이름의길이테이블이름테이블이름의길이 ROWID의최소범위 NULL 값의허용여부 반환코드 반환코드 SQL_SUCCESS 가성공적으로완료된상태 SQL_SUCCESS_WITH_INFO SQL_INVALID_HANDLE SQL_STILL_EXECUTING SQL_ERROR 가성공적으로완료되었으나, 경고메시지가있는상태입력파라미터에주어진핸들이유효하지않은상태이전에실행한 SQL 문장이완료되지않은상태치명적인에러가발생한상태 제 3 장 tbcli 95
114 S HY000 HY001 HY008 HY009 HY010 HY013 HY090 HY097 HY098 HY099 HYC00 HYT00 HYT01 IM001 일반적인경고서버와의통신연결에실패한경우잘못된커서상태인경우직렬화에실패한경우실행이완료되지않았고트랜잭션의상태를알수없는경우일반적인에러메모리할당에러연산이취소된경우 NULL 포인터를잘못사용한경우시퀀스에러메모리관리에러잘못된문자열또는버퍼길이영역밖의컬럼인경우영역밖의범위 (scope) 타입인경우영역밖의 Nullable 타입인경우선택적인기능이구현되지않은경우제한시간을초과한경우데이터베이스연결제한시간을초과한경우드라이버가 SQLSpecialColumns 를지원하지않는경우 SQLStatistics Xopen CLI/ODBC 1.0 에서지원하며, 특정테이블의인덱스통계정보를검색하는이다. 이때정보는 결과집합의형태로반환된다. SQLStatistics 의세부내용은다음과같다. 문법 SQLRETURN SQLStatistics (SQLHSTMT SQLCHAR * SQLSMALLINT SQLCHAR * SQLSMALLINT StatementHandle, CatalogName, NameLength1, SchemaName, NameLength2, 96 Tibero tbcli 안내서
115 SQLCHAR * SQLSMALLINT SQLUSMALLINT SQLUSMALLINT TableName, NameLength3, Unique, Reserved); 파라미터 파라미터 StatementHandle CatalogName NameLength1 SchemaName NameLength2 TableName NameLength3 Unique Reserved 용도입력입력입력입력입력입력입력입력입력 문장핸들카탈로그이름카탈로그이름의길이스키마이름스키마이름의길이테이블이름테이블이름의길이인덱스의종류 SQL_ENSURE로설정된경우데이터베이스에서무조건통계정보를가져온다. 이외에는사용할수없다. 반환코드 반환코드 SQL_SUCCESS 가성공적으로완료된상태 SQL_SUCCESS_WITH_INFO SQL_INVALID_HANDLE SQL_STILL_EXECUTING SQL_ERROR 가성공적으로완료되었으나, 경고메시지가있는상태입력파라미터에주어진핸들이유효하지않은상태이전에실행한 SQL 문장이완료되지않은상태치명적인에러가발생한상태 S 일반적인경고서버와의통신연결에실패한경우잘못된커서상태인경우직렬화에실패한경우실행이완료되지않았고트랜잭션의상태를알수없는경우 제 3 장 tbcli 97
116 HY000 HY001 HY008 HY009 HY010 HY013 HY090 HY100 HY101 HYC00 HYT00 HYT01 IM001 일반적인에러메모리할당에러연산이취소된경우 NULL 포인터를잘못사용한경우시퀀스에러메모리관리에러잘못된문자열또는버퍼길이영역밖의고유옵션타입 (uniqueness option type) 영역밖의정확도옵션타입 (accuracy option type) 선택적인기능이구현되지않은경우제한시간을초과한경우데이터베이스연결제한시간을초과한경우드라이버가 SQLStatistics 를지원하지않는경우 SQLTablePrivileges ISO 92 CLI/ODBC 1.0 에서지원하며, 각테이블과관련된테이블이나권한목록의정보를반환하는 이다. 이때정보는결과집합의형태로반환한다. SQLTablePrivileges 의세부내용은다음과같다. 문법 SQLRETURN SQLTablePrivileges (SQLHSTMT SQLCHAR * SQLSMALLINT SQLCHAR * SQLSMALLINT SQLCHAR * SQLSMALLINT StatementHandle, CatalogName, NameLength1, SchemaName, NameLength2, TableName, NameLength3); 파라미터 파라미터 StatementHandle CatalogName NameLength1 용도입력입력입력 문장핸들카탈로그이름카탈로그이름의길이 98 Tibero tbcli 안내서
117 파라미터 SchemaName NameLength2 TableName NameLength3 용도입력입력입력입력 스키마이름스키마이름의길이테이블이름테이블이름의길이 반환코드 반환코드 SQL_SUCCESS 가성공적으로완료된상태 SQL_SUCCESS_WITH_INFO SQL_INVALID_HANDLE SQL_STILL_EXECUTING SQL_ERROR 가성공적으로완료되었으나, 경고메시지가있는상태입력파라미터에주어진핸들이유효하지않은상태이전에실행한 SQL 문장이완료되지않은상태치명적인에러가발생한상태 S HY000 HY001 HY008 HY009 HY010 HY013 HY090 HYC00 HYT00 HYT01 IM001 일반적인경고서버와의통신연결에실패한경우잘못된커서상태인경우직렬화에실패한경우실행이완료되지않았고트랜잭션의상태를알수없는경우일반적인에러메모리할당에러연산이취소된경우 NULL 포인터를잘못사용한경우시퀀스에러메모리관리에러잘못된문자열또는버퍼길이선택적인기능이구현되지않은경우제한시간을초과한경우데이터베이스연결제한시간을초과한경우드라이버가 SQLTablePrivileges 를지원하지않는경우 제 3 장 tbcli 99
118 SQLTables Xopen CLI/ISO 92 CLI/ODBC 1.0에서지원하며, 연결된특정데이터소스의데이터사전에저장된테이블이름의리스트의정보를반환하는이다. 이때정보는결과집합의형태로반환되므로 SELECT 문에의해생성된결과집합과같이사용된다. SQLTables 의세부내용은다음과같다. 문법 SQLRETURN SQLTables (SQLHSTMT SQLCHAR * SQLSMALLINT SQLCHAR * SQLSMALLINT SQLCHAR * SQLSMALLINT SQLCHAR * SQLSMALLINT StatementHandle, CatalogName, NameLength1, SchemaName, NameLength2, TableName, NameLength3, TableType, NameLength4); 파라미터 파라미터 StatementHandle CatalogName NameLength1 SchemaName NameLength2 TableName NameLength3 TableType NameLength4 용도입력입력입력입력입력입력입력입력입력 문장핸들카탈로그이름카탈로그이름의길이스키마이름스키마이름의길이테이블이름테이블이름의길이테이블의데이터타입테이블의데이터타입의길이 반환코드 반환코드 SQL_SUCCESS 가성공적으로완료된상태 SQL_SUCCESS_WITH_INFO SQL_INVALID_HANDLE SQL_STILL_EXECUTING 가성공적으로완료되었으나, 경고메시지가있는상태 입력파라미터에주어진핸들이유효하지않은상태 이전에실행한 SQL 문장이완료되지않은상태 100 Tibero tbcli 안내서
119 반환코드 SQL_ERROR 치명적인에러가발생한상태 S HY000 HY001 HY008 HY009 HY010 HY013 HY090 HYC00 HYT00 HYT01 IM001 일반적인경고서버와의통신연결에실패한경우잘못된커서상태인경우직렬화에실패한경우실행이완료되지않았고트랜잭션의상태를알수없는경우일반적인에러메모리할당에러연산이취소된경우 NULL 포인터를잘못사용한경우시퀀스에러메모리관리에러잘못된문자열또는버퍼길이선택적인기능이구현되지않은경우제한시간을초과한경우데이터베이스연결제한시간을초과한경우드라이버가 SQLTables 를지원하지않는경우 SQLTransact (Deprecated) 수행된데이터베이스의모든변경에대해커밋을하거나롤백을하는이다. 만약트랜잭션이사용중이면애플리케이션프로그램은데이터베이스의연결이끊기기전에이를호출해야한다. 이가호출되면열린상태인커서가닫히고처리되지않은결과집합은삭제된다. 관련 SQLTransact 는 ODBC 3.x에서 SQLEndTran 로대체된다. 제 3 장 tbcli 101
120 3.2. Tibero API SQLAllocEnv2 (Deprecated) SQLAllocEnv 와같이환경핸들과연관된메모리를할당하고초기화하는이다. 또한, tbcli를사용하는애플리케이션프로그램이멀티스레드를사용하지는지의여부를설정할수있다. 멀티스레드는운영체제별로설정하는방법이다음과같이다르다. 운영체제 UNIX 계열 Windows 계열 UNIX 계열은디폴트로멀티스레드를사용하지않는것으로설정되어있다. 멀티스레드를사용하려면반드시마지막파라미터인 UseMultiThread의값에 'TRUE' 를설정해줘야한다. UseMultiThread의값에상관없이멀티스레드를사용할수있으므로 SQLAllocEnv2 또는 SQLAllocHandle2 를사용하지않기를권장한다. 이는환경핸들을처음할당할때사용해야만멀티스레드의사용여부를적용할수있다. 관련 SQLAllocEnv2 는 SQLAllocHandle2 로대체된다 SQLAllocHandle2 환경, 연결, 문장핸들을할당하고, tbcli를사용하는프로그램이멀티스레드를사용하는지의여부를설정할수있는이다. 멀티스레드를운영체제별로설정하는방법은 SQLAllocHandle 와같다. SQLAllocHandle2 의세부내용은다음과같다. 문법 SQLRETURN SQLAllocHandle (SQLSMALLINT SQLHANDLE SQLHANDLE * SQLSMALLINT HandleType, InputHandle, OutputHandle, UseMultiThread); 파라미터 파라미터 HandleType 용도 입력 할당받을핸들의타입이다. 102 Tibero tbcli 안내서
121 파라미터 용도 아래타입중하나의값을갖는다. - SQL_HANDLE_ENV - SQL_HANDLE_DBC - SQL_HANDLE_STMT InputHandle 입력 입력핸들이다. 핸들의타입에따라다른값을갖는다. - SQL_HANDLE_ENV: SQL_NULL_HANDLE - SQL_HANDLE_DBC: 환경핸들 - SQL_HANDLE_STMT: 연결핸들 OutputHandle 출력 할당받을핸들의포인터이다. 환경핸들이아닌다른핸들을할당할때 SQL_ERROR를반환하는경우, OutputHandle 파라미터를 SQL_NULL_HDBC, SQL_NULL_HSTMT 로할당한다. UseMultiThread 입력 멀티스레드의사용여부를설정한다. 멀티스레드환경에서 tbcli 를사용하는경우이값을 SQL_TRUE 로설 정한다. 반환코드 반환코드 SQL_SUCCESS 가성공적으로완료된상태 SQL_SUCCESS_WITH_INFO SQL_INVALID_HANDLE SQL_ERROR 가성공적으로완료되었으나, 경고메시지가있는상태 입력파라미터에주어진핸들이유효하지않은상태 치명적인에러가발생한상태 HY000 HY001 일반적인경고데이터베이스연결이존재하지않는경우일반적인에러메모리할당에러 제 3 장 tbcli 103
122 HY009 HY010 HY013 HY014 HY092 HYC00 HYT01 IM001 NULL 포인터를잘못사용한경우시퀀스에러메모리관리에러한정된범위의핸들개수를초과한경우잘못된속성및옵션식별자선택적인기능이구현되지않은경우데이터베이스연결제한시간을초과한경우드라이버가 SQLAllocHandle2 를지원하지않는경우 관련 이는 SQLAllocConnect, SQLAllocEnv2, SQLAllocstmt 를대체하는이다 SQLLobClose 연산의대상이되는 LOB를닫는이다. 트랜잭션이완료되기전에대상이되는 LOB가반드시닫혀야에러가발생하지않는다. 또한열지않은 LOB를닫으려할때에도에러가발생한다. 그리고 Open 및 Close를호출하지않고각 LOB와관련된를호출하면마다내부적으로 Open 및 Close를수행한다. SQLLobClose 의세부내용은다음과같다. 문법 SQLRETURN SQLLobClose (SQLHSTMT SQLINTEGER SQLINTEGER * StatementHandle, Locator, Indicator); 파라미터 파라미터 StatementHandle Locator Indicator 용도입력입력입력 문장핸들 LOB locator NULL 지시자 (indicator) 의포인터 반환코드 104 Tibero tbcli 안내서
123 반환코드 SQL_SUCCESS SQL_INVALID_HANDLE SQL_ERROR 가성공적으로완료된상태입력파라미터에주어진핸들이유효하지않은상태치명적인에러가발생한상태 HY000 HY001 HY010 HY013 HYT01 IM001 일반적인경고일반적인에러메모리할당에러시퀀스에러메모리관리에러데이터베이스연결제한시간을초과한경우드라이버가 SQLLobClose 를지원하지않는경우 SQLLobGetData 원하는위치의대용량객체형의데이터를가져오는이다. 단, BLOB 와 CLOB 에따라가져오는데이 터가다르다. SQLLobGetData 의세부내용은다음과같다. 문법 SQLRETURN SQLLobGetData (SQLHSTMT SQLINTEGER SQLBIGINT SQLINTEGER * SQLINTEGER * SQLSMALLINT SQLPOINTER SQLINTEGER SQLINTEGER * StatementHandle, SourceLocator, Offset, ByteLength, CharLength, TargetCType, Data, BufferLength, Indicator); 파라미터 파라미터 StatementHandle 용도 입력 문장핸들 제 3 장 tbcli 105
124 파라미터 SourceLocator Offset ByteLength CharLength TargetCType Data BufferLength Indicator 용도입력입력입력입력출력출력출력입력 LOB locator NULL 지시자 (indicator) 의포인터 BLOB 타입의반환될데이터의길이 CLOB 타입의반환될데이터의길이반환될데이터의 C 타입반환될데이터포인터반환될데이터버퍼의길이 NULL 지시자의포인터 반환코드 반환코드 SQL_SUCCESS 가성공적으로완료된상태 SQL_SUCCESS_WITH_INFO SQL_NO_DATA 가성공적으로완료되었으나, 경고메시지가있는상태 가성공적으로완료되었으나, 관련된데이터를찾을수없는상태 ( 예 : 주어진 SQL 문장에의해갱신된로우가없는경우 ) SQL_INVALID_HANDLE SQL_STILL_EXECUTING SQL_ERROR 입력파라미터에주어진핸들이유효하지않은상태 이전에실행한 SQL 문장이완료되지않은상태 치명적인에러가발생한상태 S S 일반적인경고문자열데이터가오른쪽에서잘린경우숫자타입이나날짜타입의일부정보가잘린경우제한된데이터타입의속성에위배되는경우잘못된서술자인덱스서버와의통신연결에실패한경우지시자변수가요구되었으나제공되지않은경우한정된범위를초과한숫자값인경우잘못된 DATETIME 타입의포맷인경우 0으로나눈경우 INTERVAL 필드에오버플로우가발생한경우 106 Tibero tbcli 안내서
125 HY000 HY001 HY003 HY008 HY009 HY010 HY013 HY090 HY109 HYC00 HYT01 IM001 캐스트설정을위한문자값이잘못된경우잘못된커서상태인경우일반적인에러메모리할당에러잘못된애플리케이션의버퍼타입연산이취소된경우 NULL 포인터를잘못사용한경우시퀀스에러메모리관리에러잘못된문자열또는버퍼길이잘못된커서위치선택적인기능이구현되지않은경우데이터베이스연결제한시간을초과한경우드라이버가 SQLLobGetData 를지원하지않는경우 SQLLobGetLength 특정 LOB 데이터의길이를검색하는이다. BLOB 와 CLOB 데이터타입모두에사용할수있다. SQLLobGetLength 의세부내용은다음과같다. 문법 SQLRETURN SQLLobGetLength (SQLHSTMT SQLINTEGER SQLBIGINT * SQLINTEGER * StatementHandle, Locator, StringLength, Indicator); 파라미터 파라미터 StatementHandle Locator StringLength Indicator 용도입력입력출력입력 문장핸들 LOB locator 반환될 LOB 데이터의길이 NULL 지시자의포인터 제 3 장 tbcli 107
126 반환코드 반환코드 SQL_SUCCESS SQL_SUCCESS_WITH_INFO SQL_INVALID_HANDLE SQL_ERROR 가성공적으로완료된상태가성공적으로완료되었으나, 경고메시지가있는상태입력파라미터에주어진핸들이유효하지않은상태치명적인에러가발생한상태 S01 HY000 HY001 HY008 HY009 HY010 HY013 HY019 HY020 HY090 HYC00 0F001 일반적인경고제한된데이터타입의속성에위배되는경우서버와의통신연결에실패한경우일반적인에러메모리할당에러연산이취소된경우 NULL 포인터를잘못사용한경우시퀀스에러메모리관리에러문자및바이너리가아닌데이터를나누어보낸경우 NULL 값을접합하려고시도하는경우잘못된문자열또는버퍼길이선택적인기능이구현되지않은경우 LOB의토큰에아무런값도없는경우 SQLLobGetPosition LOB 데이터내에서원하는문자열의위치를검색하는이다. SQLLobGetPosition 의세부내용은다음과같다. 문법 SQLRETURN SQLLobGetPosition (SQLHSTMT SQLINTEGER SQLINTEGER StatementHandle, SourceLocator, SearchLocator, 108 Tibero tbcli 안내서
127 SQLCHAR * SQLINTEGER SQLBIGINT SQLBIGINT * SQLINTEGER * SearchLiteral, SearchLiteralLength, FromPosition, LocatedAt, Indicator); 파라미터 파라미터 StatementHandle SourceLocator SearchLocator SearchLiteral SearchLiteralLength FromPosition LocatedAt Indicator 용도입력입력입력입력입력입력출력입력 문장핸들 LOB locator LOB locator 검색할문자열검색할문자열의길이검색을시작할위치반환할데이터의위치값 NULL 지시자의포인터 반환코드 반환코드 SQL_SUCCESS 가성공적으로완료된상태 SQL_SUCCESS_WITH_INFO SQL_INVALID_HANDLE SQL_STILL_EXECUTING SQL_ERROR 가성공적으로완료되었으나, 경고메시지가있는상태입력파라미터에주어진핸들이유효하지않은상태이전에실행한 SQL 문장이완료되지않은상태치명적인에러가발생한상태 S HY000 HY001 HY008 일반적인경고제한된데이터타입의속성에위배되는경우서버와의통신연결에실패한경우연산자또는의피연산자가호환되지않는경우일반적인에러메모리할당에러연산이취소된경우 제 3 장 tbcli 109
128 HY009 HY010 HY013 HY090 HYC00 0F001 NULL 포인터를잘못사용한경우시퀀스에러메모리관리에러잘못된문자열또는버퍼길이선택적인기능이구현되지않은경우 LOB의토큰에아무런값도없는경우 SQLLobOpen 연산의대상이될 LOB 데이터를여는이다. 이는각종 LOB 연산을할때항상먼저선언되어야한다. 그리고 Open 및 Close를호출하지않고각 LOB와관련된를호출하면마다내부적으로 Open 및 Close를수행한다. 한트랜잭션에서같은 LOB 인스턴스를두번열면에러가발생한다. 또한, 다른 locator를사용해다시열려고해도마찬가지로에러가발생한다. SQLLobOpen 의세부내용은다음과같다. 문법 SQLRETURN SQLLobOpen (SQLHSTMT SQLINTEGER SQLSMALLINT SQLINTEGER * StatementHandle, Locator, Mode, Indicator); 파라미터 파라미터 StatementHandle SourceLocator Mode Indicator 용도입력입력입력입력 문장핸들 LOB locator 반환할데이터의위치값 NULL 지시자의포인터 반환코드 반환코드 SQL_SUCCESS 가성공적으로완료된상태 SQL_SUCCESS_WITH_INFO 가성공적으로완료되었으나, 경고메시지가있는상태 110 Tibero tbcli 안내서
129 반환코드 SQL_INVALID_HANDLE SQL_STILL_EXECUTING SQL_ERROR 입력파라미터에주어진핸들이유효하지않은상태이전에실행한 SQL 문장이완료되지않은상태치명적인에러가발생한상태 HY000 HY001 HY010 HY013 HYT01 IM001 일반적인경고잘못된커서상태인경우일반적인에러메모리할당에러시퀀스에러메모리관리에러데이터베이스연결제한시간을초과한경우드라이버가 SQLLobOpen 를지원하지않는경우 SQLLobPutData LOB 내에서원하는위치에데이터를쓰는이다. SQLLobPutData 의세부내용은다음과같다. 문법 SQLRETURN SQLLobPutData (SQLHSTMT SQLINTEGER * SQLBIGINT SQLSMALLINT SQLPOINTER SQLINTEGER * SQLINTEGER * SQLINTEGER * StatementHandle, DestLocator, DestOffset, SourceCType, Source, ByteLength, CharLength, Indicator); 파라미터 파라미터 StatementHandle DestLocator 용도 입력 입력 문장핸들 LOB locator 제 3 장 tbcli 111
130 파라미터 DestOffset SourceCType Source ByteLength CharLength Indicator 용도입력입력입력출력출력입력 LOB 데이터에쓸위치쓸데이터의 C의타입쓸데이터의포인터 BLOB 타입의쓴데이터의길이 CLOB 타입의쓴데이터의길이 NULL 지시자의포인터 반환코드 반환코드 SQL_SUCCESS 가성공적으로완료된상태 SQL_SUCCESS_WITH_INFO SQL_INVALID_HANDLE SQL_STILL_EXECUTING SQL_ERROR 가성공적으로완료되었으나, 경고메시지가있는상태입력파라미터에주어진핸들이유효하지않은상태이전에실행한 SQL 문장이완료되지않은상태치명적인에러가발생한상태 HY000 HY001 HY010 HY013 HYT01 IM001 일반적인경고잘못된커서상태인경우일반적에러메모리할당에러시퀀스에러메모리관리에러데이터베이스연결제한시간을초과한경우드라이버가 SQLLobPutData 를지원하지않는경우 SQLLobTruncate LOB 데이터를잘라내는이다. SQLLobTruncate 의세부내용은다음과같다. 문법 112 Tibero tbcli 안내서
131 SQLRETURN SQLLobTruncate (SQLHSTMT SQLINTEGER * SQLBIGINT SQLINTEGER * StatementHandle, Locator, NewLength, Indicator); 파라미터 파라미터 StatementHandle Locator NewLength Indicator 용도입력입력입력입력 문장핸들 LOB locator 잘린후 LOB 데이터의새로운길이 NULL 지시자의포인터 반환코드 반환코드 SQL_SUCCESS 가성공적으로완료된상태 SQL_SUCCESS_WITH_INFO SQL_INVALID_HANDLE SQL_STILL_EXECUTING SQL_ERROR 가성공적으로완료되었으나, 경고메시지가있는상태입력파라미터에주어진핸들이유효하지않은상태이전에실행한 SQL 문장이완료되지않은상태치명적인에러가발생한상태 S01 08S01 HY000 HY001 HY008 HY009 HY010 HY013 HY019 일반적인경고문자열데이터가오른쪽에서잘린경우제한된데이터타입의속성에위배되는경우디폴트파라미터가잘못사용된경우서버와의통신연결에실패한경우일반적인에러메모리할당에러연산이취소된경우 NULL 포인터를잘못사용한경우시퀀스에러메모리관리에러문자및바이너리가아닌데이터를나누어보낸경우 제 3 장 tbcli 113
132 HY090 HYT01 잘못된문자열또는버퍼길이 데이터베이스연결제한시간을초과한경우 114 Tibero tbcli 안내서
133 제 4 장 tbcli 에러메시지 본장에서는 tbcli 프로그램을실행하는과정에서발생할수있는에러를한다 반환코드 모든 tbcli 는실행후반환코드를반환한다. 반환코드는 SQLRETURN 타입이며미리정해진값중의하나이다. tbcli 는다음표와같이반환되는반환코드에따라 tbcli 프로그램의상태를확인할수있다. 반환코드 SQL_SUCCESS SQL_SUCCESS_WITH_INFO SQL_NO_DATA 가성공적으로완료된상태가성공적으로완료되었으나, 경고메시지가있는상태가성공적으로완료되었으나, 관련된데이터를찾을수없는상태 ( 예 : 주어진 SQL 문장에의해갱신된로우가없는경우 ) SQL_INVALID_HANDLE SQL_NEED_DATA 입력파라미터에주어진핸들이유효하지않은상태 SQL 문장을실행하기위해데이터가더필요한상태 ( 예 : 파라미터 ) SQL_STILL_EXECUTING SQL_ERROR 이전에실행한 SQL 문장이완료되지않은상태 치명적인에러가발생한상태 이러한반환코드는추가적으로 정보가존재할수있다. 참고 에대한내용은관련 API 나 4.2. 을참고한다 본절에서는 정보를코드순으로나열하고이를한다. 추가로해당 코드를 반환할수있는도포함하여기술한다. 제 4 장 tbcli 에러메시지 115
134 ~ 일반적인경고를뜻하는에러이다. 다음의를제외한모든 SQLError, SQLGetDiagField, SQLGetDiagRec 커서연산이충돌했을때발생하는에러이다. SQLExecDirec, SQLExecute, SQLParamDat, SQLSetPos 데이터베이스연결을해제하는중에발생하는에러이다. SQLError, SQLGetDiagField, SQLGetDiagRec 설정된에서 NULL 값을제거한경우에발생하는에러이다. SQLExecDirect, SQLExecute, SQLParamData 문자열데이터가오른쪽에서잘릴때발생하는에러이다. SQLBrowseConnect, SQLBulkOperations, SQLColAttribute, SQLDataSources, SQLDescribeCol, SQLDriverConnect, SQLDrivers, SQLExecDirect, SQLExecute, SQLExtendedFetch, SQLFetch, SQLFetchScroll, SQLGetConnectAttr, SQLGetCursorName, SQLGetData, SQLGetDescField, SQLGetDescRec, SQLGetEnvAttr, SQLGetInfo, SQLGetStmtAttr, SQLNativeSql, SQLParamData, SQLPutData, SQLSetCursorName 취소되지않은특권일때발생하는에러이다. SQLExecDirec, SQLExecute, SQLParamData 116 Tibero tbcli 안내서
135 01007 부여되지않은특권일때발생하는에러이다. SQLExecDirect, SQLExecute, SQLParamData S00 ~ 01S09 01S00 유효하지않은연결문자열의속성일때발생하는에러이다. SQLBrowseConnect, SQLDriverConnect 01S01 로우에에러가있는경우발생한다. SQLBulkOperations, SQLExtendedFetch, SQLSetPos 01S02 옵션값이변경되었을때발생하는에러이다. 다음의를제외한모든 SQLBrowseConnect, SQLConnect, SQLDriverConnect, SQLExecDirect, SQLExecute, SQLParamData, SQLPrepare, SQLSetConnectAttr, SQLSetDescField, SQLSetEnvAttr, SQLSetStmtAttr 01S06 결과집합의첫번째로우가반환되기전에페치를시도한경우발생하는에러이다. SQLExtendedFetch, SQLFetchScroll 01S07 숫자타입이나날짜타입의일부정보가잘릴때발생하는에러이다. SQLBulkOperations, SQLExecDirect, SQLExecute, SQLExtendedFetch, SQLFetch, SQLFetchScroll, SQLGetData, SQLParamData, SQLSetPos 제 4 장 tbcli 에러메시지 117
136 01S08 DSN 파일 (.dsn) 을저장하지못할때발생하는에러이다. SQLDriverConnect 01S09 잘못된예약어일때발생하는에러이다. SQLDriverConnect ~ 파라미터의숫자가잘못되었을때발생하는에러이다. SQLExecDirect, SQLExecute COUNT 필드에오류가있는경우에발생하는에러이다. SQLExecDirect, SQLExecute, SQLParamData 커서의범위가아닌준비된문장인경우에발생하는에러이다. SQLColAttribute, SQLDescribeCol 제한된데이터타입의속성에위배될때발생하는에러이다. SQLBindCol, SQLBindParameter, SQLBulkOperations, SQLExecDirect, SQLExecute, SQLExtendedFetch, SQLFetch, SQLFetchScroll, SQLGetData, SQLParamData, SQLPutData, SQLSetPos 잘못된서술자인덱스일때발생하는에러이다. 118 Tibero tbcli 안내서
137 SQLBindCol, SQLBindParameter, SQLBulkOperations, SQLColAttribute, SQLDescribeCol, SQLDescribeParam, SQLFetch, SQLFetchScroll, SQLGetData, SQLGetDescField, SQLGetDescRec, SQLParamData, SQLSetDescField, SQLSetDescRec, SQLSetPos S01 07S01 디폴트파라미터를잘못사용한경우발생하는에러이다. SQLExecDirect, SQLExecute, SQLParamData, SQLPutData ~ 클라이언트가데이터소스에연결할수없을때발생하는에러이다. SQLBrowseConnect, SQLConnect, SQLDriverConnect 이미사용중인데이터베이스연결명일때발생하는에러이다. SQLBrowseConnect, SQLConnect, SQLDriverConnect, SQLSetConnectAttr 연결이존재하지않을때발생하는에러이다. SQLAllocHandle, SQLDisconnect, SQLEndTran, SQLGetConnectAttr, SQLGetInfo, SQLNativeSql, SQLSetConnectAttr 서버가연결을거부할때발생하는에러이다. SQLBrowseConnect, SQLConnect, SQLDriverConnect 제 4 장 tbcli 에러메시지 119
138 08007 트랜잭션을수행하는중에연결이실패한경우발생하는에러이다. SQLEndTran S01 08S01 통신연결이실패한경우발생하는에러이다. SQLBrowseConnect, SQLColumnPrivileges, SQLColumns, SQLConnect, SQLCopyDesc, SQLDescribeCol, SQLDescribeParam, SQLDriverConnect, SQLExecDirect, SQLExecute, SQLExtendedFetch, SQLFetch, SQLFetchScroll, SQLForeignKeys, SQLGetConnectAttr, SQLGetData, SQLGetDescField, SQLGetDescRec, SQLGetFunctions, SQLGetInfo, SQLGetTypeInfo, SQLMoreResults, SQLNativeSql, SQLNumParams, SQLNumResultCols, SQLParamData, SQLPrepare, SQLPrimaryKeys, SQLProcedureColumns, SQLProcedures, SQLPutData, SQLSetConnectAttr, SQLSetDescField, SQLSetDescRec, SQLSetEnvAttr, SQLSetStmtAttr, SQLSpecialColumns, SQLStatistics, SQLTablePrivileges, SQLTables S01 ~ 21S02 21S01 삽입될값의리스트가컬럼과일치하지않을때발생하는에러이다. SQLExecDirect, SQLPrepare 21S02 파생된테이블의 degree 가컬럼과일치하지않을때발생하는에러이다. SQLBulkOperations, SQLExecDirect, SQLExecute, SQLParamData, SQLPrepare, SQLSetPos 120 Tibero tbcli 안내서
139 ~ 문자열데이터가오른쪽에서잘릴때발생하는에러이다. SQLBulkOperations, SQLExecDirect, SQLExecute, SQLFetch, SQLFetchScroll, SQLParamData, SQLPutData, SQLSetDescField, SQLSetPos 지시자변수가요구되었으나, 제공되지않았을때발생하는에러이다. SQLExecDirect, SQLExecute, SQLExtendedFetch, SQLFetch, SQLFetchScroll, SQLGetData, SQLParamData 한정된범위를초과한숫자값일때발생하는에러이다. SQLBulkOperations, SQLExecDirect, SQLExecute, SQLExtendedFetch, SQLFetch, SQLFetchScroll, SQLGetData, SQLGetInfo, SQLParamData, SQLPutData, SQLSetPos 유효하지않은날짜형 (DATETIME) 형식일때발생하는에러이다. SQLBulkOperations, SQLExecDirect, SQLExecute, SQLExtendedFetch, SQLFetch, SQLFetchScroll, SQLGetData, SQLParamData, SQLPutData, SQLSetPos 날짜형필드에오버플로우가발생했을때나타나는에러이다. SQLBulkOperations, SQLExecDirect, SQLExecute, SQLParamData, SQLPutData 제 4 장 tbcli 에러메시지 121
140 으로나누었을때발생하는에러이다. SQLExecDirect, SQLExecute, SQLExtendedFetch, SQLFetch, SQLFetchScroll, SQLGetData, SQLParamData, SQLPutData INTERVAL 필드에오버플로우가발생했을때나타나는에러이다. SQLBulkOperations, SQLExecDirect, SQLExecute, SQLExtendedFetch, SQLFetch, SQLFetchScroll, SQLGetData, SQLParamData, SQLPutData, SQLSetPos 캐스트설정을위한문자값이잘못된경우에발생하는에러이다. SQLBulkOperations, SQLExecDirect, SQLExecute, SQLExtendedFetch, SQLFetch, SQLFetchScroll, SQLGetData, SQLParamData, SQLPutData, SQLSetPos 잘못된이스케이프문자일때발생하는에러이다. SQLExecDirect, SQLExecute, SQLPrepare 잘못된이스케이프시퀀스일때발생하는에러이다. SQLExecDirect, SQLExecute, SQLPrepare 잘못된길이를가진문자열데이터일때발생하는에러이다. SQLParamData 122 Tibero tbcli 안내서
141 , 24000, 무결성제약조건에위배될때발생하는에러이다. SQLBulkOperations, SQLExecDirect, SQLExecute, SQLParamData, SQLSetPos 잘못된커서상태일때발생하는에러이다. SQLBulkOperations, SQLCloseCursor, SQLColumnPrivileges, SQLColumns, SQLExecDirect, SQLExecute, SQLExtendedFetch, SQLFetch, SQLFetchScroll, SQLForeignKeys, SQLGetData, SQLGetStmtAttr, SQLGetTypeInfo, SQLNativeSql, SQLPrepare, SQLPrimaryKeys, SQLProcedureColumns, SQLProcedures, SQLSetConnectAttr, SQLSetCursorName, SQLSetPos, SQLSetStmtAttr, SQLSpecialColumns, SQLStatistics, SQLTablePrivileges, SQLTables 잘못된트랜잭션상태일때발생하는에러이다. SQLDisconnect S01 ~ 25S03 25S01 트랜잭션상태일때발생하는에러이다. SQLEndTran 25S02 트랜잭션이아직활성화중일때발생하는에러이다. 제 4 장 tbcli 에러메시지 123
142 SQLEndTran 25S03 트랜잭션이롤백되었을때발생하는에러이다. SQLEndTran , 잘못된권한을설정했을때발생하는에러이다. SQLBrowseConnect, SQLConnect, SQLDriverConnect 잘못된커서이름일때발생하는에러이다. SQLExecDirect, SQLPrepare, SQLSetCursorName C000 ~ 3F000 3C000 중복된커서이름일때발생하는에러이다. SQLSetCursorName 3D000 잘못된카탈로그이름일때발생하는에러이다. SQLExecDirect, SQLPrepare, SQLSetConnectAttr 3F000 잘못된스키마이름일때발생하는에러이다. SQLExecDirect, SQLPrepare 124 Tibero tbcli 안내서
143 ~ 40003, 직렬화에실패했을때발생하는에러이다. SQLBulkOperations, SQLColumnPrivileges, SQLColumns, SQLEndTran, SQLExecDirect, SQLExecute, SQLFetch, SQLFetchScroll, SQLForeignKeys, SQLGetTypeInfo, SQLMoreResults, SQLParamData, SQLPrimaryKeys, SQLProcedureColumns, SQLProcedures, SQLSetPos, SQLSpecialColumns, SQLStatistics, SQLTablePrivileges, SQLTables 무결성제약조건에위배될때발생하는에러이다. SQLEndTran 실행이완료되지않았고, 트랜잭션의상태를알수없을때발생하는에러이다. SQLBulkOperations, SQLColumnPrivileges, SQLColumns, SQLExecDirect, SQLExecute, SQLFetch, SQLFetchScroll, SQLForeignKeys, SQLGetTypeInfo, SQLMoreResults, SQLPrimaryKeys, SQLProcedureColumns, SQLProcedures, SQLParamData, SQLSetPos, SQLSpecialColumns, SQLStatistics, SQLTablePrivileges, SQLTables 문법에러또는접근위배가발생한경우나타나는에러이다. SQLBulkOperations, SQLExecDirect, SQLExecute, SQLParamData, SQLPrepare, SQLSetPos 제 4 장 tbcli 에러메시지 125
144 S01 ~ 42S22, S01 기반테이블또는뷰가이미존재할때발생하는에러이다. SQLExecDirect, SQLPrepare 42S02 기반테이블또는뷰를찾을수없을때발생하는에러이다. SQLExecDirect, SQLPrepare 42S11 인덱스가이미존재할때발생하는에러이다. SQLExecDirect, SQLPrepare 42S12 인덱스를찾을수없을때발생하는에러이다. SQLExecDirect, SQLPrepare 42S21 컬럼이이미존재할때발생하는에러이다. SQLExecDirect, SQLPrepare 42S22 컬럼을찾을수없을때발생하는에러이다. SQLExecDirect, SQLPrepare WITH CHECK OPTION 에위배될때발생하는에러이다. SQLBulkOperations, SQLExecDirect, SQLExecute, SQLParamData, SQLSetPos 126 Tibero tbcli 안내서
145 HY000 ~ HY024 HY000 일반적인에러를뜻하는에러이다. All ODBC functions except:, SQLError, SQLGetDiagField, SQLGetDiagRec HY001 메모리할당에실패했을때발생하는에러이다. All ODBC functions except:, SQLError, SQLGetDiagField, SQLGetDiagRec HY003 잘못된애플리케이션의버퍼타입일때발생하는에러이다. SQLBindCol, SQLBindParameter, SQLGetData HY004 잘못된 SQL 의데이터타입일때발생하는에러이다. SQLBindParameter, SQLGetTypeInfo HY007 해당문장이준비되지않았을때발생하는에러이다. SQLCopyDesc, SQLGetDescField, SQLGetDescRec HY008 연산이취소되었을때발생하는에러이다. SQLBulkOperations, SQLColAttribute, SQLColumnPrivileges, SQLColumns, SQLDescribeCol, SQLDescribeParam, SQLExecDirect, SQLExecute, SQLExtendedFetch, SQLFetch, SQLFetchScroll, SQLForeignKeys, SQLGetData, SQLGetTypeInfo, SQLMoreResults, SQLNumParams, 제 4 장 tbcli 에러메시지 127
146 SQLNumResultCols, SQLParamData, SQLPrepare, SQLPrimaryKeys, SQLProcedureColumns, SQLProcedures, SQLPutData, SQLSetPos, SQLSpecialColumns, SQLStatistics, SQLTablePrivileges, SQLTables HY009 NULL 포인터를잘못사용했을때발생하는에러이다. SQLAllocHandle, SQLBindParameter, SQLBulkOperations, SQLColumnPrivileges, SQLColumns, SQLExecDirect, SQLForeignKeys, SQLGetCursorName, SQLGetData, SQLGetFunctions, SQLNativeSql, SQLPrepare, SQLPrimaryKeys, SQLProcedureColumns, SQLProcedures, SQLPutData, SQLSetConnectAttr, SQLSetCursorName, SQLSetEnvAttr, SQLSetStmtAttr, SQLSpecialColumns, SQLStatistics, SQLTablePrivileges, SQLTables HY010 시퀀스에문제가있는경우발생하는에러이다. SQLAllocHandle, SQLBindCol, SQLBindParameter, SQLBulkOperations, SQLCloseCursor, SQLColAttribute, SQLColumnPrivileges, SQLColumns, SQLCopyDesc, SQLDescribeCol, SQLDescribeParam, SQLDisconnect, SQLEndTran, SQLExecDirect, SQLExecute, SQLExtendedFetch, SQLFetch, SQLFetchScroll, SQLForeignKeys, SQLFreeHandle, SQLFreeStmt, SQLGetConnectAttr, SQLGetCursorName, SQLGetData, SQLGetDescField, SQLGetDescRec, SQLGetFunctions, SQLGetStmtAttr, SQLGetTypeInfo, SQLMoreResults, SQLNumParams, SQLNumResultCols, SQLParamData, SQLPrepare, 128 Tibero tbcli 안내서
147 SQLPrimaryKeys, SQLProcedureColumns, SQLProcedures, SQLPutData, SQLRowCount, SQLSetConnectAttr, SQLSetCursorName, SQLSetDescField, SQLSetEnvAttr, SQLSetDescRec, SQLSetPos, SQLSetStmtAttr, SQLSpecialColumns, SQLStatistics, SQLTablePrivileges, SQLTables HY011 현재설정될수없는속성일때발생하는에러이다. SQLBulkOperations, SQLParamData, SQLSetConnectAttr, SQLSetPos, SQLSetStmtAttr HY012 잘못된트랜잭션의연산코드일때발생하는에러이다. SQLEndTran HY013 메모리관리에에러가발생한경우나타나는에러이다. All ODBC functions except:, SQLGetDiagField, SQLGetDiagRec HY014 한정된핸들개수를초과했을때발생하는에러이다. SQLAllocHandle HY015 사용할수있는커서이름이없을때발생하는에러이다. SQLGetCursorName HY016 구현로우서술자를수정할수없을때발생하는에러이다. 제 4 장 tbcli 에러메시지 129
148 SQLCopyDesc, SQLSetDescField, SQLSetDescRec HY017 자동으로할당된서술자핸들을잘못사용했을때발생하는에러이다. SQLFreeHandle, SQLSetStmtAttr HY018 서버가취소요구를거부했을때발생하는에러이다. SQLCancel HY019 비문자열 (Non-character) 과비이진데이터 (Non-binary data) 를여러조각으로나누어보냈 을때발생하는에러이다. SQLPutData HY020 NULL 값을접합하려고시도했을때발생하는에러이다. SQLPutData HY021 모순이있는서술자정보일때발생하는에러이다. SQLBindParameter, SQLCopyDesc, SQLGetDescField, SQLSetDescField, SQLSetDescRec HY024 잘못된속성값일때발생하는에러이다. SQLSetConnectAttr, SQLSetEnvAttr, SQLSetStmtAttr 130 Tibero tbcli 안내서
149 HY090 ~ HY111 HY090 잘못된문자열또는버퍼길이일때발생하는에러이다. SQLBindCol, SQLBindParameter, SQLBrowseConnect, SQLBulkOperations, SQLColAttribute, SQLColumnPrivileges, SQLColumns, SQLConnect, SQLDataSources, SQLDescribeCol, SQLDriverConnect, SQLDrivers, SQLExecDirect, SQLExecute, SQLFetch, SQLFetchScroll, SQLForeignKeys, SQLGetConnectAttr, SQLGetCursorName, SQLGetData, SQLGetDescField, SQLGetInfo, SQLGetStmtAttr, SQLNativeSql, SQLParamData, SQLPrepare, SQLPrimaryKeys, SQLProcedureColumns, SQLProcedures, SQLPutData, SQLSetConnectAttr, SQLSetCursorName, SQLSetDescField, SQLSetDescRec, SQLSetEnvAttr, SQLSetStmtAttr, SQLSetPos, SQLSpecialColumns, SQLStatistics, SQLTablePrivileges, SQLTables HY091 잘못된서술자의필드식별자일때발생하는에러이다. SQLColAttribute, SQLGetDescField, SQLSetDescField HY092 잘못된속성및옵션식별자일때발생하는에러이다. SQLAllocHandle, SQLBulkOperations, SQLCopyDesc, SQLDriverConnect, SQLEndTran, SQLFreeStmt, SQLGetConnectAttr, SQLGetEnvAttr, SQLGetStmtAttr, SQLParamData, SQLSetConnectAttr, SQLSetDescField, SQLSetEnvAttr, SQLSetPos, SQLSetStmtAttr 제 4 장 tbcli 에러메시지 131
150 HY095 영역밖의타입인경우발생하는에러이다. SQLGetFunctions HY096 잘못된정보타입인경우발생하는에러이다. SQLGetInfo HY097 영역밖의컬럼인경우발생하는에러이다. SQLSpecialColumns HY098 영역밖의범위타입인경우발생하는에러이다. SQLSpecialColumns HY099 영역밖의 Nullable 타입인경우발생하는에러이다. SQLSpecialColumns HY100 영역밖의고유옵션타입인경우발생하는에러이다. SQLStatistics HY101 영역밖의정확도옵션타입인경우발생하는에러이다. SQLStatistics HY103 잘못된검색 (retrieval) 코드인경우발생하는에러이다. SQLDataSources, SQLDrivers 132 Tibero tbcli 안내서
151 HY104 잘못된정밀도또는스케일값인경우발생하는에러이다. SQLBindParameter HY105 잘못된파라미터타입인경우발생하는에러이다. SQLBindParameter, SQLExecDirect, SQLExecute, SQLParamData, SQLSetDescField HY106 영역밖의페치타입인경우발생하는에러이다. SQLExtendedFetch, SQLFetchScroll HY107 영역밖의로우값인경우발생하는에러이다. SQLExtendedFetch, SQLFetch, SQLFetchScroll, SQLSetPos HY109 잘못된커서위치일때발생하는에러이다. SQLExecDirect, SQLExecute, SQLGetData, SQLGetStmtAttr, SQLNativeSql, SQLParamData, SQLSetPos HY110 잘못된드라이버완성 (driver completion) 일때발생하는에러이다. SQLDriverConnect HY111 잘못된북마크값인경우발생하는에러이다. SQLExtendedFetch, SQLFetchScroll 제 4 장 tbcli 에러메시지 133
152 HYC00 HYC00 구현되지않은선택적인기능 (Optional feature) 을사용하려할때발생하는에러이다. SQLBindCol, SQLBindParameter, SQLBulkOperations, SQLColAttribute, SQLColumnPrivileges, SQLColumns, SQLDriverConnect, SQLEndTran, SQLExecDirect, SQLExecute, SQLExtendedFetch, SQLFetch, SQLFetchScroll, SQLForeignKeys, SQLGetConnectAttr, SQLGetData, SQLGetEnvAttr, SQLGetInfo, SQLGetStmtAttr, SQLGetTypeInfo, SQLParamData, SQLPrepare, SQLPrimaryKeys, SQLProcedureColumns, SQLProcedures, SQLSetConnectAttr, SQLSetEnvAttr, SQLSetPos, SQLSetStmtAttr, SQLSpecialColumns, SQLStatistics, SQLTablePrivileges, SQLTables HYT00 ~ HYT01 HYT00 제한시간을초과했을때발생하는에러이다. SQLBrowseConnect, SQLBulkOperations, SQLColumnPrivileges, SQLColumns, SQLConnect, SQLDriverConnect, SQLExecDirect, SQLExecute, SQLExtendedFetch, SQLForeignKeys, SQLGetTypeInfo, SQLParamData, SQLPrepare, SQLPrimaryKeys, SQLProcedureColumns, SQLProcedures, SQLSetPos, SQLSpecialColumns, SQLStatistics, SQLTablePrivileges, SQLTables 134 Tibero tbcli 안내서
153 HYT01 데이터베이스연결제한시간을초과했을때발생하는에러이다. All ODBC functions except:, SQLDrivers, SQLDataSources, SQLGetEnvAttr, SQLSetEnvAttr IM001 ~ IM015 IM001 드라이버가해당를제공하지않을때발생하는에러이다. All ODBC functions except:, SQLAllocHandle, SQLDataSources, SQLDrivers, SQLFreeHandle, SQLGetFunctions IM002 데이터소스의이름을찾을수없거나, 디폴트드라이버가존재하지않을때발생하는에러 이다. SQLBrowseConnect, SQLConnect, SQLDriverConnect IM003 지정한드라이버를로드할수없을때발생하는에러이다. SQLBrowseConnect, SQLConnect, SQLDriverConnect IM004 해당드라이버에 SQLAllocHandle 를이용한환경핸들할당에실패했을때발생하는 에러이다. SQLBrowseConnect, SQLConnect, SQLDriverConnect IM005 해당드라이버에 SQLAllocHandle 를이용한연결핸들할당에실패했을때발생하는 에러이다. SQLBrowseConnect, SQLConnect, SQLDriverConnect 제 4 장 tbcli 에러메시지 135
154 IM006 해당드라이버에 SQLSetConnectAttr 를이용한데이터베이스연결속성설정에실패 했을때발생하는에러이다. SQLBrowseConnect, SQLConnect, SQLDriverConnect IM007 데이터소스또는드라이버가지정되지않았을때발생하는에러이다. SQLDriverConnect IM009 Translation DLL 를로드하는것이불가능할때발생하는에러이다. SQLBrowseConnect, SQLConnect, SQLDriverConnect, SQLSetConnectAttr IM010 데이터소스의이름이 SQL_MAX_DSN_LENGTH 파라미터에설정된값보다길때발생 하는에러이다. SQLBrowseConnect, SQLConnect, SQLDriverConnect IM011 드라이버이름이길때발생하는에러이다. SQLBrowseConnect, SQLDriverConnect IM012 드라이버예약어에문법에러가발생했을때나타나는에러이다. SQLBrowseConnect, SQLDriverConnect IM013 트레이스파일에문제가발생한경우나타나는에러이다. All ODBC functions 136 Tibero tbcli 안내서
155 IM014 잘못된파일 DSN 의이름일때발생하는에러이다. SQLDriverConnect IM015 손상된파일의데이터소스일때발생하는에러이다. SQLDriverConnect , 가성공적으로완료된상태 모든 가성공적으로완료되었으나, 관련된데이터를찾을수없는상태 제 4 장 tbcli 에러메시지 137
156
157 제 5 장 tbcli 와 ODBC 본장에서는 tbcli 와 ODBC 를연동하는방법을한다 ODBC ODBC 는아래와같은 Call-Level Interface (CLI) 명세와표준을따르는데이터베이스의 API 이다. The Open Group CAE Specification "Data Management: SQL Call-Level Interface (CLI)" ISO/IEC :1995 (E) Call-Level Interface (SQL/CLI) ODBC 를사용하게되면, 동일한애플리케이션프로그램으로다양한벤더의 DBMS 에접근할수있다. 이 를위해서는 ODBC 소프트웨어외에, 액세스할데이터베이스마다별도의모듈이나드라이버가필요하다 tbcli 와 ODBC 의연동 tbcli는 Call-Level Interface (CLI) 명세와표준을따르므로, ODBC와연동할수있다. tbcli는 ODBC 3.51 표준에맞게구현되어있어데이터베이스추적로그등 ODBC가가진기능을사용할수있다. Tibero에서는 ODBC와의연동을위해운영체제별로 ODBC 드라이버를제공한다 Windows 계열에서의설치 Windows 계열에서 TiberoODBC 5 Driver를설치할때사용자의편의를위해 Tibero에서는 WIN32용 ODBC 드라이버설치실행파일 (odbc_driver_install.exe) 과 WIN32용 ODBC 클라이언트라이브러리파일 (libtbcli.dll) 을제공하고있다. 이두파일은다음과같은디렉터리에존재한다. Win32용배포판의경우 %TB_HOME%\bin\odbc_driver_install.exe %TB_HOME%\bin\libtbcli.dll UNIX 용배포판의경우 $TB_HOME/client/win32/bin/odbc_driver_install.exe $TB_HOME/client/win32/lib/libtbcli.dll 제 5 장 tbcli 와 ODBC 139
158 설치 설치순서는다음과같다. 1. libtbcli.dll 파일을설치할폴더에복사한다. ODBC 데이터원본관리자에서 libtbcli.dll 파일을동적으로링크하여사용한다. 2. 명령프롬프트 (cmd.exe) 창을실행한후, 다음과같은명령을실행한다. %TB_HOME%\bin\odbc_driver_install.exe -i [ 설치경로 ] 설치경로는복사한 libtbcli.dll 파일이있는디렉터리까지의절대경로를입력한다. 이때설치경로를입 력하지않으면디폴트로설정된 %TB_HOME%\bin 폴더에설치된다. 설치확인 설치후확인하는순서는다음과같다. 1. ODBC 데이터원본관리자를실행한다. 실행하는방법은 [ 제어판 ] > [ 관리도구 ] > [ 데이터원본 (ODBC)] 메뉴를선택하거나또는 %System Root%\system32 폴더에서 odbcad32.exe 파일을실행하면된다. 2. 드라이버탭으로이동한후, Tibero5 ODBC Driver 가있는지확인한다. [ 그림 5.1] Tibero5 ODBC Driver 설치확인 140 Tibero tbcli 안내서
159 DSN 등록 Tibero5 ODBC Driver를정상적으로설치했으면, 이드라이버를통해 DSN(Data Source Name) 를등록하여데이터베이스접속정보를저장한다. DSN를등록하는방법은다음과같이두가지가있다. 사용자 DSN 현재로그인을한윈도우계정에서만사용할수있는 DSN이다. 시스템 DSN 어떠한윈도우계정으로도사용할수있는 DSN 이다. 등록순서는다음과같다. 본안내서에서는사용자 DSN 이라는방법을통해 DSN 을등록한다. 1. ODBC 데이터원본관리자를실행한다. 2. 사용자 DSN 탭으로이동한후 [ 추가 ] 버튼을클릭한다. [ 그림 5.2] 사용자 DSN - 추가 제 5 장 tbcli 와 ODBC 141
160 3. 설치된 Tibero5 ODBC Driver 를선택한후, [ 마침 ] 버튼을클릭한다. [ 그림 5.3] 사용자 DSN - Tibero5 ODBC Driver 선택 4. TIBERO5 ODBC CONFIGURATION 대화상자가나타난다. 이대화상자에데이터베이스접속정보를입력한다. TIBERO5 ODBC Driver에서는 IP와 PORT로접속하는방식과 tbdsn.tbr 파일에설정된 SID로접속하는방식두가지를제공한다. (IP/PORT 방식으로접속하면 TB_HOME 환경을구축하지않고도간편하게드라이버를사용할수있지만 tbdsn.tbr 파일에 TB_NLS_LANG 설정값을넣는등의기능을사용할수없다는단점이있다 ) [ 그림 5.4] 사용자 DSN - 데이터베이스접속정보입력 (IP, PORT 방식 ) 142 Tibero tbcli 안내서
161 [ 그림 5.5] 사용자 DSN - 데이터베이스접속정보입력 (SID 방식 ) 5. 데이터베이스접속정보가모두입력되면 [OK] 버튼을클릭한다. 등록이완료되면다음그림과같이새 로등록된 DSN 이표시된다. [ 그림 5.6] 사용자 DSN - 등록완료 DSN 등록이완료되면 tibero5 를 SQLConnect 또는 SQLDriverConnect 에사용할수있으며, 이를통해데이터베이스에접속할수있다. 제 5 장 tbcli 와 ODBC 143
Tibero RDBMS
Tibero RDBMS tbcli 안내서 Tibero RDBMS 4 SP1 Copyright 2013 TIBERO Co., Ltd. All Rights Reserved. Copyright Notice Copyright 2013 TIBERO Co., Ltd. All Rights Reserved. 대한민국경기도성남시분당구서현동 272-6 우 ) 463-824 Restricted
More informationMicrosoft Word - ODBC
ALTIBASE Application Development ODBC User s Manual Release 5.3.3 ----------------------------------------------------------- ALTIBASE Application Development ODBC User s Manual Release 5.3.3 Copyright
More informationAltibase Installation Manual
ALTIBASE HDB Application Development ODBC User's Manual Release 6.3.1 (April 17, 2015) ----------------------------------------------------------- ALTIBASE Application Development ODBC User's Manual Release
More informationTmax
Tmax JTmaxServer User Guide Tmax v5.0 SP1 Copyright 2009 TmaxSoft Co., Ltd. All Rights Reserved. Copyright Notice Copyright 2009 TmaxSoft Co., Ltd. All Rights Reserved. 대한민국경기도성남시분당구서현동 263 분당스퀘어 (AK 프라자
More informationDBMS & SQL Server Installation Database Laboratory
DBMS & 조교 _ 최윤영 } 데이터베이스연구실 (1314 호 ) } 문의사항은 cyy@hallym.ac.kr } 과제제출은 dbcyy1@gmail.com } 수업공지사항및자료는모두홈페이지에서확인 } dblab.hallym.ac.kr } 홈페이지 ID: 학번 } 홈페이지 PW:s123 2 차례 } } 설치전점검사항 } 설치단계별설명 3 Hallym Univ.
More informationTibero
Tibero 클라이언트설치가이드 Copyright 2013 TmaxData Co., Ltd. All Rights Reserved. Copyright Notice Copyright 2013 TmaxData Co., Ltd. All Rights Reserved. 대한민국경기도성남시분당구황새울로 329 번길 5 티맥스빌딩우 ) 463-824 Restricted Rights
More informationTibero
릴리즈노트 5 Copyright 2013 TIBERO Co., Ltd. All Rights Reserved. Copyright Notice Copyright 2013 TIBERO Co., Ltd. All Rights Reserved. 대한민국경기도성남시분당구서현동 272-6 우 ) 463-824 Restricted Rights Legend All TIBERO
More informationMicrosoft Word - ntasFrameBuilderInstallGuide2.5.doc
NTAS and FRAME BUILDER Install Guide NTAS and FRAME BUILDER Version 2.5 Copyright 2003 Ari System, Inc. All Rights reserved. NTAS and FRAME BUILDER are trademarks or registered trademarks of Ari System,
More informationMicrosoft PowerPoint - chap02-C프로그램시작하기.pptx
#include int main(void) { int num; printf( Please enter an integer "); scanf("%d", &num); if ( num < 0 ) printf("is negative.\n"); printf("num = %d\n", num); return 0; } 1 학습목표 을 작성하면서 C 프로그램의
More informationAPI 매뉴얼
PCI-DIO12 API Programming (Rev 1.0) Windows, Windows2000, Windows NT and Windows XP are trademarks of Microsoft. We acknowledge that the trademarks or service names of all other organizations mentioned
More informationWindows 8에서 BioStar 1 설치하기
/ 콘텐츠 테이블... PC에 BioStar 1 설치 방법... Microsoft SQL Server 2012 Express 설치하기... Running SQL 2012 Express Studio... DBSetup.exe 설정하기... BioStar 서버와 클라이언트 시작하기... 1 1 2 2 6 7 1/11 BioStar 1, Windows 8 BioStar
More informationFileMaker 15 ODBC 및 JDBC 설명서
FileMaker 15 ODBC JDBC 2004-2016 FileMaker, Inc.. FileMaker, Inc. 5201 Patrick Henry Drive Santa Clara, California 95054 FileMaker FileMaker Go FileMaker, Inc.. FileMaker WebDirect FileMaker, Inc... FileMaker.
More information개발및운영 Tibero DB Link (Tibero To Oracle) - Local 방식
Tibero DB Link (Tibero To Oracle) - Local 방식 2014. 04. 16. 목차 1. 구성환경... 3 2. 환경설정... 3 2.1. Tibero 서버 (AIX) 에 Oracle instance Client 파일을업로드... 3 2.2. Oracle Instance Client에대한환경설정등록 (.profile)... 4 2.3.
More information강의 개요
DDL TABLE 을만들자 웹데이터베이스 TABLE 자료가저장되는공간 문자자료의경우 DB 생성시지정한 Character Set 대로저장 Table 생성시 Table 의구조를결정짓는열속성지정 열 (Clumn, Attribute) 은이름과자료형을갖는다. 자료형 : http://dev.mysql.cm/dc/refman/5.1/en/data-types.html TABLE
More information<322EBCF8C8AF28BFACBDC0B9AEC1A6292E687770>
연습문제해답 5 4 3 2 1 0 함수의반환값 =15 5 4 3 2 1 0 함수의반환값 =95 10 7 4 1-2 함수의반환값 =3 1 2 3 4 5 연습문제해답 1. C 언어에서의배열에대하여다음중맞는것은? (1) 3차원이상의배열은불가능하다. (2) 배열의이름은포인터와같은역할을한다. (3) 배열의인덱스는 1에서부터시작한다. (4) 선언한다음, 실행도중에배열의크기를변경하는것이가능하다.
More information쉽게 풀어쓴 C 프로그래밊
Power Java 제 27 장데이터베이스 프로그래밍 이번장에서학습할내용 자바와데이터베이스 데이터베이스의기초 SQL JDBC 를이용한프로그래밍 변경가능한결과집합 자바를통하여데이터베이스를사용하는방법을학습합니다. 자바와데이터베이스 JDBC(Java Database Connectivity) 는자바 API 의하나로서데이터베이스에연결하여서데이터베이스안의데이터에대하여검색하고데이터를변경할수있게한다.
More information개발및운영 Tibero Perl 연동
Tibero Perl 연동 2014. 05. 27. 목차 1. Windows에서의홖경구성... 3 1.1 Tibero ODBC Driver 설치... 3 1.2. Tool 설치... 5 2. Unix에서의홖경구성... 6 2.1 iodbc 설치... 7 2.2 Tibero 설치... 7 2.3 Iodbc drvier manager 등록... 7 3. Tibero
More informationMicrosoft Word - AnyLink Introduction v3.2.3.doc
Copyright 2007 Tmax Soft Co., Ltd. All Rights Reserved. AnyLInk Copyright Notice Copyright 2007 Tmax Soft Co., Ltd. All Rights Reserved. Tmax Soft Co., Ltd. 대한민국서울시강남구대치동 946-1 글라스타워 18 층우 )135-708 Restricted
More information문서 템플릿
HDSI 툴분석 [sql injection 기술명세서 ] Sql injection 기술명세서 Ver. 0.01 이문서는 sql injection 기술명세가범위입니다. Copyrights Copyright 2009 by CanvasTeam@SpeeDroot( 장경칩 ) All Rights Reserved. 장경칩의사전승인없이본내용의전부또는일부에대한복사, 전재,
More informationALTIBASE 사용자가이드 Templete
Real Alternative DBMS ALTIBASE, Since 1999 ALTIBASE & Visual C++ 2010 Professional Edition 개발가이드 2014. 04 Copyright c 2000~2013 ALTBASE Corporation. All Rights Reserved. Document Control Change Record
More informationFileMaker ODBC 및 JDBC 가이드
FileMaker ODBC JDBC 2004-2019 FileMaker, Inc.. FileMaker, Inc. 5201 Patrick Henry Drive Santa Clara, California 95054 FileMaker, FileMaker Cloud, FileMaker Go FileMaker, Inc.. FileMaker WebDirect FileMaker,
More information개요오라클과티베로에서 JDBC 를통해접속한세션을구분할수있도록 JDBC 접속시 ConnectionProperties 를통해구분자를넣어줄수있다. 하나의 Node 에다수의 WAS 가있을경우 DB 에서 Session Kill 등의동작수행시원하는 Session 을선택할수있다.
설치및환경설정 JDBC 접속세션구분 / 확인 2013. 11. 01 개요오라클과티베로에서 JDBC 를통해접속한세션을구분할수있도록 JDBC 접속시 ConnectionProperties 를통해구분자를넣어줄수있다. 하나의 Node 에다수의 WAS 가있을경우 DB 에서 Session Kill 등의동작수행시원하는 Session 을선택할수있다. 사용하기 JEUS 에서설정방법
More information다른 JSP 페이지호출 forward() 메서드 - 하나의 JSP 페이지실행이끝나고다른 JSP 페이지를호출할때사용한다. 예 ) <% RequestDispatcher dispatcher = request.getrequestdispatcher(" 실행할페이지.jsp");
다른 JSP 페이지호출 forward() 메서드 - 하나의 JSP 페이지실행이끝나고다른 JSP 페이지를호출할때사용한다. 예 ) RequestDispatcher dispatcher = request.getrequestdispatcher(" 실행할페이지.jsp"); dispatcher.forward(request, response); - 위의예에서와같이 RequestDispatcher
More informationPowerPoint 프레젠테이션
System Software Experiment 1 Lecture 5 - Array Spring 2019 Hwansoo Han (hhan@skku.edu) Advanced Research on Compilers and Systems, ARCS LAB Sungkyunkwan University http://arcs.skku.edu/ 1 배열 (Array) 동일한타입의데이터가여러개저장되어있는저장장소
More information학습목차 2.1 다차원배열이란 차원배열의주소와값의참조
- Part2- 제 2 장다차원배열이란무엇인가 학습목차 2.1 다차원배열이란 2. 2 2 차원배열의주소와값의참조 2.1 다차원배열이란 2.1 다차원배열이란 (1/14) 다차원배열 : 2 차원이상의배열을의미 1 차원배열과다차원배열의비교 1 차원배열 int array [12] 행 2 차원배열 int array [4][3] 행 열 3 차원배열 int array [2][2][3]
More information1217 WebTrafMon II
(1/28) (2/28) (10 Mbps ) Video, Audio. (3/28) 10 ~ 15 ( : telnet, ftp ),, (4/28) UDP/TCP (5/28) centralized environment packet header information analysis network traffic data, capture presentation network
More informationTibero
Tibero tbesql/cobol 안내서 Tibero 5 Copyright 2013 TIBERO Co., Ltd. All Rights Reserved. Copyright Notice Copyright 2013 TIBERO Co., Ltd. All Rights Reserved. 대한민국경기도성남시분당구서현동 272-6 우 ) 463-824 Restricted
More informationMicrosoft PowerPoint - chap06-2pointer.ppt
2010-1 학기프로그래밍입문 (1) chapter 06-2 참고자료 포인터 박종혁 Tel: 970-6702 Email: jhpark1@snut.ac.kr 한빛미디어 출처 : 뇌를자극하는 C프로그래밍, 한빛미디어 -1- 포인터의정의와사용 변수를선언하는것은메모리에기억공간을할당하는것이며할당된이후에는변수명으로그기억공간을사용한다. 할당된기억공간을사용하는방법에는변수명외에메모리의실제주소값을사용하는것이다.
More informationMicrosoft PowerPoint - 3ÀÏ°_º¯¼ö¿Í »ó¼ö.ppt
변수와상수 1 변수란무엇인가? 변수 : 정보 (data) 를저장하는컴퓨터내의특정위치 ( 임시저장공간 ) 메모리, register 메모리주소 101 번지 102 번지 변수의크기에따라 주로 byte 단위 메모리 2 기본적인변수형및변수의크기 변수의크기 해당컴퓨터에서는항상일정 컴퓨터마다다를수있음 short
More informationMicrosoft PowerPoint - 10Àå.ppt
10 장. DB 서버구축및운영 DBMS 의개념과용어를익힌다. 간단한 SQL 문법을학습한다. MySQL 서버를설치 / 운영한다. 관련용어 데이터 : 자료 테이블 : 데이터를표형식으로표현 레코드 : 테이블의행 필드또는컬럼 : 테이블의열 필드명 : 각필드의이름 데이터타입 : 각필드에입력할값의형식 학번이름주소연락처 관련용어 DB : 테이블의집합 DBMS : DB 들을관리하는소프트웨어
More informationMicrosoft PowerPoint - chap03-변수와데이터형.pptx
#include int main(void) { int num; printf( Please enter an integer: "); scanf("%d", &num); if ( num < 0 ) printf("is negative.\n"); printf("num %d\n", num); return 0; } 1 학습목표 의 개념에 대해 알아본다.
More informationC# Programming Guide - Types
C# Programming Guide - Types 최도경 lifeisforu@wemade.com 이문서는 MSDN 의 Types 를요약하고보충한것입니다. http://msdn.microsoft.com/enus/library/ms173104(v=vs.100).aspx Types, Variables, and Values C# 은 type 에민감한언어이다. 모든
More informationInsertColumnNonNullableError(#colName) 에해당하는메시지출력 존재하지않는컬럼에값을삽입하려고할경우, InsertColumnExistenceError(#colName) 에해당하는메시지출력 실행결과가 primary key 제약에위배된다면, Ins
Project 1-3: Implementing DML Due: 2015/11/11 (Wed), 11:59 PM 이번프로젝트의목표는프로젝트 1-1 및프로젝트 1-2에서구현한프로그램에기능을추가하여간단한 DML을처리할수있도록하는것이다. 구현한프로그램은 3개의 DML 구문 (insert, delete, select) 을처리할수있어야한다. 테이블데이터는파일에저장되어프로그램이종료되어도사라지지않아야한다.
More information[Brochure] KOR_TunA
LG CNS LG CNS APM (TunA) LG CNS APM (TunA) 어플리케이션의 성능 개선을 위한 직관적이고 심플한 APM 솔루션 APM 이란? Application Performance Management 란? 사용자 관점 그리고 비즈니스 관점에서 실제 서비스되고 있는 어플리케이션의 성능 관리 체계입니다. 이를 위해서는 신속한 장애 지점 파악 /
More informationAPI STORE 키발급및 API 사용가이드 Document Information 문서명 : API STORE 언어별 Client 사용가이드작성자 : 작성일 : 업무영역 : 버전 : 1 st Draft. 서브시스템 : 문서번호 : 단계 : Docum
API STORE 키발급및 API 사용가이드 Document Information 문서명 : API STORE 언어별 Client 사용가이드작성자 : 작성일 : 2012.11.23 업무영역 : 버전 : 1 st Draft. 서브시스템 : 문서번호 : 단계 : Document Distribution Copy Number Name(Role, Title) Date
More information°æÁ¦Àü¸Á-µ¼º¸.PDF
www.keri.org i ii iii iv v vi vii viii ix x xi xii xiii xiv xv 3 4 5 6 7 8 9 10 11 12 13 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 47 48 49 50 51 52 53
More information<BFDCB1B9C0CE20C5F5C0DAB1E2BEF7C0C720B3EBBBE7B0FCB0E82E687770>
외국인 투자기업의 노사관계 요 약 i ii 외국인 투자기업의 노사관계 요 약 iii iv 외국인 투자기업의 노사관계 요 약 v vi 외국인 투자기업의 노사관계 요 약 vii viii 외국인 투자기업의 노사관계 요 약 ix x 외국인 투자기업의 노사관계 요 약 xi xii 외국인 투자기업의 노사관계 요 약 xiii xiv 외국인 투자기업의 노사관계
More information인디쓔피-IOM핸돜벁닄큐1014pdf, page 59 @ Preflight ( IOM핸돜벁닄큐__1014 )
Publisher: International Organization for Migration 17, route des Morillons 1211 Geneva 19 Switzerland Tel: +41.22.717 91 11 Fax: +41.22.798 61 50 E-mail: hq@iom.int Internet: http://www.iom.int ISBN 978
More informationMicrosoft PowerPoint - ch07 - 포인터 pm0415
2015-1 프로그래밍언어 7. 포인터 (Pointer), 동적메모리할당 2015 년 4 월 4 일 교수김영탁 영남대학교공과대학정보통신공학과 (Tel : +82-53-810-2497; Fax : +82-53-810-4742 http://antl.yu.ac.kr/; E-mail : ytkim@yu.ac.kr) Outline 포인터 (pointer) 란? 간접참조연산자
More informationMicrosoft PowerPoint - C프로그래밍-chap03.ppt [호환 모드]
Chapter 03 변수와자료형 2009 한국항공대학교항공우주기계공학부 (http://mercury.kau.ac.kr/sjkwon) 1 변수와자료유형 변수 프로그램에서자료값을임시로기억할수있는저장공간을변수 (variables) 변수 (Variables) 는컴퓨터의메모리인 RAM(Random Access Memory) 에저장 물건을담는박스라고생각한다면박스의크기에따라담을물건이제한됨
More information금오공대 컴퓨터공학전공 강의자료
C 프로그래밍프로젝트 Chap 14. 포인터와함수에대한이해 2013.10.09. 오병우 컴퓨터공학과 14-1 함수의인자로배열전달 기본적인인자의전달방식 값의복사에의한전달 val 10 a 10 11 Department of Computer Engineering 2 14-1 함수의인자로배열전달 배열의함수인자전달방식 배열이름 ( 배열주소, 포인터 ) 에의한전달 #include
More informationJDBC 소개및설치 Database Laboratory
JDBC 소개및설치 JDBC } What is the JDBC? } JAVA Database Connectivity 의약어 } 자바프로그램안에서 SQL 을실행하기위해데이터베이스를연결해주는응용프로그램인터페이스 } 연결된데이터베이스의종류와상관없이동일한방법으로자바가데이터베이스내에서발생하는트랜잭션을제어할수있도록하는환경을제공 2 JDBC Driver Manager }
More informationTablespace On-Offline 테이블스페이스 온라인/오프라인
2018/11/10 12:06 1/2 Tablespace On-Offline 테이블스페이스온라인 / 오프라인 목차 Tablespace On-Offline 테이블스페이스온라인 / 오프라인... 1 일반테이블스페이스 (TABLESPACE)... 1 일반테이블스페이스생성하기... 1 테이블스페이스조회하기... 1 테이블스페이스에데이터파일 (DATA FILE) 추가
More information목차 BUG DEQUEUE 의 WAIT TIME 이 1 초미만인경우, 설정한시간만큼대기하지않는문제가있습니다... 3 BUG [qp-select-pvo] group by 표현식에있는컬럼을참조하는집합연산이존재하지않으면결괏값오류가발생할수있습니다... 4
ALTIBASE HDB 6.5.1.5.10 Patch Notes 목차 BUG-46183 DEQUEUE 의 WAIT TIME 이 1 초미만인경우, 설정한시간만큼대기하지않는문제가있습니다... 3 BUG-46249 [qp-select-pvo] group by 표현식에있는컬럼을참조하는집합연산이존재하지않으면결괏값오류가발생할수있습니다... 4 BUG-46266 [sm]
More information13주-14주proc.PDF
12 : Pro*C/C++ 1 2 Embeded SQL 3 PRO *C 31 C/C++ PRO *C NOT! NOT AND && AND OR OR EQUAL == = SQL,,, Embeded SQL SQL 32 Pro*C C SQL Pro*C C, C Pro*C, C C 321, C char : char[n] : n int, short, long : float
More informationJVM 메모리구조
조명이정도면괜찮조! 주제 JVM 메모리구조 설미라자료조사, 자료작성, PPT 작성, 보고서작성. 발표. 조장. 최지성자료조사, 자료작성, PPT 작성, 보고서작성. 발표. 조원 이용열자료조사, 자료작성, PPT 작성, 보고서작성. 이윤경 자료조사, 자료작성, PPT작성, 보고서작성. 이수은 자료조사, 자료작성, PPT작성, 보고서작성. 발표일 2013. 05.
More informationPostgreSQL 2 Uniersity of California at Berkeley ( ) 에서개발된관계형데이터베이스서버인 Ingres 가시초 ( 후에 Computer Associates 에인수됨 ) 1
ERwin 과 PostgreSQL 연동하기 인하대학교지리정보공학과데이터베이스실습 PostgreSQL 2 http://www.postgresql.org/ Uniersity of California at Berkeley (1977-1985) 에서개발된관계형데이터베이스서버인 Ingres 가시초 ( 후에 Computer Associates 에인수됨 ) 1996 년부터
More information목차 BUG offline replicator 에서유효하지않은로그를읽을경우비정상종료할수있다... 3 BUG 각 partition 이서로다른 tablespace 를가지고, column type 이 CLOB 이며, 해당 table 을 truncate
ALTIBASE HDB 6.1.1.5.6 Patch Notes 목차 BUG-39240 offline replicator 에서유효하지않은로그를읽을경우비정상종료할수있다... 3 BUG-41443 각 partition 이서로다른 tablespace 를가지고, column type 이 CLOB 이며, 해당 table 을 truncate 한뒤, hash partition
More informationSpotlight on Oracle V10.x 트라이얼프로그램설치가이드 DELL SOFTWARE KOREA
Spotlight on Oracle V10.x DELL SOFTWARE KOREA 2016-11-15 Spotlight on Oracle 목차 1. 시스템요구사항... 2 1.1 지원하는데이터베이스...2 1.2 사용자설치홖경...2 2. 프로그램설치... 3 2.1 설치프로그램실행...3 2.2 라이선스사용관련내용확인및사용동의...3 2.3 프로그램설치경로지정...4
More informationHLS(HTTP Live Streaming) 이용가이드 1. HLS 소개 Apple iphone, ipad, ipod의운영체제인 ios에서사용하는표준 HTTP 기반스트리밍프로토콜입니다. 2. HLS 지원대상 - 디바이스 : iphone/ipad/ipod - 운영체제 :
HLS(HTTP Live Streaming) 이용가이드 1. HLS 소개 Apple iphone, ipad, ipod의운영체제인 ios에서사용하는표준 HTTP 기반스트리밍프로토콜입니다. 2. HLS 지원대상 - 디바이스 : iphone/ipad/ipod - 운영체제 : ios 3.0 이상 - 콘텐츠형식 : MP4 (H264,AAC ), MP3 * 디바이스별해상도,
More information2014 학년도종합설계 1 차중간보고서 ( 스마트폰기반의나만의검색엔진 ) 성명학번 연락처 하희진 김태훈
2014 학년도종합설계 1 차중간보고서 ( 스마트폰기반의나만의검색엔진 ) 성명학번 e-mail 연락처 하희진 200412361 wheejinv@naver.com 010-2009-9073 김태훈 200811424 eamay00@gmail.com 010-9032-5537 담당교수 : 유준범교수님 ( 인 ) - 1 - 목 차 1. 프로젝트개요 2. 개발동기 3.
More informationC++ Programming
C++ Programming 예외처리 Seo, Doo-okok clickseo@gmail.com http://www.clickseo.com 목 차 예외처리 2 예외처리 예외처리 C++ 의예외처리 예외클래스와객체 3 예외처리 예외를처리하지않는프로그램 int main() int a, b; cout > a >> b; cout
More informationThe Pocket Guide to TCP/IP Sockets: C Version
인터넷프로토콜 5 장 데이터송수신 (3) 1 파일전송메시지구성예제 ( 고정크기메시지 ) 전송방식 : 고정크기 ( 바이너리전송 ) 필요한전송정보 파일이름 ( 최대 255 자 => 255byte 의메모리공간필요 ) 파일크기 (4byte 의경우최대 4GB 크기의파일처리가능 ) 파일내용 ( 가변길이, 0~4GB 크기 ) 메시지구성 FileName (255bytes)
More information목차 BUG 문법에맞지않는질의문수행시, 에러메시지에질의문의일부만보여주는문제를수정합니다... 3 BUG ROUND, TRUNC 함수에서 DATE 포맷 IW 를추가지원합니다... 5 BUG ROLLUP/CUBE 절을포함하는질의는 SUBQUE
ALTIBASE HDB 6.3.1.10.1 Patch Notes 목차 BUG-45710 문법에맞지않는질의문수행시, 에러메시지에질의문의일부만보여주는문제를수정합니다... 3 BUG-45730 ROUND, TRUNC 함수에서 DATE 포맷 IW 를추가지원합니다... 5 BUG-45760 ROLLUP/CUBE 절을포함하는질의는 SUBQUERY REMOVAL 변환을수행하지않도록수정합니다....
More informationMicrosoft PowerPoint - chap01-C언어개요.pptx
#include int main(void) { int num; printf( Please enter an integer: "); scanf("%d", &num); if ( num < 0 ) printf("is negative.\n"); printf("num = %d\n", num); return 0; } 1 학습목표 프로그래밍의 기본 개념을
More informationMySQL-.. 1
MySQL- 기초 1 Jinseog Kim Dongguk University jinseog.kim@gmail.com 2017-08-25 Jinseog Kim Dongguk University jinseog.kim@gmail.com MySQL-기초 1 2017-08-25 1 / 18 SQL의 기초 SQL은 아래의 용도로 구성됨 데이터정의 언어(Data definition
More information사물인터넷비즈니스빅뱅_내지_11차_160421.indd
사물인터넷 빅뱅 2016. 연대성 All Rights Reserved. 초판 1쇄 발행 2016년 4월 29일 지은이 연대성 펴낸이 장성두 펴낸곳 제이펍 출판신고 2009년 11월 10일 제406 2009 000087호 주소 경기도 파주시 문발로 141 뮤즈빌딩 403호 전화 070 8201 9010 / 팩스 02 6280 0405 홈페이지 www.jpub.kr
More informationPowerPoint Presentation
Package Class 3 Heeseung Jo 목차 section 1 패키지개요와패키지의사용 section 2 java.lang 패키지의개요 section 3 Object 클래스 section 4 포장 (Wrapper) 클래스 section 5 문자열의개요 section 6 String 클래스 section 7 StringBuffer 클래스 section
More informationALTIBASE HDB Patch Notes
ALTIBASE HDB 6.5.1.5.6 Patch Notes 목차 BUG-45643 암호화컬럼의경우, 이중화환경에서 DDL 수행시 Replication HandShake 가실패하는문제가있어수정하였습니다... 4 BUG-45652 이중화에서 Active Server 와 Standby Server 의 List Partition 테이블의범위조건이다른경우에 Handshake
More informationMicrosoft PowerPoint - e pptx
Import/Export Data Using VBA Objectives Referencing Excel Cells in VBA Importing Data from Excel to VBA Using VBA to Modify Contents of Cells 새서브프로시저작성하기 프로시저실행하고결과확인하기 VBA 코드이해하기 Referencing Excel Cells
More informationMicrosoft Word - PLC제어응용-2차시.doc
과정명 PLC 제어응용차시명 2 차시. 접점명령 학습목표 1. 연산개시명령 (LOAD, LOAD NOT) 에대하여설명할수있다. 2. 직렬접속명령 (AND, AND NOT) 에대하여설명할수있다. 3. 병렬접속명령 (OR, OR NOT) 에대하여설명할수있다. 4.PLC의접점명령을가지고간단한프로그램을작성할수있다. 학습내용 1. 연산개시명령 1) 연산개시명령 (LOAD,
More informationTibero
Tibero 전환유틸리티가이드 Copyright 2013 TmaxData Co., Ltd. All Rights Reserved. Copyright Notice Copyright 2013 TmaxData Co., Ltd. All Rights Reserved. 대한민국경기도성남시분당구황새울로 329 번길 5 티맥스빌딩우 ) 463-824 Restricted Rights
More information10.ppt
: SQL. SQL Plus. JDBC. SQL >> SQL create table : CREATE TABLE ( ( ), ( ),.. ) SQL >> SQL create table : id username dept birth email id username dept birth email CREATE TABLE member ( id NUMBER NOT NULL
More informationPowerPoint Presentation
FORENSICINSIGHT SEMINAR SQLite Recovery zurum herosdfrc@google.co.kr Contents 1. SQLite! 2. SQLite 구조 3. 레코드의삭제 4. 삭제된영역추적 5. 레코드복원기법 forensicinsight.org Page 2 / 22 SQLite! - What is.. - and why? forensicinsight.org
More informationTTA Journal No.157_서체변경.indd
표준 시험인증 기술 동향 FIDO(Fast IDentity Online) 생체 인증 기술 표준화 동향 이동기 TTA 모바일응용서비스 프로젝트그룹(PG910) 의장 SK텔레콤 NIC 담당 매니저 76 l 2015 01/02 PASSWORDLESS EXPERIENCE (UAF standards) ONLINE AUTH REQUEST LOCAL DEVICE AUTH
More informationMicrosoft PowerPoint - ch09 - 연결형리스트, Stack, Queue와 응용 pm0100
2015-1 프로그래밍언어 9. 연결형리스트, Stack, Queue 2015 년 5 월 4 일 교수김영탁 영남대학교공과대학정보통신공학과 (Tel : +82-53-810-2497; Fax : +82-53-810-4742 http://antl.yu.ac.kr/; E-mail : ytkim@yu.ac.kr) 연결리스트 (Linked List) 연결리스트연산 Stack
More informationvRealize Automation용 VMware Remote Console - VMware
vrealize Automation 용 VMware Remote Console VMware Remote Console 9.0 이문서는새버전으로교체되기전까지나열된각제품버전및모든이후버전을지원합니다. 이문서에대한최신버전을확인하려면 http://www.vmware.com/kr/support/pubs 를참조하십시오. KO-002230-00 vrealize Automation
More information1. Windows 설치 (Client 설치 ) 원하는위치에다운받은발송클라이언트압축파일을해제합니다. Step 2. /conf/config.xml 파일수정 conf 폴더에서 config.xml 파일을텍스트에디터를이용하여 Open 합니다. config.xml 파일에서, 아
LG U+ SMS/MMS 통합클라이언트 LG U+ SMS/MMS Client Simple Install Manual LG U+ SMS/MMS 통합클라이언트 - 1 - 간단설치매뉴얼 1. Windows 설치 (Client 설치 ) 원하는위치에다운받은발송클라이언트압축파일을해제합니다. Step 2. /conf/config.xml 파일수정 conf 폴더에서 config.xml
More information09 강제근로의 금지 폭행의 금지 공민권 행사의 보장 38 10 중간착취의 금지 41 - 대판 2008.9.25, 2006도7660 [근로기준법위반] (쌍용자동차 취업알선 사례) 11 균등대우의 원칙 43 - 대판 2003.3.14, 2002도3883 [남녀고용평등법위
01 노동법 법원으로서의 노동관행 15 - 대판 2002.4.23, 2000다50701 [퇴직금] (한국전력공사 사례) 02 노동법과 신의성실의 원칙 17 - 대판 1994.9.30, 94다9092 [고용관계존재확인등] (대한조선공사 사례) 03 퇴직금 청구권 사전 포기 약정의 효력 19 - 대판 1998.3.27, 97다49732 [퇴직금] (아시아나 항공
More information슬라이드 제목 없음
5.2 ER 모델 ( 계속 ) 관계와관계타입 관계는엔티티들사이에존재하는연관이나연결로서두개이상의엔티티타입들사이의사상으로생각할수있음 관계집합은동질의관계들의집합 관계타입은동질의관계들의틀 관계집합과관계타입을엄격하게구분할필요는없음 요구사항명세에서흔히동사는 ER 다이어그램에서관계로표현됨 ER 다이어그램에서다이어몬드로표기 관계타입이서로연관시키는엔티티타입들을관계타입에실선으로연결함
More information<C1A62038B0AD20B0ADC0C7B3EBC6AE2E687770>
제 8강 SQL: 관계데이터베이스언어 강의목표 관계데이타베이스언어로서상용 DBMS에서가장널리사용되는 SQL의동작원리에관하여학습하고, 이를이용하여다양한질의문을작성하는방법을습득한다 기대효과 SQL의데이터정의기능을이해한다 SQL의데이터조작기능중질의기능을이해한다 SQL의데이터조작기능중데이터갱신기능을이해한다 SQL의데이터조작기능중뷰및인덱스관련기능을이해한다 SQL 의개요
More informationuntitled
시스템소프트웨어 : 운영체제, 컴파일러, 어셈블러, 링커, 로더, 프로그래밍도구등 소프트웨어 응용소프트웨어 : 워드프로세서, 스프레드쉬트, 그래픽프로그램, 미디어재생기등 1 n ( x + x +... + ) 1 2 x n 00001111 10111111 01000101 11111000 00001111 10111111 01001101 11111000
More information5장. JSP와 Servlet 프로그래밍을 위한 기본 문법(완성-0421).hwp
1 0 1.7 6 5 'A ' '/ u 4 4 2 2 ' " JS P 프로그래밍 " A ', 'b ', ' 한 ', 9, \ u d 6 5 4 ' c h a r a = 'A '; 0 1 0 2 0 3 0 4 0 5 0 6 0 7 0 8 0 9 1 0 1 1 1 2 1 3 1 4 1 5 1 6 1 7 1 8 1 9 < % @ p a g e c o n te n
More informationuntitled
Content Ⅰ. 기본방향 1. 목 적 3 2. 적용범위 3 Ⅱ. 사회복지관 운영 1. 사회복지관의 정의 7 2. 사회복지관의 목표 7 3. 사회복지관의 연혁 7 4. 사회복지관 운영의 기본원칙 8 Ⅲ. 사회복지관 사업 1. 가족복지사업 15 2. 지역사회보호사업 16 3. 지역사회조직사업 18 4. 교육 문화사업 19 5. 자활사업 20 6. 재가복지봉사서비스
More information6장. SQL
학습목표 SQL이 무엇인지 개념을 설명 테이블을 생성, 변경, 제거할 할 수 있다. 수 있다. 데이터를 검색, 갱신, 삽입, 삭 제할 수 있다. 뷰, 시스템 카탈로그, 저장 프 로시저, 트리거에 대한 개념 을 설명할 수 있다. 2 목차 SECTION 01 SQL의 개요 11 SQL의 역사 12 SQL의 유형별 종류 SECTION 0 21 스키마 22 테이블
More information윈도우시스템프로그래밍
데이터베이스및설계 MySQL 을위한 MFC 를사용한 ODBC 프로그래밍 2012.05.10. 오병우 컴퓨터공학과금오공과대학교 http://www.apmsetup.com 또는 http://www.mysql.com APM Setup 설치발표자료참조 Department of Computer Engineering 2 DB 에속한테이블보기 show tables; 에러발생
More informationMicrosoft PowerPoint - chap10-함수의활용.pptx
#include int main(void) { int num; printf( Please enter an integer: "); scanf("%d", &num); if ( num < 0 ) printf("is negative.\n"); printf("num = %d\n", num); return 0; } 1 학습목표 중 값에 의한 전달 방법과
More information마리오와 소닉 리우 올림픽™
마리오와 소닉 리우 올림픽 1 사용하기 전에 준비하기 2 유저 콘텐츠에 대하여 3 인터넷으로 이용 가능한 기능 4 보호자 여러분께 5 amiibo란 시작하기 전에 6 게임 소개 7 게임 시작 방법 8 조작 방법 9 데이터 저장과 삭제 통신으로 더욱 즐기기 10 대전 모드 11 포켓 마라톤 12 기록 기타 13 사용 곡명과 작곡자 소개 14 플레이 정보 송신
More information윈백및업그레이드 Tibero Flashback 가이드
Tibero Flashback 가이드 2014. 05. 09. 목차 1. FLASHBACK 소개... 3 1.1. Flashback 개요... 3 1.2. Flashback 기능... 3 2. FLASHBACK 기능... 3 2.1. FLASHBACK QUERY... 3 2.1.1. FLASHBACK QUERY 개요... 3 2.1.2. FLASHBACK QUERY
More informationOCW_C언어 기초
초보프로그래머를위한 C 언어기초 4 장 : 연산자 2012 년 이은주 학습목표 수식의개념과연산자및피연산자에대한학습 C 의알아보기 연산자의우선순위와결합방향에대하여알아보기 2 목차 연산자의기본개념 수식 연산자와피연산자 산술연산자 / 증감연산자 관계연산자 / 논리연산자 비트연산자 / 대입연산자연산자의우선순위와결합방향 조건연산자 / 형변환연산자 연산자의우선순위 연산자의결합방향
More informationSpring Boot/JDBC JdbcTemplate/CRUD 예제
Spring Boot/JDBC JdbcTemplate/CRUD 예제 오라클자바커뮤니티 (ojc.asia, ojcedu.com) Spring Boot, Gradle 과오픈소스인 MariaDB 를이용해서 EMP 테이블을만들고 JdbcTemplate, SimpleJdbcTemplate 을이용하여 CRUD 기능을구현해보자. 마리아 DB 설치는다음 URL 에서확인하자.
More information금오공대 컴퓨터공학전공 강의자료
C 프로그래밍프로젝트 Chap 13. 포인터와배열! 함께이해하기 2013.10.02. 오병우 컴퓨터공학과 13-1 포인터와배열의관계 Programming in C, 정재은저, 사이텍미디어. 9 장참조 ( 교재의 13-1 은읽지말것 ) 배열이름의정체 배열이름은 Compile 시의 Symbol 로서첫번째요소의주소값을나타낸다. Symbol 로서컴파일시에만유효함 실행시에는메모리에잡히지않음
More informationTibero RDBMS
릴리즈노트 4 SP1 Copyright 2013 TIBERO Co., Ltd. All Rights Reserved. Copyright Notice Copyright 2013 TIBERO Co., Ltd. All Rights Reserved. 대한민국경기도성남시분당구서현동 272-6 우 ) 463-824 Restricted Rights Legend All TIBERO
More informationA Dynamic Grid Services Deployment Mechanism for On-Demand Resource Provisioning
C Programming Practice (II) Contents 배열 문자와문자열 구조체 포인터와메모리관리 구조체 2/17 배열 (Array) (1/2) 배열 동일한자료형을가지고있으며같은이름으로참조되는변수들의집합 배열의크기는반드시상수이어야한다. type var_name[size]; 예 ) int myarray[5] 배열의원소는원소의번호를 0 부터시작하는색인을사용
More informationPowerPoint Presentation
객체지향프로그래밍 클래스, 객체, 메소드 ( 실습 ) 손시운 ssw5176@kangwon.ac.kr 예제 1. 필드만있는클래스 텔레비젼 2 예제 1. 필드만있는클래스 3 예제 2. 여러개의객체생성하기 4 5 예제 3. 메소드가추가된클래스 public class Television { int channel; // 채널번호 int volume; // 볼륨 boolean
More information임베디드시스템설계강의자료 6 system call 2/2 (2014 년도 1 학기 ) 김영진 아주대학교전자공학과
임베디드시스템설계강의자료 6 system call 2/2 (2014 년도 1 학기 ) 김영진 아주대학교전자공학과 System call table and linkage v Ref. http://www.ibm.com/developerworks/linux/library/l-system-calls/ - 2 - Young-Jin Kim SYSCALL_DEFINE 함수
More informationadfasdfasfdasfasfadf
C 4.5 Source code Pt.3 ISL / 강한솔 2019-04-10 Index Tree structure Build.h Tree.h St-thresh.h 2 Tree structure *Concpets : Node, Branch, Leaf, Subtree, Attribute, Attribute Value, Class Play, Don't Play.
More informationChap7.PDF
Chapter 7 The SUN Intranet Data Warehouse: Architecture and Tools All rights reserved 1 Intranet Data Warehouse : Distributed Networking Computing Peer-to-peer Peer-to-peer:,. C/S Microsoft ActiveX DCOM(Distributed
More information<4D F736F F F696E74202D20B8AEB4AABDBA20BFC0B7F920C3B3B8AEC7CFB1E22E BC8A3C8AF20B8F0B5E55D>
리눅스 오류처리하기 2007. 11. 28 안효창 라이브러리함수의오류번호얻기 errno 변수기능오류번호를저장한다. 기본형 extern int errno; 헤더파일 라이브러리함수호출에실패했을때함수예 정수값을반환하는함수 -1 반환 open 함수 포인터를반환하는함수 NULL 반환 fopen 함수 2 유닉스 / 리눅스 라이브러리함수의오류번호얻기 19-1
More informationSQL Developer Connect to TimesTen 유니원아이앤씨 DB 기술지원팀 2010 년 07 월 28 일 문서정보 프로젝트명 SQL Developer Connect to TimesTen 서브시스템명 버전 1.0 문서명 작성일 작성자
SQL Developer Connect to TimesTen 유니원아이앤씨 DB 팀 2010 년 07 월 28 일 문서정보 프로젝트명 SQL Developer Connect to TimesTen 서브시스템명 버전 1.0 문서명 작성일 2010-07-28 작성자 김학준 최종수정일 2010-07-28 문서번호 20100728_01_khj 재개정이력 일자내용수정인버전
More informationez-shv manual
ez-shv+ SDI to HDMI Converter with Display and Scaler Operation manual REVISION NUMBER: 1.0.0 DISTRIBUTION DATE: NOVEMBER. 2018 저작권 알림 Copyright 2006~2018 LUMANTEK Co., Ltd. All Rights Reserved 루먼텍 사에서
More information[ 마이크로프로세서 1] 2 주차 3 차시. 포인터와구조체 2 주차 3 차시포인터와구조체 학습목표 1. C 언어에서가장어려운포인터와구조체를설명할수있다. 2. Call By Value 와 Call By Reference 를구분할수있다. 학습내용 1 : 함수 (Functi
2 주차 3 차시포인터와구조체 학습목표 1. C 언어에서가장어려운포인터와구조체를설명할수있다. 2. Call By Value 와 Call By Reference 를구분할수있다. 학습내용 1 : 함수 (Function) 1. 함수의개념 입력에대해적절한출력을발생시켜주는것 내가 ( 프로그래머 ) 작성한명령문을연산, 처리, 실행해주는부분 ( 모듈 ) 자체적으로실행되지않으며,
More informationiii. Design Tab 을 Click 하여 WindowBuilder 가자동으로생성한 GUI 프로그래밍환경을확인한다.
Eclipse 개발환경에서 WindowBuilder 를이용한 Java 프로그램개발 이예는 Java 프로그램의기초를이해하고있는사람을대상으로 Embedded Microcomputer 를이용한제어시스템을 PC 에서 Serial 통신으로제어 (Graphical User Interface (GUI) 환경에서 ) 하는프로그램개발예를설명한다. WindowBuilder:
More informationchap 5: Trees
5. Threaded Binary Tree 기본개념 n 개의노드를갖는이진트리에는 2n 개의링크가존재 2n 개의링크중에 n + 1 개의링크값은 null Null 링크를다른노드에대한포인터로대체 Threads Thread 의이용 ptr left_child = NULL 일경우, ptr left_child 를 ptr 의 inorder predecessor 를가리키도록변경
More informationMicrosoft PowerPoint - chap04-연산자.pptx
int num; printf( Please enter an integer: "); scanf("%d", &num); if ( num < 0 ) printf("is negative.\n"); printf("num = %d\n", num); } 1 학습목표 수식의 개념과 연산자, 피연산자에 대해서 알아본다. C의 를 알아본다. 연산자의 우선 순위와 결합 방향에
More informationPowerPoint Template
16-1. 보조자료템플릿 (Template) 함수템플릿 클래스템플릿 Jong Hyuk Park 함수템플릿 Jong Hyuk Park 함수템플릿소개 함수템플릿 한번의함수정의로서로다른자료형에대해적용하는함수 예 int abs(int n) return n < 0? -n : n; double abs(double n) 함수 return n < 0? -n : n; //
More information<3036C7E2BCF6C3D6C1BEBABB2E687770>
문화향수실태조사 SURVEY REPORT ON CULTURAL ENJOYMENT 2006 문화관광부 한국문화관광정책연구원 Ministry of Culture & Tourism Korea Culture & Tourism Policy Institute 서문 우리나라 국민들이 문화와 예술을 얼마나, 그리고 어떻게 즐기고 있는지를 객관적으 로 파악하기 위하여, 1988년부터
More information- JPA를사용하는경우의스프링설정파일에다음을기술한다. <bean id="entitymanagerfactory" class="org.springframework.orm.jpa.localentitymanagerfactorybean" p:persistenceunitname=
JPA 와 Hibernate - 스프링의 JDBC 대신에 JPA를이용한 DB 데이터검색작업 - JPA(Java Persistence API) 는자바의 O/R 매핑에대한표준지침이며, 이지침에따라설계된소프트웨어를 O/R 매핑프레임워크 라고한다. - O/R 매핑 : 객체지향개념인자바와관계개념인 DB 테이블간에상호대응을시켜준다. 즉, 객체지향언어의인스턴스와관계데이터베이스의레코드를상호대응시킨다.
More informationC++ Programming
C++ Programming 연산자다중정의 Seo, Doo-okok clickseo@gmail.com http://www.clickseo.com 목 차 연산자다중정의 C++ 스타일의문자열 2 연산자다중정의 연산자다중정의 단항연산자다중정의 이항연산자다중정의 cin, cout 그리고 endl C++ 스타일의문자열 3 연산자다중정의 연산자다중정의 (Operator
More informationMicrosoft PowerPoint - QVIZMVUMWURI.pptx
데이타베이스시스템 2011.03 충북대학교경영정보학과조완섭 (wscho@chungbuk.ac.kr) Chap. 4 SQL 질의어 C4 2 목차 - SQL2에서데이터정의, 제약조건및스키마변경 - SQL에서의기본질의 - 더복잡한 SQL 질의들 - SQL에서삽입, 삭제, 갱신구문 - SQL 뷰 - 주장으로추가적인제약조건명시 - SQL의부가적인기능들 Ch4 3 SQL
More information