日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 运维知识 > 数据库 >内容正文

数据库

C语言连接Oracle数据库

發布時間:2023/12/10 数据库 45 豆豆
生活随笔 收集整理的這篇文章主要介紹了 C语言连接Oracle数据库 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

文章目錄

  • 一、源代碼說明
  • 二、概述
  • 三、connection類
  • 四、sqlstatement類
  • 五、程序流程
    • 1、無結果集SQL的程序的流程
    • 2、有結果集SQL的程序的流程
  • 六、示例程序
    • 1、創建超女信息表
    • 2、向超女表中插入5條記錄
    • 3、更新超女表中的記錄
    • 在這里插入圖片描述 4、查詢超女表中的記錄
    • 5、查詢超女表中的記錄數
    • 7、刪除超女表中的記錄
    • 8、執行PL/SQL過程
    • 9、CLOB和BLOB字段的操作
  • 七、應用經驗
  • 八、獲取視頻教程
  • 九、版權聲明

對很多C/C++程序員來說,操作Oracle數據庫是一個技術難點,本文講述采用freecplus開源框架操作Oracle數據庫,freecplus框架是C語言技術網作者二十年的技術積累,功能強大,簡單易用。

一、源代碼說明

freecplus是一個Linux系統下的C/C++開源框架,源代碼請前往C語言技術網(www.freecplus.net)下載。

本文介紹的是freecplus框架中采用connection和sqlstatement類操作Oracle數據庫。

類的聲明文件是freecplus/db/oracle/_ooci.h。

類的定義文件是freecplus/db/oracle/_ooci.cpp。

示例程序位于freecplus/db/oracle目錄中。

編譯規則文件是freecplus/db/oracle/makefile。

二、概述

本文不會介紹Oracle數據庫、SQL語言和C/C++的基礎知識,您應該是一個職業的C/C++程序員,在閱讀本文之前,您已經掌握了Oracle數據庫和SQL語言的基礎知識。

Oracle數據庫功能強大,性能卓越,無與倫比,并提供了數據訪問接口OCI,OCI非常強大,強大到了普通C/C++程序員難以駕馭。

freecplus框架把OCI(Oracle Call Interface)封裝成了connection和sqlstatement類,采用封裝后的類操作Oracle數據庫,代碼簡潔優雅,性能卓越。

接下來我先列出connection和sqlstatement類的聲明,然后通過流程圖和示例程序介紹它位的用法。

三、connection類

Oracle數據庫連接池connection類的聲明(程序員不必關心的私有成員和數據結構未列出):

// Oracle數據庫連接池類。 class connection { public:int m_state; // 與數據庫的連接狀態,0-未連接,1-已連接。CDA_DEF m_cda; // 數據庫操作的結果或最后一次執行SQL語句的結果。char m_sql[10241]; // SQL語句的文本,最長不能超過10240字節。connection(); // 構造函數。~connection(); // 析構函數。// 登錄數據庫。// connstr:數據庫的登錄參數,格式:username/password@tnsname,username-用戶名,password-登錄密// 碼,tnsname-數據庫的服務名,在$ORACLE_HOME/network/admin/tnsnames.ora文件中配置。// charset:數據庫的字符集,必須與數據庫保持一致,否則會出現中文亂碼的情況。// autocommitopt:是否啟用自動提交,0-不啟用,1-啟用,缺省是不啟用。// 返回值:0-成功,其它失敗,失敗的代碼在m_cda.rc中,失敗的描述在m_cda.message中。int connecttodb(char *connstr,char *charset,int autocommitopt=0);// 提交事務。// 返回值:0-成功,其它失敗,程序員一般不必關心返回值。int commit(); // 回滾事務。// 返回值:0-成功,其它失敗,程序員一般不必關心返回值。int rollback();// 斷開與數據庫的連接。// 注意,斷開與數據庫的連接時,全部未提交的事務自動回滾。// 返回值:0-成功,其它失敗,程序員一般不必關心返回值。int disconnect();// 執行SQL語句。// 如果SQL語句不需要綁定輸入和輸出變量(無綁定變量、非查詢語句),可以直接用此方法執行。// 參數說明:這是一個可變參數,用法與printf函數相同。// 返回值:0-成功,其它失敗,失敗的代碼在m_cda.rc中,失敗的描述在m_cda.message中,// 如果成功的執行了非查詢語句,在m_cda.rpc中保存了本次執行SQL影響記錄的行數。// 程序員必須檢查execute方法的返回值。// 在connection類中提供了execute方法,是為了方便程序員,在該方法中,也是用sqlstatement類來完成功能。int execute(const char *fmt,...); };

四、sqlstatement類

Oracle數據庫的SQL語句操作sqlstatement類的聲明(程序員不必關心的私有成員和數據結構未列出,對CLOB和BLOB字段操作的方法也未列出):

// 操作SQL語句類。 class sqlstatement {OCI_HANDLE m_handle; // SQL句柄。connection *m_conn; // 數據庫連接池指針。int m_sqltype; // SQL語句的類型,0-查詢語句;1-非查詢語句。int m_autocommitopt; // 自動提交標志,0-關閉;1-開啟。void err_report(); // 錯誤報告。OCILobLocator *m_lob; // 指向LOB字段的指針。int alloclob(); // 初始化lob指針。int filetolob(FILE *fp); // 把文件的內容導入到clob和blob字段中。int lobtofile(FILE *fp); // 從clob和blob字段中導出內容到文件中。void freelob(); // 釋放lob指針。 public:int m_state; // 與數據庫連接池的綁定狀態,0-未綁定,1-已綁定。char m_sql[10241]; // SQL語句的文本,最長不能超過10240字節。CDA_DEF m_cda; // 執行SQL語句的結果。sqlstatement(); // 構造函數。sqlstatement(connection *conn); // 構造函數,同時綁定數據庫連接池。~sqlstatement();// 綁定數據庫連接池。// conn:數據庫連接池connection對象的地址。// 返回值:0-成功,其它失敗,只要conn參數是有效的,并且數據庫的游標資源足夠,connect方法不會返回失敗。// 程序員一般不必關心connect方法的返回值。// 注意,每個sqlstatement只需要綁定一次,在綁定新的connection前,必須先調用disconnect方法。int connect(connection *conn); // 取消與數據庫連接池的綁定。// 返回值:0-成功,其它失敗,程序員一般不必關心返回值。int disconnect();// 準備SQL語句。// 參數說明:這是一個可變參數,用法與printf函數相同。// 返回值:0-成功,其它失敗,程序員一般不必關心返回值。// 注意:如果SQL語句沒有改變,只需要prepare一次就可以了。int prepare(const char *fmt,...);// 綁定輸入變量的地址。// position:字段的順序,從1開始,必須與prepare方法中的SQL的序號一一對應。// value:輸入變量的地址,如果是字符串,內存大小應該是表對應的字段長度加1。// len:如果輸入變量的數據類型是字符串,用len指定它的最大長度,建議采用表對應的字段長度。// 返回值:0-成功,其它失敗,程序員一般不必關心返回值。// 注意:如果SQL語句沒有改變,只需要bindin一次就可以了。int bindin(unsigned int position,int *value);int bindin(unsigned int position,long *value);int bindin(unsigned int position,unsigned int *value);int bindin(unsigned int position,unsigned long *value);int bindin(unsigned int position,float *value);int bindin(unsigned int position,double *value);int bindin(unsigned int position,char *value,unsigned int len);// 綁定輸出變量的地址。// position:字段的順序,從1開始,與SQL的結果集一一對應。// value:輸出變量的地址,如果是字符串,內存大小應該是表對應的字段長度加1。// len:如果輸出變量的數據類型是字符串,用len指定它的最大長度,建議采用表對應的字段長度。// 返回值:0-成功,其它失敗,程序員一般不必關心返回值。// 注意:如果SQL語句沒有改變,只需要bindout一次就可以了。int bindout(unsigned int position,int *value);int bindout(unsigned int position,long *value);int bindout(unsigned int position,unsigned int *value);int bindout(unsigned int position,unsigned long *value);int bindout(unsigned int position,float *value);int bindout(unsigned int position,double *value);int bindout(unsigned int position,char *value,unsigned int len);// 執行SQL語句。// 返回值:0-成功,其它失敗,失敗的代碼在m_cda.rc中,失敗的描述在m_cda.message中。// 如果成功的執行了非查詢語句,在m_cda.rpc中保存了本次執行SQL影響記錄的行數。// 程序員必須檢查execute方法的返回值。int execute();// 執行SQL語句。// 如果SQL語句不需要綁定輸入和輸出變量(無綁定變量、非查詢語句),可以直接用此方法執行。// 參數說明:這是一個可變參數,用法與printf函數相同。// 返回值:0-成功,其它失敗,失敗的代碼在m_cda.rc中,失敗的描述在m_cda.message中,// 如果成功的執行了非查詢語句,在m_cda.rpc中保存了本次執行SQL影響記錄的行數。// 程序員必須檢查execute方法的返回值。int execute(const char *fmt,...);// 從結果集中獲取一條記錄。// 如果執行的SQL語句是查詢語句,調用execute方法后,會產生一個結果集(存放在數據庫的緩沖區中)。// next方法從結果集中獲取一條記錄,把字段的值放入已綁定的輸出變量中。// 返回值:0-成功,1403-結果集已無記錄,其它-失敗,失敗的代碼在m_cda.rc中,失敗的描述在m_cda.message中。// 返回失敗的原因主要有兩個:1)與數據庫的連接已斷開;2)綁定輸出變量的內存太小。// 每執行一次next方法,m_cda.rpc的值加1。// 程序員必須檢查next方法的返回值。int next(); };

五、程序流程

freecplus框架把對Oracle數據庫操作的SQL語句分為兩種:有結果集的SQL語句和無結果集的SQL語句。

如果SQL語句被執行后,有結果集的產生,稱為有結果集的SQL,即數據查詢語言DQL,以select關鍵字,各種簡單查詢,連接查詢等都屬于DQL。

如果SQL語句被執行后,沒有結果集的產生,稱為無結果集的SQL,包括數據定義語言DDL(主要是create、drop和alter)和數據操縱語言DML(insert、update和insert)。

也可以這么說,查詢的SQL語句會產生結果集,其它的SQL語句不會產生結果集。

1、無結果集SQL的程序的流程

這是一個完程的流程,在實際開發中,如果是執行簡單的SQL語句,第6步和第7步可能不需要,如果SQL語句只執行一次,第7步和第8步之間的循環也不需要。

2、有結果集SQL的程序的流程


這是一個完程的流程,在實際開發中,如果是執行簡單的查詢語句,第6步、第7步和第8步可能不需要,如果結果集中最多只有一條記錄,第10步和第11步之間的循環也不需要。

六、示例程序

1、創建超女信息表

示例(createtable.cpp)

/** 程序名:createtable.cpp,此程序演示freecplus框架操作Oracle數據庫(創建表)。* 作者:C語言技術網(www.freecplus.net) 日期:20190525 */ #include "_ooci.h" // freecplus框架操作Oracle的頭文件。int main(int argc,char *argv[]) {connection conn; // 數據庫連接類// 登錄數據庫,返回值:0-成功,其它-失敗。// 失敗代碼在conn.m_cda.rc中,失敗描述在conn.m_cda.message中。if (conn.connecttodb("scott/tiger@snorcl11g_198","Simplified Chinese_China.ZHS16GBK")!=0){printf("connect database failed.\n%s\n",conn.m_cda.message); return -1;}sqlstatement stmt(&conn); // 操作SQL語句的對象。// 準備創建表的SQL語句。// 超女表girls,超女編號id,超女姓名name,體重weight,報名時間btime,超女說明memo,超女圖片pic。stmt.prepare("\create table girls(id number(10),\name varchar2(30),\weight number(8,2),\btime date,\memo clob,\pic blob,\primary key (id))");// prepare方法不需要判斷返回值。// 執行SQL語句,一定要判斷返回值,0-成功,其它-失敗。// 失敗代碼在stmt.m_cda.rc中,失敗描述在stmt.m_cda.message中。if (stmt.execute() != 0){printf("stmt.execute() failed.\n%s\n%s\n",stmt.m_sql,stmt.m_cda.message); return -1;}printf("create table girls ok.\n"); }

運行效果

2、向超女表中插入5條記錄

示例(inserttable.cpp)

/** 程序名:inserttable.cpp,此程序演示freecplus框架操作Oracle數據庫(向表中插入5條記錄)。* 作者:C語言技術網(www.freecplus.net) 日期:20190525 */ #include "_ooci.h" // freecplus框架操作Oracle的頭文件。// 定義用于超女信息的結構,與表中的字段對應。 struct st_girls {long id; // 超女編號,用long數據類型對應Oracle無小數的number(10)。char name[11]; // 超女姓名,用char[31]對應Oracle的varchar2(30)。double weight; // 超女體重,用double數據類型對應Oracle有小數的number(8,2)。char btime[20]; // 報名時間,用char對應Oracle的date,格式:'yyyy-mm-dd hh24:mi:ssi'。 } stgirls;int main(int argc,char *argv[]) {connection conn; // 數據庫連接類// 登錄數據庫,返回值:0-成功,其它-失敗。// 失敗代碼在conn.m_cda.rc中,失敗描述在conn.m_cda.message中。if (conn.connecttodb("scott/tiger@snorcl11g_198","Simplified Chinese_China.ZHS16GBK")!=0){printf("connect database failed.\n%s\n",conn.m_cda.message); return -1;}sqlstatement stmt(&conn); // 操作SQL語句的對象。// 準備插入表的SQL語句。stmt.prepare("\insert into girls(id,name,weight,btime) \values(:1,:2,:3,to_date(:4,'yyyy-mm-dd hh24:mi:ss'))");// prepare方法不需要判斷返回值。// 為SQL語句綁定輸入變量的地址,bindin方法不需要判斷返回值。stmt.bindin(1,&stgirls.id);stmt.bindin(2, stgirls.name,10);stmt.bindin(3,&stgirls.weight);stmt.bindin(4, stgirls.btime,19);// 模擬超女數據,向表中插入5條測試信息。for (int ii=1;ii<=5;ii++){memset(&stgirls,0,sizeof(stgirls)); // 結構體變量初始化。// 為結構體變量的成員賦值。stgirls.id=ii; // 超女編號。sprintf(stgirls.name,"超女%02d",ii); // 超女姓名。stgirls.weight=ii*2.11; // 超女體重。strcpy(stgirls.btime,"2018-03-01 12:25:31"); // 報名時間。// 執行SQL語句,一定要判斷返回值,0-成功,其它-失敗。// 失敗代碼在stmt.m_cda.rc中,失敗描述在stmt.m_cda.message中。if (stmt.execute() != 0){printf("stmt.execute() failed.\n%s\n%s\n",stmt.m_sql,stmt.m_cda.message); return -1;}printf("成功插入了%ld條記錄。\n",stmt.m_cda.rpc); // stmt.m_cda.rpc是本次執行SQL影響的記錄數。}printf("insert table girls ok.\n");conn.commit(); // 提交數據庫事務。 }

運行效果

3、更新超女表中的記錄

示例(updatetable.cpp)

/** 程序名:updatetable.cpp,此程序演示freecplus框架操作Oracle數據庫(修改表中的記錄)。* 作者:C語言技術網(www.freecplus.net) 日期:20190525 */ #include "_ooci.h" // freecplus框架操作Oracle的頭文件。int main(int argc,char *argv[]) {connection conn; // 數據庫連接類// 登錄數據庫,返回值:0-成功,其它-失敗。// 失敗代碼在conn.m_cda.rc中,失敗描述在conn.m_cda.message中。if (conn.connecttodb("scott/tiger@snorcl11g_198","Simplified Chinese_China.ZHS16GBK")!=0){printf("connect database failed.\n%s\n",conn.m_cda.message); return -1;}sqlstatement stmt(&conn); // 操作SQL語句的對象。char strbtime[20]; // 用于存放超女的報名時間。memset(strbtime,0,sizeof(strbtime));strcpy(strbtime,"2019-12-20 09:45:30");// 準備更新數據的SQL語句,不需要判斷返回值。stmt.prepare("\update girls set btime=to_date(:1,'yyyy-mm-dd hh24:mi:ss') where id>=2 and id<=4");// prepare方法不需要判斷返回值。// 為SQL語句綁定輸入變量的地址,bindin方法不需要判斷返回值。stmt.bindin(1,strbtime,19);// 如果不采用綁定輸入變量的方法,把strbtime的值直接寫在SQL語句中也是可以的,如下:/*stmt.prepare("\update girls set btime=to_date('%s','yyyy-mm-dd hh24:mi:ss') where id>=2 and id<=4",strbtime);*/// 執行SQL語句,一定要判斷返回值,0-成功,其它-失敗。// 失敗代碼在stmt.m_cda.rc中,失敗描述在stmt.m_cda.message中。if (stmt.execute() != 0){printf("stmt.execute() failed.\n%s\n%s\n",stmt.m_sql,stmt.m_cda.message); return -1;}// 請注意,stmt.m_cda.rpc變量非常重要,它保存了SQL被執行后影響的記錄數。printf("本次更新了girls表%ld條記錄。\n",stmt.m_cda.rpc);// 提交事務conn.commit(); }

運行效果


4、查詢超女表中的記錄

示例(selecttable.cpp)

/** 程序名:selecttable.cpp,此程序演示freecplus框架操作Oracle數據庫(查詢表中的記錄)。* 作者:C語言技術網(www.freecplus.net) 日期:20190525 */ #include "_ooci.h" // freecplus框架操作Oracle的頭文件。// 定義用于超女信息的結構,與表中的字段對應。 struct st_girls {long id; // 超女編號,用long數據類型對應Oracle無小數的number(10)。char name[31]; // 超女姓名,用char[31]對應Oracle的varchar2(30)。double weight; // 超女體重,用double數據類型對應Oracle有小數的number(8,2)。char btime[20]; // 報名時間,用char對應Oracle的date,格式:'yyyy-mm-dd hh24:mi:ss'。 } stgirls;int main(int argc,char *argv[]) {connection conn; // 數據庫連接類// 登錄數據庫,返回值:0-成功,其它-失敗。// 失敗代碼在conn.m_cda.rc中,失敗描述在conn.m_cda.message中。if (conn.connecttodb("scott/tiger@snorcl11g_198","Simplified Chinese_China.ZHS16GBK")!=0){printf("connect database failed.\n%s\n",conn.m_cda.message); return -1;}sqlstatement stmt(&conn); // 操作SQL語句的對象。int iminid,imaxid; // 查詢條件最小和最大的id。// 準備查詢表的SQL語句。stmt.prepare("\select id,name,weight,to_char(btime,'yyyy-mm-dd hh24:mi:ss') from girls where id>=:1 and id<=:2");// prepare方法不需要判斷返回值。// 為SQL語句綁定輸入變量的地址,bindin方法不需要判斷返回值。stmt.bindin(1,&iminid);stmt.bindin(2,&imaxid);// 為SQL語句綁定輸出變量的地址,bindout方法不需要判斷返回值。stmt.bindout(1,&stgirls.id);stmt.bindout(2, stgirls.name,30);stmt.bindout(3,&stgirls.weight);stmt.bindout(4, stgirls.btime,19);iminid=2; // 指定待查詢記錄的最小id的值。imaxid=4; // 指定待查詢記錄的最大id的值。// 執行SQL語句,一定要判斷返回值,0-成功,其它-失敗。// 失敗代碼在stmt.m_cda.rc中,失敗描述在stmt.m_cda.message中。if (stmt.execute() != 0){printf("stmt.execute() failed.\n%s\n%s\n",stmt.m_sql,stmt.m_cda.message); return -1;}// 本程序執行的是查詢語句,執行stmt.execute()后,將會在數據庫的緩沖區中產生一個結果集。while (1){memset(&stgirls,0,sizeof(stgirls)); // 先把結構體變量初始化。// 從結果集中獲取一條記錄,一定要判斷返回值,0-成功,1403-無記錄,其它-失敗。// 在實際開發中,除了0和1403,其它的情況極少出現。if (stmt.next() !=0) break;// 把獲取到的記錄的值打印出來。printf("id=%ld,name=%s,weight=%.02f,btime=%s\n",stgirls.id,stgirls.name,stgirls.weight,stgirls.btime);}// 請注意,stmt.m_cda.rpc變量非常重要,它保存了SQL被執行后影響的記錄數。printf("本次查詢了girls表%ld條記錄。\n",stmt.m_cda.rpc); }

運行效果

5、查詢超女表中的記錄數

示例(counttable.cpp)

/** 程序名:counttable.cpp,此程序演示freecplus框架操作Oracle數據庫(查詢表中的記錄數)。* 作者:C語言技術網(www.freecplus.net) 日期:20190525 */ #include "_ooci.h" // freecplus框架操作Oracle的頭文件。int main(int argc,char *argv[]) {connection conn; // 數據庫連接類// 登錄數據庫,返回值:0-成功,其它-失敗。// 失敗代碼在conn.m_cda.rc中,失敗描述在conn.m_cda.message中。if (conn.connecttodb("scott/tiger@snorcl11g_198","Simplified Chinese_China.ZHS16GBK")!=0){printf("connect database failed.\n%s\n",conn.m_cda.message); return -1;}sqlstatement stmt(&conn); // 操作SQL語句的對象。int icount=0; // 用于存放查詢結果的記錄數。// 準備查詢表的SQL語句,把查詢條件直接寫在SQL語句中,沒有采用綁定輸入變量的方法。stmt.prepare("select count(*) from girls where id>=2 and id<=4");// prepare方法不需要判斷返回值。// 為SQL語句綁定輸出變量的地址,bindout方法不需要判斷返回值。stmt.bindout(1,&icount);// 執行SQL語句,一定要判斷返回值,0-成功,其它-失敗。// 失敗代碼在stmt.m_cda.rc中,失敗描述在stmt.m_cda.message中。if (stmt.execute() != 0){printf("stmt.execute() failed.\n%s\n%s\n",stmt.m_sql,stmt.m_cda.message); return -1;}// 本程序執行的是查詢語句,執行stmt.execute()后,將會在數據庫的緩沖區中產生一個結果集。// 但是,在本程序中,結果集永遠只有一條記錄,調用stmt.next()一次就行,不需要循環。stmt.next();printf("girls表中符合條件的記錄數是%d。\n",icount); }

運行效果

7、刪除超女表中的記錄

示例(deletetable.cpp)

/** 程序名:deletetable.cpp,此程序演示freecplus框架操作Oracle數據庫(刪除表中的記錄)。* 作者:C語言技術網(www.freecplus.net) 日期:20190525 */ #include "_ooci.h" // freecplus框架操作Oracle的頭文件。int main(int argc,char *argv[]) {connection conn; // 數據庫連接類// 登錄數據庫,返回值:0-成功,其它-失敗。// 失敗代碼在conn.m_cda.rc中,失敗描述在conn.m_cda.message中。if (conn.connecttodb("scott/tiger@snorcl11g_198","Simplified Chinese_China.ZHS16GBK")!=0){printf("connect database failed.\n%s\n",conn.m_cda.message); return -1;}sqlstatement stmt(&conn); // 操作SQL語句的對象。// 執行SQL語句,一定要判斷返回值,0-成功,其它-失敗。// 失敗代碼在stmt.m_cda.rc中,失敗描述在stmt.m_cda.message中。// 如果不需要綁定輸入和輸出變量,用stmt.execute()方法直接執行SQL語句,不需要stmt.prepare()。if (stmt.execute("delete from girls where id>=2 and id<=4") != 0){printf("stmt.execute() failed.\n%s\n%s\n",stmt.m_sql,stmt.m_cda.message); return -1;}// 請注意,stmt.m_cda.rpc變量非常重要,它保存了SQL被執行后影響的記錄數。printf("本次從girls表中刪除了%ld條記錄。\n",stmt.m_cda.rpc); // 提交事務conn.commit(); }

運行效果

8、執行PL/SQL過程

示例(execplsql.cpp)

/** 程序名:execplsql.cpp,此程序演示freecplus框架操作Oracle數據庫(執行PL/SQL過程)。* 作者:C語言技術網(www.freecplus.net) 日期:20190525* 說說我個人的看法,我從不在Oracle數據庫中創建PL/SQL過程,也很少使用觸發器,原因如下:* 1、在Oracle數據庫中創建PL/SQL過程,程序的調試很麻煩;* 2、維護工作很麻煩,因為維護人員要花時間去了解數據庫中的存儲過程;* 3、采用freecplus框架操作Oracle已經是非常簡單,沒必要去折騰存儲過程;* 4、PL/SQL過程可移植性不好,如果換成mysql或其它數據庫,比較麻煩。* 還有,我在C/C++程序中很少用復雜的PL/SQL過程,因為復雜的PL/SQL調試麻煩。 */ #include "_ooci.h" // freecplus框架操作Oracle的頭文件。int main(int argc,char *argv[]) {connection conn; // 數據庫連接類// 登錄數據庫,返回值:0-成功,其它-失敗。// 失敗代碼在conn.m_cda.rc中,失敗描述在conn.m_cda.message中。if (conn.connecttodb("scott/tiger@snorcl11g_198","Simplified Chinese_China.ZHS16GBK")!=0){printf("connect database failed.\n%s\n",conn.m_cda.message); return -1;}sqlstatement stmt(&conn); // 操作SQL語句的對象。int id=100;// 準備查詢表的PL/SQL語句,先刪除girls表中的全部記錄,再插入一條記錄。stmt.prepare("\BEGIN\delete from girls;\insert into girls(id,name,weight,btime)\values(:1,'超女過程',55.65,to_date('2018-01-02 13:00:55','yyyy-mm-dd hh24:mi:ss'));\END;");// 注意,PL/SQL中的每條SQL需要用分號結束,END之后還有一個分號。// prepare方法不需要判斷返回值。// 為PL/SQL語句綁定輸入變量的地址,bindin方法不需要判斷返回值。stmt.bindin(1,&id);// 執行SQL語句,一定要判斷返回值,0-成功,其它-失敗。if (stmt.execute() != 0){printf("stmt.execute() failed.\n%s\n%s\n",stmt.m_sql,stmt.m_cda.message); return -1;}printf("exec PL/SQL ok.\n");// 提交事務。conn.commit(); }

運行效果

9、CLOB和BLOB字段的操作

sqlstatement類還可以操作CLOB和BLOB字段,在實際開發中,這種需求不多,本文就不演示了,如果您在項目開發中有這方面的需求,可以參考demo程序,示例程序位于freecplus/db/oracle目錄中,如下:

filetoclob.cpp:把文本文件存入數據表的CLOB字段。

clobtofile.cpp:把數據表CLOB字段中的內容導出到文本文件中。

filetoblob.cpp:把文本文件存入數據表的BLOB字段。

blobtofile.cpp:把數據表BLOB字段中的內容導出到文本文件中。

七、應用經驗

freecplus框架的connection和sqlstatement類把OCI的強大功能充分的發揮了出來,且性能卓越。本文提供的示例程序看上去簡單,實則很精妙,希望大家多多思考,慢慢體會。

為了讓大家完全掌握connection和sqlstatement類的用法,我將錄制freecplus框架的專題視頻,請大家多關注C語言技術網(www.freecplus.net)發布的內容。

八、獲取視頻教程

百萬年薪程序員錄制,《C/C++高性能服務開發基礎》視頻教程已在CSDN學院發布,優惠價12元,地址如下:
https://edu.csdn.net/course/play/29402

九、版權聲明

C語言技術網原創文章,轉載請說明文章的來源、作者和原文的鏈接。
來源:C語言技術網(www.freecplus.net)
作者:碼農有道

總結

以上是生活随笔為你收集整理的C语言连接Oracle数据库的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

久久久国际精品 | 欧美精品在线观看免费 | 日韩视频一区二区在线观看 | 久久久久久久久久久免费 | 欧美一级久久久久 | 精品国产aⅴ麻豆 | 2021国产精品视频 | 久久人人97超碰国产公开结果 | 久久久官网 | 免费看三片| 国产免费一区二区三区最新 | 精品无人国产偷自产在线 | 顶级欧美色妇4khd | 亚洲精品中文字幕在线 | 欧美在线一二区 | 麻豆激情电影 | 丁香花在线观看免费完整版视频 | 天天草网站 | 亚洲欧美日本国产 | 久久精品人人做人人综合老师 | 99热高清 | 欧美一级裸体视频 | 激情五月婷婷激情 | 亚洲激情视频在线观看 | 国产综合视频在线观看 | 国产精品久久久久久久久久久久午夜 | 日韩精品一区二 | 国产婷婷精品av在线 | 久久久久免费观看 | av大全在线播放 | 黄在线 | 一区二区三区免费在线观看视频 | 九九一级片 | 99精品在线视频观看 | 国产精品成人一区二区三区吃奶 | av高清影院 | 国产区av在线 | 果冻av在线 | 国产一区二区在线免费播放 | 国产精品欧美一区二区三区不卡 | 欧美韩国日本在线观看 | 天天综合色网 | 精品综合久久久 | 国产一区二区在线观看免费 | 97av视频| 三级黄色在线观看 | 成人综合日日夜夜 | 在线视频电影 | 91久久电影| 五月婷婷丁香综合 | 91中文字幕一区 | ,午夜性刺激免费看视频 | 日韩美av在线 | 国产专区视频在线 | av在线影片| 91av片| 六月天综合网 | 日韩在线高清 | av三级av | 久久99免费 | 国产精品久久久久久一区二区三区 | 麻豆视屏| 国产精品国产自产拍高清av | 精品一区二区三区久久久 | 久久免费毛片 | 国产精品va在线观看入 | 91麻豆精品一区二区三区 | 欧美精品久久久久久久久免 | 亚洲专区在线播放 | 亚洲欧美视频一区二区三区 | 国产黄色av影视 | 日韩一区二区三区在线看 | 国产一区av在线 | 精品久久久久久久久久久久久 | 成在人线av | 91精品福利在线 | 91中文字幕网| 日韩视频免费观看高清完整版在线 | 久久av免费观看 | 蜜臀av网址| 超碰97.com| 精品欧美一区二区三区久久久 | 国产精品视频不卡 | 18做爰免费视频网站 | a色网站 | 手机在线欧美 | 久久免费视频在线观看6 | 91免费看黄色 | 国产精品原创 | 久久国产午夜精品理论片最新版本 | 免费观看91视频 | 国产亚洲精品久久久久久电影 | 一区二三国产 | 97av视频在线观看 | 欧美一区二区伦理片 | 成人黄色免费观看 | 久久精品3| 国产视频在线免费 | 在线国产日韩 | 视频在线观看日韩 | 亚洲高清视频一区二区三区 | 狠狠狠狠狠狠狠干 | 久久久久国产一区二区 | 精品欧美一区二区三区久久久 | 中文字幕精品一区二区精品 | 亚洲aⅴ在线观看 | 久久99爱视频 | 午夜av片 | 久久伊人精品天天 | 久久激情视频 久久 | 99精品国产成人一区二区 | 亚洲深爱激情 | 日韩免费中文 | 在线观看涩涩 | 91精品一 | 久操伊人| 在线电影播放 | 四虎伊人 | 国产91九色视频 | 午夜三级大片 | 亚洲一区美女视频在线观看免费 | 美女免费网站 | 日本精品久久久一区二区三区 | av成年人电影 | 久久久久电影 | 在线免费观看视频一区二区三区 | 免费观看性生交 | 亚洲国产精品va在线看 | 91插插插免费视频 | 91精品久久久久久综合乱菊 | 欧美最猛性xxx | 精品一区二区三区四区在线 | 欧美激情精品久久久久久免费 | 91精品国产高清自在线观看 | 97超碰资源网 | 欧美日韩一级久久久久久免费看 | 久久99九九99精品 | 99久久国产免费看 | 欧美久久99 | 欧美日韩精品在线免费观看 | 九九久久精品视频 | 一级成人网 | 久草视频手机在线 | 激情网站 | 欧美激情在线看 | 久久撸在线视频 | 国产视频二 | 日韩久久精品 | 中文字幕色在线 | 国产一区二区不卡在线 | 91精品免费| 国产69精品久久久久99尤 | 国产片免费在线观看视频 | 精品国产乱码久久久久久浪潮 | 美女视频免费一区二区 | 中文综合在线 | 亚洲欧美怡红院 | 狠狠干狠狠插 | 丁香六月久久综合狠狠色 | 国产成在线观看免费视频 | 亚洲午夜电影网 | 亚洲欧洲日韩在线观看 | 免费观看av网站 | 成人av影视观看 | 人人插人人射 | 香蕉影院在线 | 激情五月综合 | 亚洲免费成人 | 美女网站黄免费 | 丁香视频全集免费观看 | 91精品视频在线播放 | 国产综合在线视频 | 国产小视频在线免费观看视频 | 国产一二区视频 | 亚洲最大在线视频 | 我要看黄色一级片 | 99精品在线观看视频 | 国产精品九九久久99视频 | 人人干网| 亚洲成人午夜在线 | 激情五月婷婷综合网 | 中文字幕在线观看完整版电影 | 久久99视频精品 | 日韩精品视频久久 | 色视频网页| 日韩一区二区免费播放 | 精品一区二区三区电影 | 干天天| 久久这里只有精品视频首页 | 国产中文字幕一区二区三区 | 青青草在久久免费久久免费 | 超碰伊人网 | 91精品国产成 | 日韩一区在线播放 | 在线观看的黄色 | 久久久久国产精品一区二区 | 超碰免费公开 | 黄色在线视频网址 | 婷婷九月丁香 | 五月婷婷视频在线 | 亚洲视屏一区 | 超碰人人在线观看 | 久久这里有 | 特级a毛片| 国产成人精品午夜在线播放 | 久久不卡国产精品一区二区 | 182午夜在线观看 | 91av久久| 91黄色小视频 | 国产成人av一区二区三区在线观看 | 婷婷精品国产一区二区三区日韩 | 国产无遮挡又黄又爽在线观看 | 久久精品一区八戒影视 | 亚洲精品国产精品国自产 | 免费观看完整版无人区 | 欧美性超爽 | 久久8| 992tv又爽又黄的免费视频 | 中文字幕 国产精品 | 日韩精品aaa | 一区二区成人国产精品 | 在线精品视频免费观看 | 这里有精品在线视频 | www国产一区| 伊人婷婷久久 | 丁香影院在线 | 亚洲一级在线观看 | 成人av电影在线播放 | 精品国产一区二区三区四区在线观看 | 97超碰色 | 91热视频 | 日本久热 | 久久人人爽人人人人片 | 日本久久视频 | 国产色视频网站2 | 亚洲一级电影视频 | 国产精品wwwwww| 97香蕉久久超级碰碰高清版 | 国产精品久久一卡二卡 | 国产精品video爽爽爽爽 | 亚洲精品美女久久久久网站 | 国产成人免费观看久久久 | 天天射天天干天天 | 日批视频在线播放 | 日韩va欧美va亚洲va久久 | 97人人模人人爽人人少妇 | 天天射天天爱天天干 | 综合久久久久久 | 久久精品成人热国产成 | 在线观看网站你懂的 | 毛片视频网址 | 日本精品久久久久影院 | 精品中文字幕在线 | 日日夜夜狠狠操 | 日韩黄色影院 | 久久av免费电影 | 91av成人 | 国产成人亚洲精品自产在线 | 天天色.com| 精品麻豆入口免费 | 免费情缘 | 综合网伊人 | 久久久私人影院 | 91一区二区三区在线观看 | 丁香电影小说免费视频观看 | 日韩精品免费一区二区三区 | 99re6热在线精品视频 | 午夜成人免费影院 | 久草精品视频在线播放 | 久久精品www人人爽人人 | 日韩电影在线一区 | 欧洲一区二区三区精品 | 91成品人影院 | 成人精品一区二区三区电影免费 | 国产一级片在线播放 | 一区二区av| 国产黄免费在线观看 | 午夜一级免费电影 | 91在线观看高清 | 九九免费观看视频 | 亚洲人成精品久久久久 | 免费看国产黄色 | av网站有哪些 | 精品国产一区二区三区久久影院 | 中文字幕不卡在线88 | 亚洲精品国产精品国产 | 日韩成人邪恶影片 | 天天色棕合合合合合合 | 九九视频这里只有精品 | 日韩精品中文字幕在线 | 黄色成人影院 | 免费看的av片 | 色成人亚洲网 | 免费久久精品视频 | 五月花婷婷| 亚洲成av人影院 | 亚洲涩涩涩涩涩涩 | 国产91精品一区二区绿帽 | 操操色 | 婷婷在线看 | 日日骑 | 久久免费视频精品 | 成年人在线视频观看 | 激情婷婷亚洲 | 亚洲a网 | 中文字幕免费播放 | 成人av片免费看 | 在线亚洲人成电影网站色www | 国产在线欧美日韩 | a视频在线观看免费 | 中文字幕人成乱码在线观看 | 亚洲激情校园春色 | 久久精品99精品国产香蕉 | wwxxxx日本 | 亚洲欧洲国产精品 | 免费亚洲黄色 | 91亚色在线观看 | 成人av电影在线 | 亚洲黄色区 | 久久久免费播放 | 国模视频一区二区三区 | 日韩成人免费在线电影 | 欧美污污视频 | 国产成人av电影 | 国产精品h在线观看 | 国产一级免费av | 国产精品一区二区三区在线 | 亚洲精品乱码久久久久久写真 | 伊人丁香 | 日韩成人高清在线 | 911久久香蕉国产线看观看 | 久久久久久久久久久久av | 激情综合五月婷婷 | 免费男女羞羞的视频网站中文字幕 | 亚洲影院一区 | 亚洲精品美女久久 | 在线观看不卡视频 | 日韩精品一区二区在线观看 | 中文字幕一区二区三区视频 | 国产天天爽 | 国产精品黄色 | 九月婷婷人人澡人人添人人爽 | 中文久草| a黄在线观看 | 成人国产综合 | 国产高清无av久久 | 久久视了 | 一区二区三区www | 欧美一区二区三区激情视频 | 亚洲一区免费在线 | 久久不卡国产精品一区二区 | a级国产乱理论片在线观看 伊人宗合网 | 色网站国产精品 | 黄色精品网站 | 日韩成人中文字幕 | 青青啪 | 国产第一页福利影院 | 中文字幕永久在线 | 九九九九精品 | 亚洲手机天堂 | 天天射天天干 | 国产黄色a| 美女网色| 国产在线精 | 香蕉久草 | av黄色成人 | 精品不卡av | 天天射天天射天天 | 日本精品一区二区三区在线观看 | 热re99久久精品国产66热 | 日韩精品一区二区三区三炮视频 | 久久再线视频 | 亚洲精品国产精品国自产观看 | 国产黄色特级片 | 久久久综合九色合综国产精品 | 成人久久综合 | 免费在线观看av网址 | 久久久影院一区二区三区 | 国产精品综合久久久久久 | 色婷婷激情电影 | 99久精品视频 | 亚洲欧美成人综合 | 夜夜躁天天躁很躁波 | 欧美精品久久久久久久久久白贞 | 99精品在线看| 在线免费黄 | 色五月激情五月 | 西西444www高清大胆 | a视频在线看 | 日本成人中文字幕在线观看 | 亚洲最大成人免费网站 | 天天插天天狠 | 日韩中文字幕电影 | 国产精品刺激对白麻豆99 | 国产精品美女毛片真酒店 | 日韩欧美精品一区二区 | 免费av观看 | 99综合影院在线 | 日韩精品中字 | 在线а√天堂中文官网 | 免费国产一区二区视频 | 色老板在线视频 | 午夜国产在线 | 国产成人精品久 | 西西4444www大胆艺术 | 国产成人精品999在线观看 | 人人爽人人爽人人片av免 | 日本在线观看一区二区三区 | 久久久免费精品 | 国产手机视频在线播放 | 天天天天天天操 | 999ZYZ玖玖资源站永久 | 波多野结衣在线观看一区 | 免费日韩 精品中文字幕视频在线 | 欧美二区三区91 | 精品日韩在线一区 | 精品久久久久久久久中文字幕 | 毛片永久新网址首页 | 91视频国产免费 | 九九热国产| 日日夜夜91 | 国产第一页在线播放 | 天天干夜夜夜 | 天天舔天天搞 | 免费在线国产视频 | 日韩欧美视频免费观看 | 国产精品久久久久国产精品日日 | 欧美精品乱码久久久久久按摩 | 日韩美女免费线视频 | 91系列在线 | 久久一二三四 | 一本大道久久精品懂色aⅴ 五月婷社区 | 四虎影视精品成人 | 成人黄色毛片视频 | 成人在线免费小视频 | 日韩精品一区二区三区在线播放 | 国产成人精品福利 | 狠狠的干狠狠的操 | 久久久麻豆精品一区二区 | 在线精品在线 | 月下香电影 | 成年美女黄网站色大片免费看 | 欧洲精品码一区二区三区免费看 | 91精品视频在线观看免费 | 国产黄 | 久草电影在线 | 久久少妇 | 91在线免费视频观看 | 91麻豆操 | 97品白浆高清久久久久久 | 久久久久久久av麻豆果冻 | 久久视屏网 | 国产 日韩 欧美 自拍 | 97视频在线观看网址 | 国产精品久久久久永久免费看 | 黄色小说免费在线观看 | 婷婷在线播放 | 中文高清av | 日韩欧美精品一区 | 国产精品一区二区精品视频免费看 | 色婷婷亚洲精品 | 天天天干夜夜夜操 | 国产亚洲精品久久久久久移动网络 | 欧美午夜性生活 | 久久视频一区二区 | 欧美精品在线观看免费 | 天天干天天操天天拍 | 天天操人人要 | 97碰在线| 天天躁日日躁狠狠躁av中文 | 精品国产伦一区二区三区观看方式 | 久久伊人八月婷婷综合激情 | 免费成人av电影 | 久久男女视频 | 91九色在线| 亚洲精品电影在线 | 又黄又刺激又爽的视频 | 国产高清成人在线 | 97成人资源站 | 中文字幕av免费观看 | 日韩精品免费在线播放 | 国产精品国产亚洲精品看不卡 | 五月婷婷播播 | 欧美一级片免费观看 | 国产精品亚洲片在线播放 | 国产亚洲片 | 啪啪肉肉污av国网站 | 青青河边草免费直播 | 久草香蕉在线视频 | 亚洲一区欧美精品 | 69国产精品视频 | 人人爱人人爽 | 国产一区二区三区久久久 | 亚洲一级片 | 亚洲一区美女视频在线观看免费 | 亚洲精品国产精品国自产观看 | 天天综合狠狠精品 | 午夜精品婷婷 | 婷婷激情站 | 18+视频网站链接 | 国产一级精品在线观看 | 91看片在线播放 | 天天做天天爱天天综合网 | 国产理论在线 | 欧美精品国产综合久久 | 亚洲老妇xxxxxx | 精品国产一区二区三区av性色 | 久草免费电影 | 黄色av电影网| 韩国精品一区二区三区六区色诱 | 国产精品国产三级国产专区53 | 91完整版| 国产高清精 | 国产黄色一级片在线 | 精品视频久久久 | 亚洲九九 | 黄色影院在线免费观看 | 999超碰 | 国产 日韩 欧美 自拍 | 在线激情影院一区 | 人人干人人做 | 色婷婷狠狠五月综合天色拍 | 一区二区三区在线看 | 黄色av免费 | 人人爽人人舔 | www.狠狠干 | 在线观看不卡视频 | 国产精品日韩欧美一区二区 | 97超碰人人澡 | 国产精品 日韩精品 | 在线 国产一区 | 日本深夜福利视频 | 国产精品一区二区电影 | 99在线观看免费视频精品观看 | 日韩欧美在线视频一区二区三区 | 99c视频高清免费观看 | 国产成人亚洲在线观看 | 日韩在线观看的 | 久久久亚洲网站 | 久久久精品 | 成人影音在线 | 91在线看 | 麻豆一二| 亚洲综合色播 | 亚洲婷久久 | av网站在线观看播放 | 综合国产在线观看 | 天天干夜夜爽 | 黄色av免费| 久久免费公开视频 | 免费久久99精品国产 | 欧美最猛性xxxxx(亚洲精品) | 国产亚洲成人网 | 欧美俄罗斯性视频 | 麻豆果冻剧传媒在线播放 | 国产精品嫩草影院123 | 国产又黄又猛又粗 | 欧美精品久久久久久久久久丰满 | 五月天精品视频 | 国产麻豆精品在线观看 | 9992tv成人免费看片 | 六月丁香激情综合 | 色综合天天色综合 | 国产99久久精品一区二区300 | 欧洲精品亚洲精品 | 中文字幕精品在线 | 久久另类小说 | 99久视频| 国产亚洲精品bv在线观看 | 91国内产香蕉| 成人一区二区在线观看 | 99精品在线免费观看 | 可以免费观看的av片 | 欧美日韩国产亚洲乱码字幕 | 国产视| 久9在线 | 国产成人一区二区三区在线观看 | 欧美另类tv | 91精品免费视频 | 国产精品视频免费观看 | 国产乱码精品一区二区三区介绍 | 一区二区三区av在线 | 久久免费一 | 超碰在线免费97 | 国产精品乱码久久久 | 天天久久夜夜 | 国产自产在线视频 | 天天射天天射 | 中文在线天堂资源 | 最近字幕在线观看第一季 | 国产99在线免费 | 免费在线观看av不卡 | 日本 在线 视频 中文 有码 | 麻豆传媒视频在线免费观看 | 日韩久久电影 | 国产精品自产拍在线观看 | 国产精品6| 国产精品影音先锋 | 一本一本久久a久久精品综合 | 99精品欧美一区二区蜜桃免费 | 国产青春久久久国产毛片 | 精品一区 在线 | 午夜精品一区二区三区四区 | 欧美一级电影免费观看 | 亚洲欧洲中文日韩久久av乱码 | 日韩精品久久一区二区 | 狠狠躁日日躁 | 麻豆av一区二区三区在线观看 | 成人综合日日夜夜 | 天无日天天操天天干 | 91精品视频免费观看 | 中文视频在线看 | 日韩三级.com | 亚洲伦理一区 | 玖玖玖在线观看 | 日韩在线视 | 精品国产一区二区三区免费 | 在线观看免费视频你懂的 | 国产成人久久 | 亚洲视频在线观看网站 | 国内99视频| 在线看日韩av | www.久久色| 日韩av福利在线 | 欧美日韩中文在线 | 成人91免费视频 | 在线观看韩日电影免费 | 久久精品国产成人 | 欧美成人亚洲成人 | 69亚洲乱 | 亚洲精品高清视频在线观看 | 国产精品久久久久久久久久不蜜月 | 国产视频精品久久 | 亚洲精品成人免费 | 天天干夜夜操视频 | 天天干亚洲| 国产小视频在线免费观看视频 | 色综合天天综合 | 精品国产a | 伊人五月天| 国产精品成久久久久三级 | 欧美三级在线播放 | 国产精品一区免费在线观看 | 高潮久久久 | 亚洲欧美国内爽妇网 | 精品一区电影国产 | 在线综合色 | 国产一区免费在线 | 日韩av在线网站 | 国产精品国产三级国产 | 日韩专区在线播放 | 最近2019年日本中文免费字幕 | 成人免费网站视频 | 日韩视频精品在线 | 一区二区三区国产精品 | 81精品国产乱码久久久久久 | www.av小说| 日韩精品大片 | 日韩视频免费 | 欧美日韩国产三级 | 四虎欧美 | 欧美极品少妇xbxb性爽爽视频 | 亚洲精品www久久久久久 | 免费色视频网址 | 国内久久久久久 | 日韩网站在线看片你懂的 | 国产又粗又长又硬免费视频 | 欧美在线视频a | 国产中文字幕免费 | 91精品国产91热久久久做人人 | 国产精品影音先锋 | 日黄网站| 久草在线免费在线观看 | 在线超碰av | 成人影视片 | 天天爱天天 | 久久免费视频精品 | 国产欧美久久久精品影院 | 亚洲一级黄色大片 | 久久99亚洲网美利坚合众国 | 色婷婷综合激情 | 国产精品一区二区三区四 | 日日草天天草 | 99精品电影 | 国产精品理论在线观看 | 国产精品片| 久久国产精品精品国产色婷婷 | 久草在线资源免费 | 在线免费观看麻豆 | 中文在线字幕免费观看 | 久久日韩精品 | 国产白浆视频 | 精品国产区在线 | 欧美成人在线网站 | 天天干天天想 | 91欧美精品 | 天天艹 | 日韩欧美精选 | 一区二区电影在线观看 | 欧美一级爽 | 国产一区高清在线 | 精品一区二区三区香蕉蜜桃 | www.久热| 91久久精品一区 | 色婷婷激情五月 | 国产麻豆精品久久一二三 | 五月天丁香 | 婷婷丁香色综合狠狠色 | 久久国产女人 | 久久亚洲视频 | 色播五月激情综合网 | 亚洲天堂香蕉 | 亚洲精品国产精品国产 | 色综合久久精品 | 九九国产视频 | 片黄色毛片黄色毛片 | 99热最新地址 | 欧美夫妻性生活电影 | 国产一区二区视频在线播放 | 精品字幕 | 国产精品99久久久久久人免费 | 免费观看一区二区三区视频 | 亚洲成人黄色在线 | 久久av中文字幕片 | 免费午夜视频在线观看 | 青青草国产精品视频 | 日韩欧美高清在线观看 | 中文字幕久久亚洲 | 玖玖玖在线观看 | 麻豆一区二区三区视频 | www.com在线观看 | 狠狠色丁香久久婷婷综合_中 | 99精品成人| 97人人超碰在线 | 97理论电影 | 91视频 - 114av | 免费久久网 | 深爱激情五月综合 | 亚洲精选在线 | 久久爱www. | 一级特黄aaa大片在线观看 | 日日日日日 | 夜夜看av | 久久久999 | 午夜丰满寂寞少妇精品 | 99精品免费久久久久久久久日本 | 亚洲成人第一区 | av动态图片| 久久综合久久综合这里只有精品 | 特级黄色一级 | 精品亚洲视频在线观看 | 黄色一及电影 | 欧美日韩性生活 | 麻豆91精品 | 国产无套精品久久久久久 | 日日天天狠狠 | 黄色特级毛片 | 一区二区欧美日韩 | 久国产在线播放 | 欧美无极色| 丁香五月亚洲综合在线 | 亚洲激情在线观看 | 久草资源在线观看 | 91精品国产成人观看 | 亚州av网站大全 | 在线欧美中文字幕 | 91手机视频在线 | a视频在线观看免费 | 国产在线高清 | 久久亚洲精品电影 | 久久精品免费播放 | 久久综合色婷婷 | 九九热1 | 天天干 天天摸 天天操 | 精品久久一区二区 | 五月亚洲婷婷 | 国产黑丝一区二区 | 久久99精品久久久久蜜臀 | 瑞典xxxx性hd极品 | 天天干天天色2020 | 欧美另类一二三四区 | 成人精品久久久 | 婷婷av电影 | 国产视频在线观看一区二区 | 久久好看免费视频 | 亚洲精品视频在线观看网站 | 天天干com| 99精品国产成人一区二区 | 国产精品久免费的黄网站 | 狠狠操狠狠干天天操 | 在线观看日韩精品视频 | 中文字幕中文中文字幕 | 超碰久热 | 在线观看黄色免费视频 | 久久久久久久久久久久电影 | 少妇性xxx | 久久99视频免费观看 | www.夜色321.com | 欧美一级片免费 | www99精品 | 亚洲成人影音 | 国产理论片在线观看 | 在线一区二区三区 | 日韩精品久久久 | 久久视频免费 | 91精品国产欧美一区二区 | 91精品入口 | 97精品一区 | 西西4444www大胆无视频 | 亚洲精品日韩在线观看 | 午夜影院在线观看18 | 国产高清不卡av | 亚洲国产中文字幕在线观看 | 午夜精品久久久久99热app | 9在线观看免费高清完整版 玖玖爱免费视频 | 免费进去里的视频 | 一区在线观看视频 | 日韩中文字幕91 | 免费色视频网址 | 97人人模人人爽人人喊中文字 | 欧美精品一区二区蜜臀亚洲 | 久久免费视频99 | 人人干天天射 | 国产精品久久久久久久久久直播 | 国产破处视频在线播放 | www.狠狠干 | 日本中文字幕在线观看 | 欧美日韩激情视频8区 | 六月激情婷婷 | 中文字幕在线视频一区 | 久久国产精品免费看 | 亚洲精品乱码久久久久久蜜桃91 | 国产一级一片免费播放放 | 在线观看色网 | 婷婷性综合 | 96视频在线| 91综合视频在线观看 | 成人一级影视 | 国产免费观看高清完整版 | 久久久久北条麻妃免费看 | 欧美一区二区精品在线 | 欧美伦理一区 | 色婷婷狠狠五月综合天色拍 | 在线播放精品一区二区三区 | 国产三级午夜理伦三级 | 久久久久久久久久久高潮一区二区 | 欧美天堂视频在线 | 成全在线视频免费观看 | 国产精品欧美在线 | 成人小视频在线观看免费 | 日韩中文字幕一区 | 国产最顶级的黄色片在线免费观看 | 在线观看国产一区 | 99热这里只有精品国产首页 | av在线收看 | 成人97视频一区二区 | 天天综合网 天天 | 97超碰国产精品 | 探花系列在线 | 免费看十八岁美女 | 99久久久久免费精品国产 | 欧美精品黑人性xxxx | 日韩av电影国产 | 亚洲成aⅴ人在线观看 | 天天爱天天射 | 国产精品麻豆视频 | 江苏妇搡bbbb搡bbbb | 中文字幕 国产视频 | 国产精品麻豆视频 | 狠狠gao| 狠狠狠干 | 狠狠色伊人亚洲综合成人 | 免费看片网页 | 免费福利在线播放 | 久久久久久久久久久电影 | 91精品一区二区在线观看 | 96香蕉视频 | 久久一区二区三区超碰国产精品 | 天天操天天干天天 | 国产精品门事件 | 亚洲精品久久在线 | 国产成人av在线影院 | 911久久香蕉国产线看观看 | 国产123av| 就要干b| 美女黄视频免费看 | 一区二区中文字幕在线播放 | 不卡电影一区二区三区 | 国产资源在线视频 | www.色com| 午夜国产福利在线 | 超碰人人在 | 国产不卡一区二区视频 | 超碰在线98 | 麻花豆传媒mv在线观看网站 | 黄色三级久久 | 国产精品99久久久久久武松影视 | 国产成人无码AⅤ片在线观 日韩av不卡在线 | 日韩av午夜| 亚洲精品视频在线观看免费 | 91资源在线视频 | 国产精品一区二区三区四 | 日韩欧美在线高清 | 亚洲欧美视频在线播放 | 欧美激情视频一二区 | 欧美天堂久久 | 操久在线| 亚洲成人av一区二区 | av3级在线| 2023年中文无字幕文字 | 久久美女精品 | 18pao国产成视频永久免费 | 激情文学综合丁香 | 中文字幕在线一区观看 | 一区二区视频网站 | 日韩精品一区电影 | 97超碰人人澡人人爱 | 欧美91成人网| 久久午夜国产 | 青青河边草免费直播 | 91综合视频在线观看 | 久草在线观看资源 | 亚洲日本国产精品 | 伊人婷婷色 | 99精品视频免费观看视频 | 日韩中文字幕免费 | 欧美福利片在线观看 | 久久老司机精品视频 | 麻豆极品| 欧美99久久| 免费能看的av | 久草视频中文 | 成人在线黄色 | 精品在线观看一区二区 | 中文字幕精品三区 | 伊人久久精品久久亚洲一区 | 五月婷婷激情网 | 女女av在线 | 久久国产精品一区二区三区四区 | 四虎在线免费 | 久久久高清免费视频 | 麻豆国产网站入口 | 精品亚洲成a人在线观看 | 伊人久久精品久久亚洲一区 | 香蕉视频在线免费看 | av资源在线观看 | 毛片a级片| 亚洲免费永久精品国产 | 国产精品乱码一区二区视频 | 手机av电影在线 | 97理论片| 性色av一区二区三区在线观看 | 一区二区不卡高清 | 日韩欧美大片免费观看 | 久操视频在线观看 | 91最新在线 | 免费黄色一区 | 三级黄色大片在线观看 | 成人av在线直播 | 在线 国产 亚洲 欧美 | 国产精品永久免费在线 | 精品久久久久一区二区国产 | 午夜视频在线观看一区二区三区 | 天天综合中文 | 国产丝袜一区二区三区 | 午夜男人影院 | 久久不见久久见免费影院 | 在线天堂中文在线资源网 | 午夜12点 | 久久久国产精华液 | 久久成人综合 | 99精品久久久久久久 | 狠狠色丁香婷婷综合 | 日本女人逼 | 天天操狠狠操网站 | 亚洲成人网av | 在线欧美最极品的av | 91在线免费视频 | 久久久免费视频播放 | 亚洲免费在线看 | 丁香狠狠 | 国产亚洲激情视频在线 | 97国产一区二区 | 91看片淫黄大片91 | 99在线视频播放 | 色婷婷综合久久久 | 成人av教育 | 久久人人爽人人爽人人片av免费 | 久久精品国产99国产 | 国产一区二区综合 | 国产私拍在线 | 国产录像在线观看 | 国产精品一区免费观看 | 久久精品第一页 | 全黄色一级片 | 蜜臀av夜夜澡人人爽人人桃色 | 午夜国产一区二区 | 欧美日韩国产亚洲乱码字幕 |