C語言是一門很受歡迎的編程語言,其與Oracle數據庫的結合運用廣泛。C語言提供了直接訪問系統硬件、編寫操作系統和編寫高效程序等能力,而Oracle是一種強大的對象關系數據庫管理系統,可以存儲數據、管理數據、提供安全性和擴展性等。
在使用C語言寫入Oracle時,我們通常會使用頭文件,如oci.h、oratypes.h等。這些頭文件提供了鏈接Oracle數據庫的函數和數據類型,如連接、查詢、事務等。下面是一段示例代碼:
#include#include #include int main() { OCIEnv *envhp; OCIError *errhp; OCIServer *srvhp; OCISession *usrhp; OCIStmt *stmthp; OCIDefine *defhp; //初始化環境 OCIInitialize(OCI_DEFAULT); OCIEnvInit(&envhp, OCI_DEFAULT, 0, 0); //分配錯誤句柄、服務器句柄和用戶會話句柄 OCIHandleAlloc(envhp, (void **)&errhp, OCI_HTYPE_ERROR, 0, 0); OCIHandleAlloc(envhp, (void **)&srvhp, OCI_HTYPE_SERVER, 0, 0); OCIHandleAlloc(envhp, (void **)&usrhp, OCI_HTYPE_SESSION, 0, 0); //連接到數據庫,輸入用戶名和密碼 OCIServerAttach(srvhp, errhp, (text *)"oracle.example.com:1521/ORCLCDB", strlen("oracle.example.com:1521/ORCLCDB"), OCI_DEFAULT); OCIAttrSet(usrhp, OCI_HTYPE_SESSION, (void *)"username", strlen("username"), OCI_ATTR_USERNAME, errhp); OCIAttrSet(usrhp, OCI_HTYPE_SESSION, (void *)"password", strlen("password"), OCI_ATTR_PASSWORD, errhp); OCISessionBegin(srvhp, errhp, usrhp, OCI_CRED_RDBMS, OCI_DEFAULT); //分配語句句柄 OCIHandleAlloc(envhp, (void **)&stmthp, OCI_HTYPE_STMT, 0, 0); //執行查詢語句 OCIStmtPrepare(stmthp, errhp, (text *)"SELECT * FROM test_table", strlen("SELECT * FROM test_table"), OCI_NTV_SYNTAX, OCI_DEFAULT); OCIStmtExecute(srvhp, stmthp, errhp, 1, 0, 0, 0, OCI_DEFAULT); //定義結果集 OCIHandleAlloc(envhp, (void **)&defhp, OCI_HTYPE_DEFINE, 0, 0); OCIStmtFetch(stmthp, errhp, 1, OCI_FETCH_NEXT, OCI_DEFAULT); //釋放資源 OCIHandleFree(stmthp, OCI_HTYPE_STMT); OCISessionEnd(srvhp, errhp, usrhp, OCI_DEFAULT); OCIHandleFree(usrhp, OCI_HTYPE_SESSION); OCIHandleFree(srvhp, OCI_HTYPE_SERVER); OCIHandleFree(errhp, OCI_HTYPE_ERROR); OCIHandleFree(envhp, OCI_HTYPE_ENV); return 0; }
在此代碼示例中,我們使用OCIServerAttach函數連接到Oracle數據庫,并使用OCISessionBegin函數輸入用戶名和密碼進行會話。然后我們使用OCIStmtPrepare函數預編譯一個查詢語句,并使用OCIStmtExecute函數執行該語句,最后使用OCIStmtFetch函數獲取查詢ResultSet并進行操作。最后,我們使用OCIHandleFree函數釋放所有分配的資源。
除了查詢之外,我們還可以使用C語言向Oracle數據庫中寫入數據。下面是一段使用OCIStmtExecute函數寫入數據的示例代碼:
int main() { OCIEnv *envhp; OCIError *errhp; OCIServer *srvhp; OCISession *usrhp; OCIStmt *stmthp; //初始化環境 OCIInitialize(OCI_DEFAULT); OCIEnvInit(&envhp, OCI_DEFAULT, 0, 0); //分配錯誤句柄、服務器句柄和用戶會話句柄 OCIHandleAlloc(envhp, (void **)&errhp, OCI_HTYPE_ERROR, 0, 0); OCIHandleAlloc(envhp, (void **)&srvhp, OCI_HTYPE_SERVER, 0, 0); OCIHandleAlloc(envhp, (void **)&usrhp, OCI_HTYPE_SESSION, 0, 0); //連接到數據庫,輸入用戶名和密碼 OCIServerAttach(srvhp, errhp, (text *)"oracle.example.com:1521/ORCLCDB", strlen("oracle.example.com:1521/ORCLCDB"), OCI_DEFAULT); OCIAttrSet(usrhp, OCI_HTYPE_SESSION, (void *)"username", strlen("username"), OCI_ATTR_USERNAME, errhp); OCIAttrSet(usrhp, OCI_HTYPE_SESSION, (void *)"password", strlen("password"), OCI_ATTR_PASSWORD, errhp); OCISessionBegin(srvhp, errhp, usrhp, OCI_CRED_RDBMS, OCI_DEFAULT); //分配語句句柄 OCIHandleAlloc(envhp, (void **)&stmthp, OCI_HTYPE_STMT, 0, 0); //執行插入語句 OCIStmtPrepare(stmthp, errhp, (text *)"INSERT INTO test_table(id, name) VALUES (:id, :name)", strlen("INSERT INTO test_table(id, name) VALUES (:id, :name)"), OCI_NTV_SYNTAX, OCI_DEFAULT); //綁定參數 int id = 1; char name[10] = "test"; OCIBind *bndhp; OCIHandleAlloc(envhp, (void **)&bndhp, OCI_HTYPE_BIND, 0, 0); OCIBindByName(stmthp, &bndhp, errhp, (text *)":id", strlen(":id"), &id, sizeof(id), SQLT_INT, 0, 0, 0, 0, OCI_DEFAULT); OCIBindByName(stmthp, &bndhp, errhp, (text *)":name", strlen(":name"), name, sizeof(name), SQLT_STR, 0, 0, 0, 0, OCI_DEFAULT); OCIStmtExecute(srvhp, stmthp, errhp, 1, 0, 0, 0, OCI_DEFAULT); //釋放資源 OCIHandleFree(stmthp, OCI_HTYPE_STMT); OCISessionEnd(srvhp, errhp, usrhp, OCI_DEFAULT); OCIHandleFree(usrhp, OCI_HTYPE_SESSION); OCIHandleFree(srvhp, OCI_HTYPE_SERVER); OCIHandleFree(errhp, OCI_HTYPE_ERROR); OCIHandleFree(envhp, OCI_HTYPE_ENV); return 0; }
在此示例代碼中,我們使用OCIStmtPrepare函數預編譯一個插入語句,并使用OCIBindByName函數綁定參數。然后我們使用OCIStmtExecute函數執行該語句,并使用OCIHandleFree函數釋放所有分配的資源。
總之,C語言結合Oracle數據庫可以實現強大的功能。我們可以利用這種結合來讀取和寫入Oracle數據庫,執行各種查詢和操作,并管理數據庫。
上一篇c 創建oracle 表
下一篇c 使用oracle