oci mysql_Oracle常用的OCI函数
歡迎進入Oracle社區論壇,與200萬技術人員互動交流 >>進入 sword OCIEnvInit ( OCIEnv **envhpp, ub4 mode, size_t xtramemsz, dvoid **usrmempp ); 注: 在8i以后,可用OCIEnvCreate一個函數就可以初始化環境了,相當于OCIInitialize+ OCIEnvInit 2.申請/
歡迎進入Oracle社區論壇,與200萬技術人員互動交流 >>進入
sword OCIEnvInit (
OCIEnv **envhpp,
ub4 mode,
size_t xtramemsz,
dvoid **usrmempp
);
注:
在8i以后,可用OCIEnvCreate一個函數就可以初始化環境了,相當于OCIInitialize+ OCIEnvInit
2.申請/釋放句柄
sword OCIHandleAlloc(
CONST dvoid *parenth, //新申請句柄的父句柄,一般為OCI環境句柄
Dvoid **hndlpp, //申請的新句柄
Ub4 type, type, //句柄類型
Size_t xtramem_sz, //申請的內存數
Dvoid **usrmempp //申請到的內存塊指針
)
注:
一般需要申請的句柄有:
服務器句柄OCIServer, 句柄類型OCI_HTYPE_SERVER
錯誤句柄OCIError,用于捕獲OCI錯誤信息, 句柄類型OCI_HTYPE_ERROR
事務句柄OCISession, 句柄類型OCI_HTYPE_SESSION
上下文句柄OCISvcCtx, 句柄類型OCI_HTYPE_SVCCTX
SQL語句句柄OCIStmt, 句柄類型OCI_HTYPE_STMT
eg: 申請一個錯誤句柄OCIError
swResult = OCIHandleAlloc(envhpp, (dvoid *)& errhp, OCI_HTYPE_ERROR, 0, NULL);
if(swResult != OCI_SUCCESS && swResult != OCI_SUCCESS_WITH_INFO)
{
return FALSE;
}
釋放句柄
sword OCIHandleFree(
dvoid *hndlp, //要釋放的句柄
ub4 type //句柄類型
)
eg:
OCIHandleFree(stmtp, OCI_HTYPE_STMT)
3.讀取/設置句柄屬性
sword OCIAttrSet(
dvoid *trgthndlp, //需設置的句柄名
ub4 trghndltyp, //句柄類型
dvoid *attributep, //設置的屬性名
ub4 size, //屬性值長度
ub4 attrtype, //屬性類型
OCIError *errhp //錯誤句柄
)
注:一般要設置的屬性有:
服務器實例:
句柄類型OCI_HTYPE_SVCCTX,屬性類型OCI_ATTR_SERVER
連接數據的用戶名:
句柄類型OCI_HTYPE_SESSION,屬性類型OCI_ATTR_USERNAME
用戶密碼
句柄類型OCI_HTYPE_SESSION,屬性類型OCI_ATTR_PASSWORD
事務:
句柄類型OCI_HTYPE_SVCCTX,屬性類型OCI_ATTR_SESSION
eg:設置用戶名和密碼
char username[20],passwd[20];
strcpy(username,”tiger”)
strcpy(passwd,”cotton”)
swResult = OCIAttrSet(usrhp, OCI_HTYPE_SESSION, (text*) username, strlen(username),
OCI_ATTR_USERNAME, errhp);
if(swResult != OCI_SUCCESS && swResult != OCI_SUCCESS_WITH_INFO)
return FALSE;
swResult = OCIAttrSet(usrhp, OCI_HTYPE_SESSION, (text*) passwd, strlen(passwd),
OCI_ATTR_PASSWORD, errhp);
if(swResult != OCI_SUCCESS && swResult != OCI_SUCCESS_WITH_INFO)
return FALSE;
sword OCIAttrGet(
dvoid *trgthndlp, //需讀取的句柄名
ub4 trghndltyp, //句柄類型
dvoid *attributep, //讀取的屬性名
ub4 *sizep, //屬性值長度
ub4 attrtype, //屬性類型
OCIError *errhp //錯誤句柄
)
4.連接/斷開服務器
多用戶方式連接:
sword OCIServerAttach(
OCIServer *srvhp,//未初始化的服務器句柄
OCIError *errhp,
CONST text *dblink,//服務器SID
sb4 dblink_len,
ub4 mode //=OCI_DEFAULT,系統環境將設為阻塞方式
);
sword OCIServerDetach (
OCIServer *srvhp,
OCIError *errhp,
ub4 mode //OCI_DEFAULT
);
單用戶方式連接:
sword OCILogon (
OCIEnv *envhp,
OCIError *errhp,
OCISvcCtx **svchp,
CONST text *username,
ub4 uname_len,
CONST text *password,
ub4 passwd_len,
CONST text *dbname,
ub4 dbname_len
);
sword OCILogoff (
OCISvcCtx *svchp
OCIError *errhp
);
5.開始/結束一個會話
先認證用戶再建立一個會話連接
sword OCISessionBegin (
OCISvcCtx *svchp, //服務環境句柄
OCIError *errhp,
OCISession *usrhp, //用戶會話句柄
ub4 credt, //認證類型
ub4 mode //操作模式
);
*認證類型:
OCI_CRED_RDBMS:用數據庫用戶名和密碼進行認證,則先要設置OCI_ATTR_USERNAME和OCI_ATTR_PASSWORD屬性
OCI_CRED_EXT:外部認證,不需要設置用戶和密碼
OCI_DEFAULT:用戶會話環境只能被指定的服務器環境句柄所設置
OCI_SYSDBA:用戶要具有sysdba權限
OCI_SYSOPER:用戶要具有sysoper權限
Eg:
swResult = OCISessionBegin(svchp, errh,usrhp, OCI_CRED_RDBMS, OCI_DEFAULT);
if(swResult != OCI_SUCCESS && swResult != OCI_SUCCESS_WITH_INFO)
return FALSE;
sword OCISessionEnd (
OCISvcCtx *svchp,
OCIError *errhp,
OCISession *usrhp,
ub4 mode );
6.讀取錯誤信息
sword OCIErrorGet (
dvoid *hndlp, //錯誤句柄
ub4 recordno,//從那里讀取錯誤記錄,從1開始
text *sqlstate,//已取消,=NULL
sb4 *errcodep, //錯誤號
text *bufp, //錯誤內容
ub4 bufsiz, //bufp長度
ub4 type //傳遞的錯誤句柄類型
=OCI_HTYPE_ERROR:錯誤句柄
=OCI_HTYPE_ENV:環境句柄
);
eg:
ub4 ub4RecordNo = 1;
OCIError* hError
sb4 sb4ErrorCode;
char sErrorMsg[1024];
if (OCIErrorGet(hError, ub4RecordNo++, NULL, &sb4ErrorCode, (OraText*) sErrorMsg, sizeof(sErrorMsg), OCI_HTYPE_ERROR) == OCI_SUCCESS)
printf(“error msg:%s\n”, sErrorMsg);
[1] [2] [3] [4] [5]
本文原創發布php中文網,轉載請注明出處,感謝您的尊重!
總結
以上是生活随笔為你收集整理的oci mysql_Oracle常用的OCI函数的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 分享NI卸载工具(免费)
- 下一篇: Unity3d Network 局域网多