久久精品国产精品国产精品污,男人扒开添女人下部免费视频,一级国产69式性姿势免费视频,夜鲁夜鲁很鲁在线视频 视频,欧美丰满少妇一区二区三区,国产偷国产偷亚洲高清人乐享,中文 在线 日韩 亚洲 欧美,熟妇人妻无乱码中文字幕真矢织江,一区二区三区人妻制服国产

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

JDBC系列教程

發布時間:2023/12/14 编程问答 34 豆豆
生活随笔 收集整理的這篇文章主要介紹了 JDBC系列教程 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

JDBC系列教程(一)---連接

2.1 概述
Connection 對象代表與數據庫的連接。連接過程包括所執行的 SQL 語句和在該連接上所返回的結果。一個應用程序可與單個數據庫有一個或多個連接,或者可與許多數據庫有連接。


2.1.1 打開連接
與數據庫建立連接的標準方法是調用 DriverManager.getConnection 方法。該方法接受含有某個 URL 的字符串。DriverManager 類(即所謂的 JDBC 管理層)將嘗試找到可與那個 URL 所代表的數據庫進行連接的驅動程序。DriverManager 類存有已注冊的 Driver 類的清單。當調用方法 getConnection 時,它將檢查清單中的每個驅動程序,直到找到可與 URL 中指定的數據庫進行連接的驅動程序為止。Driver 的方法 connect 使用這個 URL 來建立實際的連接。

用戶可繞過 JDBC 管理層直接調用 Driver 方法。這在以下特殊情況下將很有用:當兩個驅動器可同時連接到數據庫中,而用戶需要明確地選用其中特定的驅動器。但一般情況下,讓 DriverManager 類處理打開連接這種事將更為簡單。

下述代碼顯示如何打開一個與位于 URL "jdbc:odbc:wombat" 的數據庫的連接。所用的用戶標識符為 "oboy" ,口令為 "12Java": 

String url = "jdbc:odbc:wombat";
Connection con = DriverManager.getConnection(url, "oboy", "12Java");

2.1.2 一般用法的 URL
由于 URL 常引起混淆,我們將先對一般 URL 作簡單說明,然后再討論 JDBC URL。

URL(統一資源定位符)提供在 Internet 上定位資源所需的信息。可將它想象為一個地址。

URL 的第一部份指定了訪問信息所用的協議,后面總是跟著冒號。常用的協議有 "ftp"(代表“文件傳輸協議”)和 "http" (代表“超文本傳輸協議”)。如果協議是 "file",表示資源是在某個本地文件系統上而非在 Internet 上(下例用于表示我們所描述的部分;它并非 URL 的組成部分)。

ftp://javasoft.com/docs/JDK-1_apidocs.zip
http://java.sun.com/products/jdk/CurrentRelease
file:/home/haroldw/docs/books/tutorial/summary.html

URL 的其余部份(冒號后面的)給出了數據資源所處位置的有關信息。如果協議是 file,則 URL 的其余部份是文件的路徑。對于 ftp 和 http 協議,URL 的其余部份標識了主機并可選地給出某個更詳盡的地址路徑。例如,以下是 JavaSoft 主頁的 URL。該 URL 只標識了主機: 

http://java.sun.com

從該主頁開始瀏覽,就可以進到許多其它的網頁中,其中之一就是 JDBC 主頁。JDBC 主頁的 URL 更為具體,它看起來類似: 

http://java.sun.com/products/jdbc

2.1.3 JDBC URL 
JDBC URL 提供了一種標識數據庫的方法,可以使相應的驅動程序能識別該數據庫并與之建立連接。實際上,驅動程序編程員將決定用什么 JDBC URL 來標識特定的驅動程序。用戶不必關心如何來形成 JDBC URL;他們只須使用與所用的驅動程序一起提供的 URL 即可。JDBC 的作用是提供某些約定,驅動程序編程員在構造他們的 JDBC URL 時應該遵循這些約定。

由于 JDBC URL 要與各種不同的驅動程序一起使用,因此這些約定應非常靈活。首先,它們應允許不同的驅動程序使用不同的方案來命名數據庫。例如, odbc 子協議允許(但并不是要求) URL 含有屬性值。

第二,JDBC URL 應允許驅動程序編程員將一切所需的信息編入其中。這樣就可以讓要與給定數據庫對話的 applet 打開數據庫連接,而無須要求用戶去做任何系統管理工作。

第三, JDBC URL 應允許某種程度的間接性。也就是說,JDBC URL 可指向邏輯主機或數據庫名,而這種邏輯主機或數據庫名將由網絡命名系統動態地轉換為實際的名稱。這可以使系統管理員不必將特定主機聲明為 JDBC 名稱的一部份。網絡命名服務(例如 DNS、 NIS 和 DCE )有多種,而對于使用哪種命名服務并無限制。

JDBC URL 的標準語法如下所示。它由三部分組成,各部分間用冒號分隔: 

jdbc:< 子協議 >:< 子名稱 >

JDBC URL 的三個部分可分解如下: 


jdbc ─ 協議。JDBC URL 中的協議總是 jdbc。


<子協議> ─ 驅動程序名或數據庫連接機制(這種機制可由一個或多個驅動程序支持)的名稱。子協議名的典型示例是 "odbc",該名稱是為用于指定 ODBC 風格的數據資源名稱的 URL 專門保留的。例如,為了通過 JDBC-ODBC 橋來訪問某個數據庫,可以用如下所示的 URL: 
jdbc:odbc:fred

本例中,子協議為 "odbc",子名稱 "fred" 是本地
ODBC 數據資源。

如果要用網絡命名服務(這樣 JDBC URL 中的數據庫名稱不必是實際名稱),則命名服務可以作為子協議。例如,可用如下所示的 URL : 

jdbc:dcenaming:accounts-payable

本例中,該 URL 指定了本地 DCE 命名服務應該將
數據庫名稱 "accounts-payable" 解析為更為具體的
可用于連接真實數據庫的名稱。


<子名稱> ─ 一種標識數據庫的方法。子名稱可以依不同的子協議而變化。它還可以有子名稱的子名稱(含有驅動程序編程員所選的任何內部語法)。使用子名稱的目的是為定位數據庫提供足夠的信息。前例中,因為 ODBC 將提供其余部份的信息,因此用 "fred" 就已足夠。然而,位于遠程服務器上的數據庫需要更多的信息。例如,如果數據庫是通過 Internet 來訪問的,則在 JDBC URL 中應將網絡地址作為子名稱的一部份包括進去,且必須遵循如下所示的標準 URL 命名約定: 
//主機名:端口/子協議

假設 "dbnet" 是個用于將某個主機連接到 Internet 上的協議,則 JDBC URL 類似:

jdbc:dbnet://wombat:356/fred 

2.1.4 "odbc" 子協議
子協議 odbc 是一種特殊情況。它是為用于指定 ODBC 風格的數據資源名稱的 URL 而保留的,并具有下列特性:允許在子名稱(數據資源名稱)后面指定任意多個屬性值。odbc 子協議的完整語法為: 


jdbc:odbc:< 數據資源名稱 >[;< 屬性名 >=< 屬性值 >]*

因此,以下都是合法的 jdbc:odbc 名稱: 

jdbc:odbc:qeor7
jdbc:odbc:wombat
jdbc:odbc:wombat;CacheSize=20;ExtensionCase=LOWER
jdbc:odbc:qeora;UID=kgh;PWD=fooey

2.1.5 注冊子協議
驅動程序編程員可保留某個名稱以將之用作 JDBC URL 的子協議名。當 DriverManager 類將此名稱加到已注冊的驅動程序清單中時,為之保留該名稱的驅動程序應能識別該名稱并與它所標識的數據庫建立連接。例如,odbc 是為 JDBC- ODBC 橋而保留的。示例之二,假設有個 Miracle 公司,它可能會將 "miracle" 注冊為連接到其 Miracle DBMS 上的 JDBC 驅動程序的子協議,從而使其他人都無法使用這個名稱。

JavaSoft 目前作為非正式代理負責注冊 JDBC 子協議名稱。要注冊某個子協議名稱,請發送電子郵件到下述地址: 

jdbc@wombat.eng.sun.com

2.1.6 發送 SQL 語句
連接一旦建立,就可用來向它所涉及的數據庫傳送 SQL 語句。JDBC 對可被發送的 SQL 語句類型不加任何限制。這就提供了很大的靈活性,即允許使用特定的數據庫語句或甚至于非 SQL 語句。然而,它要求用戶自己負責確保所涉及的數據庫可以處理所發送的 SQL 語句,否則將自食其果。例如,如果某個應用程序試圖向不支持儲存程序的 DBMS 發送儲存程序調用,就會失敗并將拋出異常。JDBC 要求驅動程序應至少能提供 ANSI SQL-2 Entry Level 功能才可算是符合 JDBC 標準TM 的。這意味著用戶至少可信賴這一標準級別的功能。

JDBC 提供了三個類,用于向數據庫發送 SQL 語句。Connection 接口中的三個方法可用于創建這些類的實例。下面列出這些類及其創建方法: 


Statement ─ 由方法 createStatement 所創建。Statement 對象用于發送簡單的 SQL 語句。 
PreparedStatement ─ 由方法 prepareStatement 所創建。PreparedStatement 對象用于發送帶有一個或多個輸入參數( IN 參數)的 SQL 語句。PreparedStatement 擁有一組方法,用于設置 IN 參數的值。執行語句時,這些 IN 參數將被送到數據庫中。PreparedStatement 的實例擴展了 Statement ,因此它們都包括了 Statement 的方法。PreparedStatement 對象有可能比 Statement 對象的效率更高,因為它已被預編譯過并存放在那以供將來使用。 
CallableStatement ─ 由方法 prepareCall 所創建。CallableStatement 對象用于執行 SQL 儲存程序 ─ 一組可通過名稱來調用(就象函數的調用那樣)的 SQL 語句。CallableStatement 對象從 PreparedStatement 中繼承了用于處理 IN 參數的方法,而且還增加了用于處理 OUT 參數和 INOUT 參數的方法。 

以下所列提供的方法可以快速決定應用哪個 Connection 方法來創建不同類型的 SQL 語句: 


createStatement 方法用于:


簡單的 SQL 語句(不帶參數) 


prepareStatement 方法用于: 


帶一個或多個 IN 參數的 SQL 語句 


經常被執行的簡單 SQL 語句


prepareCall 方法用于: 


調用已儲存過程


2.1.7 事務
事務由一個或多個這樣的語句組成:這些語句已被執行、完成并被提交或還原。當調用方法 commit 或 rollback 時,當前事務即告就結束,另一個事務隨即開始。

缺省情況下,新連接將處于自動提交模式。也就是說,當執行完語句后,將自動對那個語句調用 commit 方法。這種情況下,由于每個語句都是被單獨提交的,因此一個事務只由一個語句組成。如果禁用自動提交模式,事務將要等到 commit 或 rollback 方法被顯式調用時才結束,因此它將包括上一次調用 commit 或 rollback 方法以來所有執行過的語句。對于第二種情況,事務中的所有語句將作為組來提交或還原。

方法 commit 使 SQL 語句對數據庫所做的任何更改成為永久性的,它還將釋放事務持有的全部鎖。而方法 rollback 將棄去那些更改。

有時用戶在另一個更改生效前不想讓此更改生效。這可通過禁用自動提交并將兩個更新組合在一個事務中來達到。如果兩個更新都是成功的,則調用 commit 方法,從而使兩個更新結果成為永久性的;如果其中之一或兩個更新都失敗了,則調用 rollback 方法,以將值恢復為進行更新之前的值。

大多數 JDBC 驅動程序都支持事務。事實上,符合 JDBC 的驅動程序必須支持事務。DatabaseMetaData 給出的信息描述 DBMS 所提供的事務支持水平。


2.1.8 事務隔離級別
如果 DBMS 支持事務處理,它必須有某種途徑來管理兩個事務同時對一個數據庫進行操作時可能發生的沖突。用戶可指定事務隔離級別,以指明 DBMS 應該花多大精力來解決潛在沖突。例如,當事務更改了某個值而第二個事務卻在該更改被提交或還原前讀取該值時該怎么辦? 假設第一個事務被還原后,第二個事務所讀取的更改值將是無效的,那么是否可允許這種沖突? JDBC 用戶可用以下代碼來指示 DBMS 允許在值被提交前讀取該值(“dirty 讀取”),其中 con 是當前連接: 

con.setTransactionIsolation(TRANSACTION_READ_UNCOMMITTED);

事務隔離級別越高,為避免沖突所花的精力也就越多。Connection 接口定義了五級,其中最低級別指定了根本就不支持事務,而最高級別則指定當事務在對某個數據庫進行操作時,任何其它事務不得對那個事務正在讀取的數據進行任何更改。通常,隔離級別越高,應用程序執行的速度也就越慢(由于用于鎖定的資源耗費增加了,而用戶間的并發操作減少了)。在決定采用什么隔離級別時,開發人員必須在性能需求和數據一致性需求之間進行權衡。當然,實際所能支持的級別取決于所涉及的 DBMS 的功能。

當創建 Connection 對象時,其事務隔離級別取決于驅動程序,但通常是所涉及的數據庫的缺省值。用戶可通過調用 setIsolationLevel 方法來更改事務隔離級別。新的級別將在該連接過程的剩余時間內生效。要想只改變一個事務的事務隔離級別,必須在該事務開始前進行設置,并在該事務結束后進行復位。我們不提倡在事務的中途對事務隔離級別進行更改,因為這將立即觸發 commit 方法的調用,使在此之前所作的任何更改變成永久性的。

--------------------------------------------------------------------------------------------------------

JDBC系列教程(二)---驅動設置

3.1 概述
DriverManager 類是 JDBC 的管理層,作用于用戶和驅動程序之間。它跟蹤可用的驅動程序,并在數據庫和相應驅動程序之間建立連接。另外,DriverManager 類也處理諸如驅動程序登錄時間限制及登錄和跟蹤消息的顯示等事務。

對于簡單的應用程序,一般程序員需要在此類中直接使用的唯一方法是 DriverManager.getConnection。正如名稱所示,該方法將建立與數據庫的連接。JDBC 允許用戶調用 DriverManager 的方法 getDriver、getDrivers 和 registerDriver 及 Driver 的方法 connect。但多數情況下,讓 DriverManager 類管理建立連接的細節為上策。


3.1.1 跟蹤可用驅動程序
DriverManager 類包含一列 Driver 類,它們已通過調用方法 DriverManager.registerDriver 對自己進行了注冊。所有 Driver 類都必須包含有一個靜態部分。它創建該類的實例,然后在加載該實例時 DriverManager 類進行注冊。這樣,用戶正常情況下將不會直接調用 DriverManager.registerDriver;而是在加載驅動程序時由驅動程序自動調用。加載 Driver 類,然后自動在 DriverManager 中注冊的方式有兩種: 


通過調用方法 Class.forName。這將顯式地加載驅動程序類。由于這與外部設置無關,因此推薦使用這種加載驅動程序的方法。以下代碼加載類 acme.db.Driver: 
Class.forName("acme.db.Driver");

如果將 acme.db.Driver 編寫為加載時創建實例,并調用以該實例為參數的 DriverManager.registerDriver(本該如此),則它在 DriverManager 的驅動程序列表中,并可用于創建連接。


通過將驅動程序添加到 java.lang.System 的屬性 jdbc.drivers 中。這是一個由 DriverManager 類加載的驅動程序類名的列表,由冒號分隔:初始化 DriverManager 類時,它搜索系統屬性 jdbc.drivers,如果用戶已輸入了一個或多個驅動程序,則 DriverManager 類將試圖加載它們。以下代碼說明程序員如何在 ~/.hotjava/properties 中輸入三個驅動程序類(啟動時,HotJava 將把它加載到系統屬性列表中): 
jdbc.drivers=foo.bah.Driver:wombat.sql.Driver:bad.test.ourDriver;

對 DriverManager 方法的第一次調用將自動加載這些驅動程序類。

注意:加載驅動程序的第二種方法需要持久的預設環境。如果對這一點不能保證,則調用方法 Class.forName 顯式地加載每個驅動程序就顯得更為安全。這也是引入特定驅動程序的方法,因為一旦 DriverManager 類被初始化,它將不再檢查 jdbc.drivers 屬性列表。

在以上兩種情況中,新加載的 Driver 類都要通過調用 DriverManager.registerDriver 類進行自我注冊。如上所述,加載類時將自動執行這一過程。

由于安全方面的原因,JDBC 管理層將跟蹤哪個類加載器提供哪個驅動程序。這樣,當 DriverManager 類打開連接時,它僅使用本地文件系統或與發出連接請求的代碼相同的類加載器提供的驅動程序。


3.1.2 建立連接
加載 Driver 類并在 DriverManager 類中注冊后,它們即可用來與數據庫建立連接。當調用 DriverManager.getConnection 方法發出連接請求時,DriverManager 將檢查每個驅動程序,查看它是否可以建立連接。

有時可能有多個 JDBC 驅動程序可以與給定的 URL 連接。例如,與給定遠程數據庫連接時,可以使用 JDBC-ODBC 橋驅動程序、JDBC 到通用網絡協議驅動程序或數據庫廠商提供的驅動程序。在這種情況下,測試驅動程序的順序至關重要,因為 DriverManager 將使用它所找到的第一個可以成功連接到給定 URL 的驅動程序。

首先 DriverManager 試圖按注冊的順序使用每個驅動程序(jdbc.drivers 中列出的驅動程序總是先注冊)。它將跳過代碼不可信任的驅動程序,除非加載它們的源與試圖打開連接的代碼的源相同。

它通過輪流在每個驅動程序上調用方法 Driver.connect,并向它們傳遞用戶開始傳遞給方法 DriverManager.getConnection 的 URL 來對驅動程序進行測試,然后連接第一個認出該 URL 的驅動程序。

這種方法初看起來效率不高,但由于不可能同時加載數十個驅動程序,因此每次連接實際只需幾個過程調用和字符串比較。

以下代碼是通常情況下用驅動程序(例如 JDBC-ODBC 橋驅動程序)建立連接所需所有步驟的示例: 

Class.forName("sun.jdbc.odbc.JdbcOdbcDriver"); //加載驅動程序
String url = "jdbc:odbc:fred";
DriverManager.getConnection(url, "userID", "passwd");

-----------------------------------------------------------------------------------------------

JDBC系列教程(三)---語句
4.1?概述?
Statement?對象用于將?SQL?語句發送到數據庫中。實際上有三種?Statement?對象,它們都作為在給定連接上執行?SQL?語句的包容器:Statement、PreparedStatement(它從?Statement?繼承而來)和?CallableStatement(它從?PreparedStatement?繼承而來)。它們都專用于發送特定類型的?SQL?語句:?Statement?對象用于執行不帶參數的簡單?SQL?語句;PreparedStatement?對象用于執行帶或不帶?IN?參數的預編譯?SQL?語句;CallableStatement?對象用于執行對數據庫已存儲過程的調用。?

Statement?接口提供了執行語句和獲取結果的基本方法。PreparedStatement?接口添加了處理?IN?參數的方法;而?CallableStatement?添加了處理?OUT?參數的方法。?


4.1.1?創建?Statement?對象?
建立了到特定數據庫的連接之后,就可用該連接發送?SQL?語句。Statement?對象用?Connection?的方法?createStatement?創建,如下列代碼段中所示: 

Connection?con?=?DriverManager.getConnection(url,?"sunny",?"");?
Statement?stmt?=?con.createStatement();?

為了執行?Statement?對象,被發送到數據庫的?SQL?語句將被作為參數提供給?Statement?的方法: 

ResultSet?rs?=?stmt.executeQuery("SELECT?a,?b,?c?FROM?Table2");?

4.1.2?使用?Statement?對象執行語句?
Statement?接口提供了三種執行?SQL?語句的方法:executeQuery、executeUpdate?和?execute。使用哪一個方法由?SQL?語句所產生的內容決定。?

方法?executeQuery?用于產生單個結果集的語句,例如?SELECT?語句。?

方法?executeUpdate?用于執行?INSERT、UPDATE?或?DELETE?語句以及?SQL?DDL(數據定義語言)語句,例如?CREATE?TABLE?和?DROP?TABLE。INSERT、UPDATE?或?DELETE?語句的效果是修改表中零行或多行中的一列或多列。executeUpdate?的返回值是一個整數,指示受影響的行數(即更新計數)。對于?CREATE?TABLE?或?DROP?TABLE?等不操作行的語句,executeUpdate?的返回值總為零。?

方法?execute?用于執行返回多個結果集、多個更新計數或二者組合的語句。因為多數程序員不會需要該高級功能,所以本概述后面將在單獨一節中對其進行介紹。?

執行語句的所有方法都將關閉所調用的?Statement?對象的當前打開結果集(如果存在)。這意味著在重新執行?Statement?對象之前,需要完成對當前?ResultSet?對象的處理。?

應注意,繼承了?Statement?接口中所有方法的?PreparedStatement?接口都有自己的?executeQuery、executeUpdate?和?execute?方法。Statement?對象本身不包含?SQL?語句,因而必須給?Statement.execute?方法提供?SQL?語句作為參數。PreparedStatement?對象并不將?SQL?語句作為參數提供給這些方法,因為它們已經包含預編譯?SQL?語句。CallableStatement?對象繼承這些方法的?PreparedStatement?形式。對于這些方法的?PreparedStatement?或?CallableStatement?版本,使用查詢參數將拋出?SQLException。?


4.1.3?語句完成?
當連接處于自動提交模式時,其中所執行的語句在完成時將自動提交或還原。語句在已執行且所有結果返回時,即認為已完成。對于返回一個結果集的?executeQuery?方法,在檢索完?ResultSet?對象的所有行時該語句完成。對于方法?executeUpdate,當它執行時語句即完成。但在少數調用方法?execute?的情況中,在檢索所有結果集或它生成的更新計數之后語句才完成。?

有些?DBMS?將已存儲過程中的每條語句視為獨立的語句;而另外一些則將整個過程視為一個復合語句。在啟用自動提交時,這種差別就變得非常重要,因為它影響什么時候調用?commit?方法。在前一種情況中,每條語句單獨提交;在后一種情況中,所有語句同時提交。?


4.1.4?關閉?Statement?對象?
Statement?對象將由?Java?垃圾收集程序自動關閉。而作為一種好的編程風格,應在不需要?Statement?對象時顯式地關閉它們。這將立即釋放?DBMS?資源,有助于避免潛在的內存問題。?


4.1.5?Statement?對象中的?SQL?轉義語法 
Statement?可包含使用?SQL?轉義語法的?SQL?語句。轉義語法告訴驅動程序其中的代碼應該以不同方式處理。驅動程序將掃描任何轉義語法,并將它轉換成特定數據庫可理解的代碼。這使得轉義語法與?DBMS?無關,并允許程序員使用在沒有轉義語法時不可用的功能。?

轉義子句由花括號和關鍵字界定: 

{keyword?.?.?.?parameters?.?.?.?}?

該關鍵字指示轉義子句的類型,如下所示。?


escape?表示?LIKE?轉義字符 


字符“%”和“_”類似于?SQL?LIKE?子句中的通配符(“%”匹配零個或多個字符,而“_”則匹配一個字符)。為了正確解釋它們,應在其前面加上反斜杠(“/”),它是字符串中的特殊轉義字符。在查詢末尾包括如下語法即可指定用作轉義字符的字符: 

{escape?'escape-character'}?


例如,下列查詢使用反斜杠字符作為轉義字符,查找以下劃線開頭的標識符名: 

stmt.executeQuery("SELECT?name?FROM?Identifiers?
WHERE?Id?LIKE?`/_%'?{escape?`/'};?


fn?表示標量函數?


幾乎所有?DBMS?都具有標量值的數值、字符串、時間、日期、系統和轉換函數。要使用這些函數,可使用如下轉義語法:關鍵字?fn?后跟所需的函數名及其參數。例如,下列代碼調用函數?concat?將兩個參數連接在一起: 

{fn?concat("Hot",?"Java")};?


可用下列語法獲得當前數據庫用戶名: 

{fn?user()};?


標量函數可能由語法稍有不同的?DBMS?支持,而它們可能不被所有驅動程序支持。各種?DatabaseMetaData?方法將列出所支持的函數。例如,方法?getNumericFunctions?返回用逗號分隔的數值函數列表,而方法?getStringFunctions?將返回字符串函數,等等。?

驅動程序將轉義函數調用映射為相應的語法,或直接實現該函數。?


d、t?和?ts?表示日期和時間文字?


DBMS?用于日期、時間和時間標記文字的語法各不相同。JDBC?使用轉義子句支持這些文字的語法的?ISO?標準格式。驅動程序必須將轉義子句轉換成?DBMS?表示。?

例如,可用下列語法在?JDBC?SQL?語句中指定日期: 

{d?`yyyy-mm-dd'}?


在該語法中,yyyy?為年代,mm?為月份,而?dd?則為日期。驅動程序將用等價的特定于?DBMS?的表示替換這個轉義子句。例如,如果?'28-?FEB-99'?符合基本數據庫的格式,則驅動程序將用它替換?{d?1999-02-28}。?

對于?TIME?和?TIMESTAMP?也有類似的轉義子句: 

{t?`hh:mm:ss'}?
{ts?`yyyy-mm-dd?hh:mm:ss.f?.?.?.'}?


TIMESTAMP?中的小數點后的秒(.f?.?.?.)部分可忽略。?


call?或???=?call?表示已存儲過程?


如果數據庫支持已存儲過程,則可從?JDBC?中調用它們,語法為: 

{call?procedure_name[(?,??,?.?.?.)]}?


或(其中過程返回結果參數): 

{??=?call?procedure_name[(?,??,?.?.?.)]}?


方括號指示其中的內容是可選的。它們不是語法的必要部分。?

輸入參數可以為文字或參數。有關詳細信息,參見?JDBC?指南中第?7?節,“CallableStatement”。?

可通過調用方法?DatabaseMetaData.supportsStoredProcedures?檢查數據庫是否支持已存儲過程。?


oj?表示外部連接?


外部連接的語法為 

{oj?outer-join}?


其中?outer-join?形式為 

table?LEFT?OUTER?JOIN?{table?/?outer-join}?ON?search-condition?


外部連接屬于高級功能。有關它們的解釋可參見?SQL?語法。JDBC?提供了三種?DatabaseMetaData?方法用于確定驅動程序支持哪些外部連接類型:supportsOuterJoins、supportsFullOuterJoins?和?supportsLimitedOuterJoins。?


方法?Statement.setEscapeProcessing?可打開或關閉轉義處理;缺省狀態為打開。當性能極為重要時,程序員可能想關閉它以減少處理時間。但通常它將出于打開狀態。應注意:?setEscapeProcessing?不適用于?PreparedStatement?對象,因為在調用該語句前它就可能已被發送到數據庫。有關預編譯的信息,參見?PreparedStatement。?


4.1.6?使用方法?execute?
execute?方法應該僅在語句能返回多個?ResultSet?對象、多個更新計數或?ResultSet?對象與更新計數的組合時使用。當執行某個已存儲過程或動態執行未知?SQL?字符串(即應用程序程序員在編譯時未知)時,有可能出現多個結果的情況,盡管這種情況很少見。例如,用戶可能執行一個已存儲過程(使用?CallableStatement?對象?-?參見第?135?頁的?CallableStatement),并且該已存儲過程可執行更新,然后執行選擇,再進行更新,再進行選擇,等等。通常使用已存儲過程的人應知道它所返回的內容。?

因為方法?execute?處理非常規情況,所以獲取其結果需要一些特殊處理并不足為怪。例如,假定已知某個過程返回兩個結果集,則在使用方法?execute?執行該過程后,必須調用方法?getResultSet?獲得第一個結果集,然后調用適當的?getXXX?方法獲取其中的值。要獲得第二個結果集,需要先調用?getMoreResults?方法,然后再調用?getResultSet?方法。如果已知某個過程返回兩個更新計數,則首先調用方法?getUpdateCount,然后調用?getMoreResults,并再次調用?getUpdateCount。?

對于不知道返回內容,則情況更為復雜。如果結果是?ResultSet?對象,則方法?execute?返回?true;如果結果是?Java?int,則返回?false。如果返回?int,則意味著結果是更新計數或執行的語句是?DDL?命令。在調用方法?execute?之后要做的第一件事情是調用?getResultSet?或?getUpdateCount。調用方法?getResultSet?可以獲得兩個或多個?ResultSet?對象中第一個對象;或調用方法?getUpdateCount?可以獲得兩個或多個更新計數中第一個更新計數的內容。?

當?SQL?語句的結果不是結果集時,則方法?getResultSet?將返回?null。這可能意味著結果是一個更新計數或沒有其它結果。在這種情況下,判斷?null?真正含義的唯一方法是調用方法?getUpdateCount,它將返回一個整數。這個整數為調用語句所影響的行數;如果為?-1?則表示結果是結果集或沒有結果。如果方法?getResultSet?已返回?null(表示結果不是?ResultSet?對象),則返回值?-1?表示沒有其它結果。也就是說,當下列條件為真時表示沒有結果(或沒有其它結果): 

((stmt.getResultSet()?==?null)?& ;& (stmt.getUpdateCount() == -1))

如果已經調用方法 getResultSet 并處理了它返回的 ResultSet 對象,則有必要調用方法 getMoreResults 以確定是否有其它結果集或更新計數。如果 getMoreResults 返回 true,則需要再次調用 getResultSet 來檢索下一個結果集。如上所述,如果 getResultSet 返回 null,則需要調用 getUpdateCount 來檢查 null 是表示結果為更新計數還是表示沒有其它結果。

當 getMoreResults 返回 false 時,它表示該 SQL 語句返回一個更新計數或沒有其它結果。因此需要調用方法 getUpdateCount 來檢查它是哪一種情況。在這種情況下,當下列條件為真時表示沒有其它結果: 

((stmt.getMoreResults() == false) && (stmt.getUpdateCount() == -1))

下面的代碼演示了一種方法用來確認已訪問調用方法 execute 所產生的全部結果集和更新計數: 


stmt.execute(queryStringWithUnknownResults);
while (true) {
int rowCount = stmt.getUpdateCount();
if (rowCount > 0) { // 它是更新計數
System.out.println("Rows changed = " + count);
stmt.getMoreResults();
continue;
}
if (rowCount == 0) { // DDL 命令或 0 個更新
System.out.println(" No rows changed or statement was DDL
command");
stmt.getMoreResults();
continue;
}

// 執行到這里,證明有一個結果集
// 或沒有其它結果

ResultSet rs = stmt.getResultSet;
if (rs != null) {
. . . // 使用元數據獲得關于結果集列的信息
while (rs.next()) {
. . . // 處理結果
stmt.getMoreResults();
continue;
}
break; // 沒有其它結果

-----------------------------------------------------------------------

JDBC系列教程(四)---結果設置

JDBC系列教程(四)---結果設置
www.firnow.com??? 時間 : 2007-02-06? 作者:佚名?? 編輯:本站 點擊:?? [ 評論 ]
-
-
5.1 概述
ResultSet 包含符合 SQL 語句中條件的所有行,并且它通過一套 get 方法(這些 get 方法可以訪問當前行中的不同列)提供了對這些行中數據的訪問。ResultSet.next 方法用于移動到 ResultSet 中的下一行,使下一行成為當前行。

結果集一般是一個表,其中有查詢所返回的列標題及相應的值。例如,如果查詢為 SELECT a, b, c FROM Table1,則結果集將具有如下形式: 


a b c
-------- --------- --------
12345 Cupertino CA
83472 Redmond WA
83492 Boston MA


下面的代碼段是執行 SQL 語句的示例。該 SQL 語句將返回行集合,其中列 1 為 int,列 2 為 String,而列 3 則為字節數組: 


java.sql.Statement stmt = conn.createStatement();
ResultSet r = stmt.executeQuery("SELECT a, b, c FROM Table1");
while (r.next())
{
// 打印當前行的值。
int i = r.getInt("a");
String s = r.getString("b");
float f = r.getFloat("c");
System.out.println("ROW = " + i + " " + s + " " + f);
}

5.1.1 行和光標
ResultSet 維護指向其當前數據行的光標。每調用一次 next 方法,光標向下移動一行。最初它位于第一行之前,因此第一次調用 next 將把光標置于第一行上,使它成為當前行。隨著每次調用 next 導致光標向下移動一行,按照從上至下的次序獲取 ResultSet 行。

在 ResultSet 對象或其父輩 Statement 對象關閉之前,光標一直保持有效。

在 SQL 中,結果表的光標是有名字的。如果數據庫允許定位更新或定位刪除,則需要將光標的名字作為參數提供給更新或刪除命令。可通過調用方法 getCursorName 獲得光標名。

注意:不是所有的 DBMS 都支持定位更新和刪除。可使用 DatabaseMetaData.supportsPositionedDelete 和 supportsPositionedUpdate 方法來檢查特定連接是否支持這些操作。當支持這些操作時,DBMS/驅動程序必須確保適當鎖定選定行,以使定位更新不會導致更新異常或其它并發問題。


5.1.2 列
方法 getXXX 提供了獲取當前行中某列值的途徑。在每一行內,可按任何次序獲取列值。但為了保證可移植性,應該從左至右獲取列值,并且一次性地讀取列值。

列名或列號可用于標識要從中獲取數據的列。例如,如果 ResultSet 對象 rs 的第二列名為“title”,并將值存儲為字符串,則下列任一代碼將獲取存儲在該列中的值: 

String s = rs.getString("title");
String s = rs.getString(2);

注意列是從左至右編號的,并且從列 1 開始。同時,用作 getXXX 方法的輸入的列名不區分大小寫。

提供使用列名這個選項的目的是為了讓在查詢中指定列名的用戶可使用相同的名字作為 getXXX 方法的參數。另一方面,如果 select 語句未指定列名(例如在“select * from table1”中或列是導出的時),則應該使用列號。這些情況下,用戶將無法確切知道列名。

有些情況下,SQL 查詢返回的結果集中可能有多個列具有相同的名字。如果列名用作 getXXX 方法的參數,則 getXXX 將返回第一個匹配列名的值。因而,如果多個列具有相同的名字,則需要使用列索引來確保檢索了正確的列值。這時,使用列號效率要稍微高一些。

關于 ResultSet 中列的信息,可通過調用方法 ResultSet.getMetaData 得到。返回的 ResultSetMetaData 對象將給出其 ResultSet 對象各列的編號、類型和屬性。

如果列名已知,但不知其索引,則可用方法 findColumn 得到其列號。


5.1.3 數據類型和轉換
對于 getXXX 方法,JDBC 驅動程序試圖將基本數據轉換成指定 Java 類型,然后返回適合的 Java 值。例如,如果 getXXX 方法為 getString,而基本數據庫中數據類型為 VARCHAR,則 JDBC 驅動程序將把 VARCHAR 轉換成 Java String。getString 的返回值將為 Java String 對象。

下表顯示了允許用 getXXX 獲取的 JDBC 類型及推薦用它獲取的 JDBC 類型(通用 SQL 類型)。小寫的 x 表示允許 getXXX 方法獲取該數據類型;大寫的 X 表示對該數據類型推薦使用 getXXX 方法。例如,除了 getBytes 和 getBinaryStream 之外的任何 getXXX 方法都可用來獲取 LONGVARCHAR 值,但是推薦根據返回的數據類型使用 getAsciiStream 或 getUnicodeStream 方法。方法 getObject 將任何數據類型返回為 Java Object。當基本數據類型是特定于數據庫的抽象類型或當通用應用程序需要接受任何數據類型時,它是非常有用的。

可使用 ResultSet.getXXX 方法獲取常見的 JDBC 數據類型。

5.1.4 對非常大的行值使用流
ResultSet 可以獲取任意大的 LONGVARBINARY 或 LONGVARCHAR 數據。方法 getBytes 和 getString 將數據返回為大的塊(最大為 Statement.getMaxFieldSize 的返回值)。但是,以較小的固定塊獲取非常大的數據可能會更方便,而這可通過讓 ResultSet 類返回 java.io.Input 流來完成。從該流中可分塊讀取數據。注意:必須立即訪問這些流,因為在下一次對 ResultSet 調用 getXXX 時它們將自動關閉(這是由于基本實現對大塊數據訪問有限制)。 

JDBC API 具有三個獲取流的方法,分別具有不同的返回值: 


getBinaryStream 返回只提供數據庫原字節而不進行任何轉換的流。


getAsciiStream 返回提供單字節 ASCII 字符的流。


getUnicodeStream 返回提供雙字節 Unicode 字符的流。


注意:它不同于 Java 流,后者返回無類型字節并可(例如)通用于 ASCII 和 Unicode 字符。

下列代碼演示了 getAsciiStream 的用法: 

java.sql.Statement stmt = con.createStatement();
ResultSet r = stmt.executeQuery("SELECT x FROM Table2");
// 現在以 4K 塊大小獲取列 1 結果:
byte buff = new byte[4096];
while (r.next()) {
Java.io.InputStream fin = r.getAsciiStream(1);
for (;;) {
int size = fin.read(buff);
if (size == -1) { // 到達流末尾
break;
}
// 將新填充的緩沖區發送到 ASCII 輸出流:
output.write(buff, 0, size);
}
}

5.1.5 NULL 結果值
要確定給定結果值是否是 JDBC NULL,必須先讀取該列,然后使用 ResultSet.wasNull 方法檢查該次讀取是否返回 JDBC NULL。

當使用 ResultSet.getXXX 方法讀取 JDBC NULL 時,方法 wasNull 將返回下列值之一: 


Java null 值:對于返回 Java 對象的 getXXX 方法(例如 getString、getBigDecimal、getBytes、getDate、getTime、getTimestamp、getAsciiStream、getUnicodeStream、getBinaryStream、getObject 等)。


零值:對于 getByte、getShort、getInt、getLong、getFloat 和 getDouble。


false 值:對于 getBoolean。


5.1.6 可選結果集或多結果集
通常使用 executeQuery(它返回單個 ResultSet)或 executeUpdate(它可用于任何數據庫修改語句,并返回更新行數)可執行 SQL 語句。但有些情況下,應用程序在執行語句之前不知道該語句是否返回結果集。此外,有些已存儲過程可能返回幾個不同的結果集和/或更新計數。

為了適應這些情況,JDBC 提供了一種機制,允許應用程序執行語句,然后處理由結果集和更新計數組成的任意集合。這種機制的原理是首先調用一個完全通用的 execute 方法,然后調用另外三個方法,getResultSet、getUpdateCount 和 getMoreResults。這些方法允許應用程序一次一個地研究語句結果,并確定給定結果是 ResultSet 還是更新計數。

用戶不必關閉 ResultSet;當產生它的 Statement 關閉、重新執行或用于從多結果序列中獲取下一個結果時,該 ResultSet 將被 Statement 自動關閉。

------------------------------------------------------------

JDBC系列教程(五)---準備語句
6.1 概述
該 PreparedStatement 接口繼承 Statement,并與之在兩方面有所不同: 


PreparedStatement 實例包含已編譯的 SQL 語句。這就是使語句“準備好”。 
包含于 PreparedStatement 對象中的 SQL 語句可具有一個或多個 IN 參數。IN 參數的值在 SQL 語句創建時未被指定。相反的,該語句為每個 IN 參數保留一個問號(“?”)作為占位符。每個問號的值必須在該語句執行之前,通過適當的 setXXX 方法來提供。 

由于 PreparedStatement 對象已預編譯過,所以其執行速度要快于 Statement 對象。因此,多次執行的 SQL 語句經常創建為 PreparedStatement 對象,以提高效率。

作為 Statement 的子類,PreparedStatement 繼承了 Statement 的所有功能。另外它還添加了一整套方法,用于設置發送給數據庫以取代 IN 參數占位符的值。同時,三種方法 execute、 executeQuery 和 executeUpdate 已被更改以使之不再需要參數。這些方法的 Statement 形式(接受 SQL 語句參數的形式)不應該用于 PreparedStatement 對象。


6.1.1 創建 PreparedStatement 對象
以下的代碼段(其中 con 是 Connection 對象)創建包含帶兩個 IN 參數占位符的 SQL 語句的 PreparedStatement 對象: 

PreparedStatement pstmt = con.prepareStatement(
"UPDATE table4 SET m = ? WHERE x = ?");

pstmt 對象包含語句 "UPDATE table4 SET m = ? WHERE x = ?",它已發送給 DBMS,并為執行作好了準備。


6.1.2 傳遞 IN 參數
在執行 PreparedStatement 對象之前,必須設置每個 ? 參數的值。這可通過調用 setXXX 方法來完成,其中 XXX 是與該參數相應的類型。例如,如果參數具有 Java 類型 long,則使用的方法就是 setLong。setXXX 方法的第一個參數是要設置的參數的序數位置,第二個參數是設置給該參數的值。例如,以下代碼將第一個參數設為 123456789,第二個參數設為 100000000: 

pstmt.setLong(1, 123456789);
pstmt.setLong(2, 100000000);

一旦設置了給定語句的參數值,就可用它多次執行該語句,直到調用 clearParameters 方法清除它為止。

在連接的缺省模式下(啟用自動提交),當語句完成時將自動提交或還原該語句。

如果基本數據庫和驅動程序在語句提交之后仍保持這些語句的打開狀態,則同一個 PreparedStatement 可執行多次。如果這一點不成立,那么試圖通過使用 PreparedStatement 對象代替 Statement 對象來提高性能是沒有意義的。

利用 pstmt(前面創建的 PreparedStatement 對象),以下代碼例示了如何設置兩個參數占位符的值并執行 pstmt 10 次。如上所述,為做到這一點,數據庫不能關閉 pstmt。在該示例中,第一個參數被設置為 "Hi"并保持為常數。在 for 循環中,每次都將第二個參數設置為不同的值:從 0 開始,到 9 結束。

pstmt.setString(1, "Hi");
for (int i = 0; i < 10; i++) {
pstmt.setInt(2, i);
int rowCount = pstmt.executeUpdate();
}

6.1.3 IN 參數中數據類型的一致性
setXXX 方法中的 XXX 是 Java 類型。它是一種隱含的 JDBC 類型(一般 SQL 類型),因為驅動程序將把 Java 類型映射為相應的 JDBC 類型(遵循該 JDBC Guide中§8.6.2 “映射 Java 和 JDBC 類型”表中所指定的映射),并將該 JDBC 類型發送給數據庫。例如,以下代碼段將 PreparedStatement 對象 pstmt 的第二個參數設置為 44,Java 類型為 short: 

pstmt.setShort(2, 44);

驅動程序將 44 作為 JDBC SMALLINT 發送給數據庫,它是 Java short 類型的標準映射。

程序員的責任是確保將每個 IN 參數的 Java 類型映射為與數據庫所需的 JDBC 數據類型兼容的 JDBC 類型。不妨考慮數據庫需要 JDBC SMALLINT 的情況。如果使用方法 setByte ,則驅動程序將 JDBC TINYINT 發送給數據庫。這是可行的,因為許多數據庫可從一種相關的類型轉換為另一種類型,并且通常 TINYINT 可用于 SMALLINT 適用的任何地方。然而,對于要適用于盡可能多的數據庫的應用程序,最好使用與數據庫所需的確切的 JDBC 類型相應的 Java 類型。如果所需的 JDBC 類型是 SMALLINT,則使用 setShort 代替 setByte 將使應用程序的可移植性更好。


6.1.4 使用 setObject
程序員可使用 setObject 方法顯式地將輸入參數轉換為特定的 JDBC 類型。該方法可以接受第三個參數,用來指定目標 JDBC 類型。將 Java Object 發送給數據庫之前,驅動程序將把它轉換為指定的 JDBC 類型。

如果沒有指定 JDBC 類型,驅動程序就會將 Java Object 映射到其缺省的 JDBC 類型(參見第 8.6.4 節中的表格),然后將它發送到數據庫。這與常規的 setXXX 方法類似;在這兩種情況下,驅動程序在將值發送到數據庫之前,會將該值的 Java 類型映射為適當的 JDBC 類型。二者的差別在于 setXXX 方法使用從 Java 類型到 JDBC 類型的標準映射(參見第 8.6.2 節中的表格),而 setObject 方法使用從 Java Object 類型到 JDBC 類型的映射(參見第 8.6.4 節中的表格)。

方法 setObject 允許接受所有 Java 對象的能力使應用程序更為通用,并可在運行時接受參數的輸入。這種情況下,應用程序在編譯時并不清楚輸入類型。通過使用 setObject,應用程序可接受所有 Java 對象類型作為輸入,并將其轉換為數據庫所需的 JDBC 類型。第 8.6.5 節中的表格顯示了 setObject 可執行的所有可能轉換。


6.1.5 將 JDBC NULL 作為 IN 參數發送
setNull 方法允許程序員將 JDBC NULL 值作為 IN 參數發送給數據庫。但要注意,仍然必須指定參數的 JDBC 類型。

當把 Java null 值傳遞給 setXXX 方法時(如果它接受 Java 對象作為參數),也將同樣把 JDBC NULL 發送到數據庫。但僅當指定 JDBC 類型時,方法 setObject 才能接受 null 值。


6.1.6 發送大的 IN 參數
setBytes 和 setString 方法能夠發送無限量的數據。但是,有時程序員更喜歡用較小的塊傳遞大型的數據。這可通過將 IN 參數設置為 Java 輸入流來完成。當語句執行時,JDBC 驅動程序將重復調用該輸入流,讀取其內容并將它們當作實際參數數據傳輸。

JDBC 提供了三種將 IN 參數設置為輸入流的方法:setBinaryStream 用于含有未說明字節的流, setAsciiStream 用于含有 ASCII 字符的流,而 setUnicodeStream 用于含有 Unicode 字符的流。因為必須指定流的總長度,所以這些方法所采用的參數比其它的 setXXX 方法要多一個。這很有必要,因為一些數據庫在發送數據之前需要知道其總的傳送大小。

以下代碼例示了使用流作為 IN 參數來發送文件內容: 

java.io.File file = new java.io.File("/tmp/data");
int fileLength = file.length();
java.io.InputStream fin = new java.io.FileInputStream(file);
java.sql.PreparedStatement pstmt = con.prepareStatement(
"UPDATE Table5 SET stuff = ? WHERE index = 4");
pstmt.setBinaryStream (1, fin, fileLength);
pstmt.executeUpdate();

當語句執行時,將反復調用輸入流 fin 以傳遞其數據。

------------------------------------------------------------------

JDBC系列教程(六)---可調用語句
7.1 概述
CallableStatement 對象為所有的 DBMS 提供了一種以標準形式調用已儲存過程的方法。已儲存過程儲存在數據庫中。對已儲存過程的調用是 CallableStatement 對象所含的內容。這種調用是用一種換碼語法來寫的,有兩種形式:一種形式帶結果參數,另一種形式不帶結果參數(有關換碼語法的信息,參見第 4 節“語句”)。結果參數是一種輸出 (OUT) 參數,是已儲存過程的返回值。兩種形式都可帶有數量可變的輸入(IN 參數)、輸出(OUT 參數)或輸入和輸出(INOUT 參數)的參數。問號將用作參數的占位符。

在 JDBC 中調用已儲存過程的語法如下所示。注意,方括號表示其間的內容是可選項;方括號本身并不是語法的組成部份。

{call 過程名[(?, ?, ...)]}

返回結果參數的過程的語法為: 

{? = call 過程名[(?, ?, ...)]}

不帶參數的已儲存過程的語法類似: 

{call 過程名}

通常,創建 CallableStatement 對象的人應當知道所用的 DBMS 是支持已儲存過程的,并且知道這些過程都是些什么。然而,如果需要檢查,多種 DatabaseMetaData 方法都可以提供這樣的信息。例如,如果 DBMS 支持已儲存過程的調用,則 supportsStoredProcedures 方法將返回 true,而 getProcedures 方法將返回對已儲存過程的描述。

CallableStatement 繼承 Statement 的方法(它們用于處理一般的 SQL 語句),還繼承了 PreparedStatement 的方法(它們用于處理 IN 參數)。CallableStatement 中定義的所有方法都用于處理 OUT 參數或 INOUT 參數的輸出部分:注冊 OUT 參數的 JDBC 類型(一般 SQL 類型)、從這些參數中檢索結果,或者檢查所返回的值是否為 JDBC NULL。


7.1.1 創建 CallableStatement 對象
CallableStatement 對象是用 Connection 方法 prepareCall 創建的。下例創建 CallableStatement 的實例,其中含有對已儲存過程 getTestData 調用。該過程有兩個變量,但不含結果參數: 

CallableStatement cstmt = con.prepareCall(
"{call getTestData(?, ?)}");

其中 ? 占位符為 IN、 OUT 還是 INOUT 參數,取決于已儲存過程 getTestData。


7.1.2 IN 和 OUT 參數
將 IN 參數傳給 CallableStatement 對象是通過 setXXX 方法完成的。該方法繼承自 PreparedStatement。所傳入參數的類型決定了所用的 setXXX 方法(例如,用 setFloat 來傳入 float 值等)。

如果已儲存過程返回 OUT 參數,則在執行 CallableStatement 對象以前必須先注冊每個 OUT 參數的 JDBC 類型(這是必需的,因為某些 DBMS 要求 JDBC 類型)。注冊 JDBC 類型是用 registerOutParameter 方法來完成的。語句執行完后,CallableStatement 的 getXXX 方法將取回參數值。正確的 getXXX 方法是為各參數所注冊的 JDBC 類型所對應的 Java 類型(從 JDBC 類型到 Java 類型的標準映射見 8.6.1 節中的表)。換言之, registerOutParameter 使用的是 JDBC 類型(因此它與數據庫返回的 JDBC 類型匹配),而 getXXX 將之轉換為 Java 類型。

作為示例,下述代碼先注冊 OUT 參數,執行由 cstmt 所調用的已儲存過程,然后檢索在 OUT 參數中返回的值。方法 getByte 從第一個 OUT 參數中取出一個 Java 字節,而 getBigDecimal 從第二個 OUT 參數中取出一個 BigDecimal 對象(小數點后面帶三位數): 

CallableStatement cstmt = con.prepareCall(
"{call getTestData(?, ?)}");
cstmt.registerOutParameter(1, java.sql.Types.TINYINT);
cstmt.registerOutParameter(2, java.sql.Types.DECIMAL, 3);
cstmt.executeQuery();
byte x = cstmt.getByte(1);
java.math.BigDecimal n = cstmt.getBigDecimal(2, 3);

CallableStatement 與 ResultSet 不同,它不提供用增量方式檢索大 OUT 值的特殊機制。


7.1.3 INOUT 參數
既支持輸入又接受輸出的參數(INOUT 參數)除了調用 registerOutParameter 方法外,還要求調用適當的 setXXX 方法(該方法是從 PreparedStatement 繼承來的)。setXXX 方法將參數值設置為輸入參數,而 registerOutParameter 方法將它的 JDBC 類型注冊為輸出參數。setXXX 方法提供一個 Java 值,而驅動程序先把這個值轉換為 JDBC 值,然后將它送到數據庫中。

這種 IN 值的 JDBC 類型和提供給 registerOutParameter 方法的 JDBC 類型應該相同。然后,要檢索輸出值,就要用對應的 getXXX 方法。例如,Java 類型為 byte 的參數應該使用方法 setByte 來賦輸入值。應該給 registerOutParameter 提供類型為 TINYINT 的 JDBC 類型,同時應使用 getByte 來檢索輸出值 (第 8 節“JDBC 和 Java 類型之間的映射”將給出詳細信息和類型映射表)。

下例假設有一個已儲存過程 reviseTotal,其唯一參數是 INOUT 參數。方法 setByte 把此參數設為 25,驅動程序將把它作為 JDBC TINYINT 類型送到數據庫中。接著,registerOutParameter 將該參數注冊為 JDBC TINYINT。執行完該已儲存過程后,將返回一個新的 JDBC TINYINT 值。方法 getByte 將把這個新值作為 Java byte 類型檢索。

CallableStatement cstmt = con.prepareCall(
"{call reviseTotal(?)}");
cstmt.setByte(1, 25);
cstmt.registerOutParameter(1, java.sql.Types.TINYINT);
cstmt.executeUpdate();
byte x = cstmt.getByte(1);

7.1.4 先檢索結果,再檢索 OUT 參數
由于某些 DBMS 的限制,為了實現最大的可移植性,建議先檢索由執行 CallableStatement 對象所產生的結果,然后再用 CallableStatement.getXXX 方法來檢索 OUT 參數。

如果 CallableStatement 對象返回多個 ResultSet 對象(通過調用 execute 方法),在檢索 OUT 參數前應先檢索所有的結果。這種情況下,為確保對所有的結果都進行了訪問,必須對 Statement 方法 getResultSet、getUpdateCount 和 getMoreResults 進行調用,直到不再有結果為止。

檢索完所有的結果后,就可用 CallableStatement.getXXX 方法來檢索 OUT 參數中的值。


7.1.5 檢索作為 OUT 參數的 NULL 值
返回到 OUT 參數中的值可能會是 JDBC NULL。當出現這種情形時,將對 JDBC NULL 值進行轉換以使 getXXX 方法所返回的值為 null、0 或 false,這取決于 getXXX 方法類型。對于 ResultSet 對象,要知道 0 或 false 是否源于 JDBC NULL 的唯一方法,是用方法 wasNull 進行檢測。如果 getXXX 方法讀取的最后一個值是 JDBC NULL,則該方法返回 true,否則返回 flase。第 5 節“ResultSet”將給出詳細信息。
文章出處:飛諾網(
www.firnow.com):http://dev.firnow.com/course/3_program/java/javaxl/200726/10227.html

總結

以上是生活随笔為你收集整理的JDBC系列教程的全部內容,希望文章能夠幫你解決所遇到的問題。

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

国内少妇偷人精品视频免费 | 99久久婷婷国产综合精品青草免费 | 内射爽无广熟女亚洲 | 欧美精品无码一区二区三区 | 色狠狠av一区二区三区 | 成人亚洲精品久久久久 | 青春草在线视频免费观看 | 美女张开腿让人桶 | 亚洲色欲色欲天天天www | 欧美第一黄网免费网站 | 成熟妇人a片免费看网站 | 国产熟妇另类久久久久 | 人妻互换免费中文字幕 | 亚洲精品国偷拍自产在线观看蜜桃 | 丰满人妻一区二区三区免费视频 | 3d动漫精品啪啪一区二区中 | 欧美三级a做爰在线观看 | aⅴ亚洲 日韩 色 图网站 播放 | 樱花草在线播放免费中文 | v一区无码内射国产 | 亚洲aⅴ无码成人网站国产app | 国产热a欧美热a在线视频 | 麻豆av传媒蜜桃天美传媒 | 久久精品中文字幕大胸 | 好男人社区资源 | www国产亚洲精品久久久日本 | 中文字幕人妻无码一区二区三区 | 欧美黑人巨大xxxxx | 国产乱人伦app精品久久 国产在线无码精品电影网 国产国产精品人在线视 | 亚洲精品一区三区三区在线观看 | 亚洲国产成人a精品不卡在线 | 色五月丁香五月综合五月 | 精品国产麻豆免费人成网站 | 亚洲娇小与黑人巨大交 | 一本久久a久久精品亚洲 | 国产成人精品一区二区在线小狼 | 久久精品国产日本波多野结衣 | 成人试看120秒体验区 | 精品国产一区av天美传媒 | 无码av中文字幕免费放 | 久在线观看福利视频 | 午夜精品久久久内射近拍高清 | 午夜福利一区二区三区在线观看 | 亚洲一区二区观看播放 | 丰满岳乱妇在线观看中字无码 | 亚洲国产精品成人久久蜜臀 | 国产一区二区三区四区五区加勒比 | 久久人人爽人人人人片 | 一个人免费观看的www视频 | 亚洲日本va中文字幕 | 精品亚洲韩国一区二区三区 | 精品偷自拍另类在线观看 | 精品人妻中文字幕有码在线 | 四虎影视成人永久免费观看视频 | 男人和女人高潮免费网站 | 荫蒂被男人添的好舒服爽免费视频 | 精品国产福利一区二区 | 亚洲成a人片在线观看日本 | 亚洲乱码国产乱码精品精 | 亚洲日韩av片在线观看 | 国产三级精品三级男人的天堂 | 色综合久久88色综合天天 | 国精品人妻无码一区二区三区蜜柚 | 啦啦啦www在线观看免费视频 | 色婷婷av一区二区三区之红樱桃 | 红桃av一区二区三区在线无码av | 国产精品爱久久久久久久 | 美女极度色诱视频国产 | 最近免费中文字幕中文高清百度 | 丁香花在线影院观看在线播放 | 亚洲精品国产精品乱码不卡 | 成人免费视频在线观看 | 麻豆国产97在线 | 欧洲 | 国产热a欧美热a在线视频 | 午夜无码区在线观看 | 国产色xx群视频射精 | 性欧美videos高清精品 | 国产av剧情md精品麻豆 | 亚洲日韩乱码中文无码蜜桃臀网站 | 亚洲国产精品无码久久久久高潮 | 国产午夜亚洲精品不卡下载 | 亚洲人成网站在线播放942 | 300部国产真实乱 | 亚洲国产精品一区二区美利坚 | 在线看片无码永久免费视频 | 久激情内射婷内射蜜桃人妖 | 极品嫩模高潮叫床 | 国产精品亚洲综合色区韩国 | 奇米影视7777久久精品人人爽 | 男女爱爱好爽视频免费看 | 日韩av无码一区二区三区 | 国产熟妇另类久久久久 | 性生交大片免费看l | 久久亚洲日韩精品一区二区三区 | 狠狠色噜噜狠狠狠狠7777米奇 | 亚无码乱人伦一区二区 | 国产无av码在线观看 | 亚洲色无码一区二区三区 | 精品国产一区二区三区四区 | 一个人免费观看的www视频 | 四虎国产精品免费久久 | 中文字幕无线码 | 亚洲日韩精品欧美一区二区 | 成 人 网 站国产免费观看 | 台湾无码一区二区 | 综合网日日天干夜夜久久 | 欧美黑人乱大交 | 国产精品人人妻人人爽 | 人妻天天爽夜夜爽一区二区 | 国产精品久久福利网站 | 亚洲欧美日韩综合久久久 | 5858s亚洲色大成网站www | 精品国产一区二区三区av 性色 | 国产乱码精品一品二品 | 国产成人精品视频ⅴa片软件竹菊 | 国产精品视频免费播放 | 久久人人爽人人爽人人片av高清 | 亚洲一区二区三区四区 | 1000部啪啪未满十八勿入下载 | 日本又色又爽又黄的a片18禁 | 国产成人精品视频ⅴa片软件竹菊 | 色婷婷欧美在线播放内射 | 中文字幕人妻丝袜二区 | 国产精品va在线观看无码 | 无码人妻出轨黑人中文字幕 | 亚洲高清偷拍一区二区三区 | 欧美熟妇另类久久久久久不卡 | 中文字幕乱妇无码av在线 | 亚洲日韩乱码中文无码蜜桃臀网站 | 国产亚洲精品久久久久久大师 | 特大黑人娇小亚洲女 | aⅴ亚洲 日韩 色 图网站 播放 | 亚洲精品国产精品乱码视色 | 成人女人看片免费视频放人 | yw尤物av无码国产在线观看 | 欧美日韩视频无码一区二区三 | 久久99精品国产.久久久久 | 亚洲精品久久久久久一区二区 | 中文字幕色婷婷在线视频 | 色欲av亚洲一区无码少妇 | 国产后入清纯学生妹 | 国产电影无码午夜在线播放 | 99久久精品日本一区二区免费 | 国产一区二区三区四区五区加勒比 | 国产人妻精品一区二区三区 | 在线观看欧美一区二区三区 | 色情久久久av熟女人妻网站 | 亚洲成色在线综合网站 | 国内综合精品午夜久久资源 | 中文字幕无码日韩专区 | 成人片黄网站色大片免费观看 | 97夜夜澡人人爽人人喊中国片 | 天干天干啦夜天干天2017 | 国产色视频一区二区三区 | 丝袜人妻一区二区三区 | 人人澡人人妻人人爽人人蜜桃 | 无人区乱码一区二区三区 | 欧美国产日韩亚洲中文 | 亚洲中文字幕在线观看 | 丝袜人妻一区二区三区 | 国产色精品久久人妻 | 爆乳一区二区三区无码 | 久久久久国色av免费观看性色 | 俺去俺来也www色官网 | 久久精品人人做人人综合试看 | 激情五月综合色婷婷一区二区 | 日日天干夜夜狠狠爱 | 又黄又爽又色的视频 | 亚洲第一网站男人都懂 | 麻花豆传媒剧国产免费mv在线 | 四十如虎的丰满熟妇啪啪 | 无套内谢老熟女 | 伊人久久大香线蕉午夜 | 少妇性荡欲午夜性开放视频剧场 | 国产精品va在线观看无码 | 国产内射老熟女aaaa | √天堂中文官网8在线 | www国产亚洲精品久久网站 | 红桃av一区二区三区在线无码av | 无码人妻丰满熟妇区五十路百度 | 双乳奶水饱满少妇呻吟 | 亚洲狠狠婷婷综合久久 | 婷婷综合久久中文字幕蜜桃三电影 | 日本一卡二卡不卡视频查询 | 女人色极品影院 | 久久99热只有频精品8 | 99re在线播放 | 亚洲毛片av日韩av无码 | 国产乱人伦app精品久久 国产在线无码精品电影网 国产国产精品人在线视 | 玩弄少妇高潮ⅹxxxyw | 麻豆果冻传媒2021精品传媒一区下载 | 久久精品一区二区三区四区 | 色窝窝无码一区二区三区色欲 | 亚洲午夜久久久影院 | 麻豆精品国产精华精华液好用吗 | 国产成人精品视频ⅴa片软件竹菊 | 国产熟女一区二区三区四区五区 | 国产偷自视频区视频 | 日日碰狠狠丁香久燥 | 久久成人a毛片免费观看网站 | 精品欧美一区二区三区久久久 | 亚洲乱亚洲乱妇50p | 亚洲乱亚洲乱妇50p | 东京热一精品无码av | 精品久久久久久人妻无码中文字幕 | 97资源共享在线视频 | 午夜福利一区二区三区在线观看 | 日本免费一区二区三区最新 | 日韩精品无码免费一区二区三区 | 国产精品多人p群无码 | 天海翼激烈高潮到腰振不止 | 日日躁夜夜躁狠狠躁 | 欧美大屁股xxxxhd黑色 | 久久久久久九九精品久 | 蜜桃av蜜臀av色欲av麻 999久久久国产精品消防器材 | 乱人伦中文视频在线观看 | 国产精品无码mv在线观看 | 日日摸日日碰夜夜爽av | 欧美人与物videos另类 | 亚洲 另类 在线 欧美 制服 | 亚洲va欧美va天堂v国产综合 | 成人免费视频视频在线观看 免费 | 99riav国产精品视频 | 亚洲区小说区激情区图片区 | 帮老师解开蕾丝奶罩吸乳网站 | 色五月五月丁香亚洲综合网 | 久久精品国产精品国产精品污 | 2019午夜福利不卡片在线 | 日本www一道久久久免费榴莲 | 中文字幕乱码中文乱码51精品 | 任你躁在线精品免费 | 熟女少妇在线视频播放 | 少妇人妻av毛片在线看 | 欧美怡红院免费全部视频 | 久久综合给久久狠狠97色 | 国产明星裸体无码xxxx视频 | 熟妇人妻激情偷爽文 | 伊人久久大香线焦av综合影院 | 日韩精品一区二区av在线 | 国产人妻人伦精品1国产丝袜 | 久久国产精品萌白酱免费 | 亚洲欧洲日本无在线码 | 人妻少妇精品无码专区动漫 | 久久久久久久久888 | 免费人成网站视频在线观看 | 无套内谢老熟女 | 人妻少妇被猛烈进入中文字幕 | 99riav国产精品视频 | 精品成在人线av无码免费看 | 久久久中文久久久无码 | 最近的中文字幕在线看视频 | 六十路熟妇乱子伦 | 大乳丰满人妻中文字幕日本 | 两性色午夜视频免费播放 | 久久99精品久久久久久 | 高潮喷水的毛片 | 久久亚洲精品中文字幕无男同 | 午夜性刺激在线视频免费 | 麻豆成人精品国产免费 | 国产精华av午夜在线观看 | 国产精品永久免费视频 | 国产精品久久久久久亚洲影视内衣 | 久久午夜无码鲁丝片午夜精品 | 国产精品沙发午睡系列 | 国产成人精品三级麻豆 | 日韩亚洲欧美精品综合 | 鲁大师影院在线观看 | 久久天天躁夜夜躁狠狠 | 乱人伦人妻中文字幕无码久久网 | 无套内谢的新婚少妇国语播放 | 久久久久国色av免费观看性色 | 免费乱码人妻系列无码专区 | 久久zyz资源站无码中文动漫 | 国产 精品 自在自线 | 亚洲精品鲁一鲁一区二区三区 | 日本一卡2卡3卡4卡无卡免费网站 国产一区二区三区影院 | 国产办公室秘书无码精品99 | 国产精品丝袜黑色高跟鞋 | 色一情一乱一伦一区二区三欧美 | 午夜理论片yy44880影院 | 婷婷五月综合激情中文字幕 | 免费观看黄网站 | 国产特级毛片aaaaaa高潮流水 | 乌克兰少妇xxxx做受 | 伊人久久婷婷五月综合97色 | 亚洲精品一区三区三区在线观看 | 国产黑色丝袜在线播放 | 国产在线aaa片一区二区99 | 天堂亚洲免费视频 | 永久免费观看美女裸体的网站 | 免费无码av一区二区 | 国产精品亚洲а∨无码播放麻豆 | 亚洲国产av美女网站 | 2020久久香蕉国产线看观看 | 久久综合给久久狠狠97色 | 亚洲aⅴ无码成人网站国产app | 色婷婷av一区二区三区之红樱桃 | 国内少妇偷人精品视频 | 中文字幕精品av一区二区五区 | 九九在线中文字幕无码 | 欧美一区二区三区视频在线观看 | 性色欲网站人妻丰满中文久久不卡 | 久久久亚洲欧洲日产国码αv | 中文字幕中文有码在线 | 国产乱人伦偷精品视频 | 亚洲国产精品久久久久久 | 亚洲国产欧美在线成人 | 久久zyz资源站无码中文动漫 | 中文字幕久久久久人妻 | 亚洲精品中文字幕乱码 | 成 人影片 免费观看 | 无码人妻少妇伦在线电影 | 久久99精品国产麻豆蜜芽 | 久久午夜无码鲁丝片 | www国产亚洲精品久久久日本 | 久久精品国产大片免费观看 | 在线观看欧美一区二区三区 | 在线播放免费人成毛片乱码 | 在线欧美精品一区二区三区 | 欧美激情一区二区三区成人 | 人人爽人人爽人人片av亚洲 | 大乳丰满人妻中文字幕日本 | 亚洲中文字幕av在天堂 | 日日天干夜夜狠狠爱 | 国产情侣作爱视频免费观看 | 最新国产乱人伦偷精品免费网站 | 在线视频网站www色 | 中文字幕色婷婷在线视频 | 精品久久综合1区2区3区激情 | 精品人人妻人人澡人人爽人人 | 黑人大群体交免费视频 | 精品国产精品久久一区免费式 | 国产午夜福利100集发布 | 窝窝午夜理论片影院 | 中文字幕无码日韩欧毛 | 丝袜 中出 制服 人妻 美腿 | 国产色视频一区二区三区 | 人妻少妇精品久久 | 一区二区三区乱码在线 | 欧洲 | 亚洲国产欧美日韩精品一区二区三区 | 久久午夜无码鲁丝片 | 久久精品人人做人人综合 | 国产精品第一区揄拍无码 | 国产精品久久久午夜夜伦鲁鲁 | 国产成人无码av片在线观看不卡 | 色诱久久久久综合网ywww | 国产偷抇久久精品a片69 | 日日摸天天摸爽爽狠狠97 | 日日噜噜噜噜夜夜爽亚洲精品 | 欧美放荡的少妇 | 成人综合网亚洲伊人 | 亚洲熟妇色xxxxx欧美老妇y | 精品国产av色一区二区深夜久久 | 亚洲精品中文字幕久久久久 | √天堂资源地址中文在线 | 国产亚洲欧美日韩亚洲中文色 | 伊人色综合久久天天小片 | 亚洲国产欧美国产综合一区 | 婷婷综合久久中文字幕蜜桃三电影 | 国产农村乱对白刺激视频 | 帮老师解开蕾丝奶罩吸乳网站 | 久久99精品久久久久久 | 国内精品久久毛片一区二区 | 久久人人爽人人爽人人片ⅴ | 5858s亚洲色大成网站www | 2019nv天堂香蕉在线观看 | 精品偷拍一区二区三区在线看 | 高中生自慰www网站 | 国精产品一区二区三区 | 精品久久久无码中文字幕 | 色狠狠av一区二区三区 | 88国产精品欧美一区二区三区 | 中文字幕乱码亚洲无线三区 | 少女韩国电视剧在线观看完整 | 狠狠色噜噜狠狠狠7777奇米 | 亚洲aⅴ无码成人网站国产app | 一本精品99久久精品77 | 熟女俱乐部五十路六十路av | 性色欲网站人妻丰满中文久久不卡 | 精品国产aⅴ无码一区二区 | 奇米影视7777久久精品人人爽 | 亚洲日本在线电影 | 国产尤物精品视频 | 激情人妻另类人妻伦 | 荫蒂被男人添的好舒服爽免费视频 | 久久99精品国产麻豆 | 日韩少妇内射免费播放 | 樱花草在线播放免费中文 | 国产精品成人av在线观看 | 特大黑人娇小亚洲女 | 麻豆蜜桃av蜜臀av色欲av | 国产亚洲日韩欧美另类第八页 | 四虎国产精品一区二区 | 亚洲第一无码av无码专区 | 国产一区二区不卡老阿姨 | 亚洲国精产品一二二线 | 性色av无码免费一区二区三区 | 中文毛片无遮挡高清免费 | 欧美成人高清在线播放 | 午夜肉伦伦影院 | 久久精品中文字幕大胸 | 欧美黑人性暴力猛交喷水 | 国产午夜无码精品免费看 | 麻豆精产国品 | 欧美日本免费一区二区三区 | 在线天堂新版最新版在线8 | 亚洲一区二区三区四区 | 5858s亚洲色大成网站www | 日韩av无码一区二区三区不卡 | www成人国产高清内射 | 天海翼激烈高潮到腰振不止 | 国产亚洲精品久久久久久久 | 亚洲精品无码人妻无码 | 国产精品99爱免费视频 | 中文精品无码中文字幕无码专区 | 欧美成人高清在线播放 | 久久97精品久久久久久久不卡 | 无套内谢的新婚少妇国语播放 | 青青草原综合久久大伊人精品 | 国产精品久久久久9999小说 | 夜夜影院未满十八勿进 | 亚洲精品中文字幕久久久久 | a在线观看免费网站大全 | 一二三四社区在线中文视频 | 色婷婷久久一区二区三区麻豆 | 思思久久99热只有频精品66 | 无码纯肉视频在线观看 | 亚洲日韩乱码中文无码蜜桃臀网站 | 美女张开腿让人桶 | 亚洲精品成a人在线观看 | 黑人大群体交免费视频 | 99久久精品日本一区二区免费 | 成人欧美一区二区三区黑人 | 野外少妇愉情中文字幕 | 国语精品一区二区三区 | 人人爽人人澡人人高潮 | 国产明星裸体无码xxxx视频 | 国产精品自产拍在线观看 | 成人三级无码视频在线观看 | 99视频精品全部免费免费观看 | 成人亚洲精品久久久久软件 | 波多野结衣 黑人 | 国产成人无码av一区二区 | 大胆欧美熟妇xx | 啦啦啦www在线观看免费视频 | 久久久精品人妻久久影视 | 色五月五月丁香亚洲综合网 | 欧美人与禽zoz0性伦交 | 伊在人天堂亚洲香蕉精品区 | 亚洲国产精品无码久久久久高潮 | 无码av免费一区二区三区试看 | 亚洲欧美日韩成人高清在线一区 | 久久精品人妻少妇一区二区三区 | 亚洲第一网站男人都懂 | 国语自产偷拍精品视频偷 | 乱码av麻豆丝袜熟女系列 | 中文无码成人免费视频在线观看 | 国产精品亚洲一区二区三区喷水 | 巨爆乳无码视频在线观看 | 丰腴饱满的极品熟妇 | 狠狠综合久久久久综合网 | 久久久无码中文字幕久... | 亲嘴扒胸摸屁股激烈网站 | 国产 精品 自在自线 | 国产精品久久久久无码av色戒 | 国产麻豆精品一区二区三区v视界 | 亚洲码国产精品高潮在线 | 欧美精品一区二区精品久久 | 国产av一区二区精品久久凹凸 | 在线天堂新版最新版在线8 | 一本久道久久综合婷婷五月 | a在线观看免费网站大全 | 2020久久超碰国产精品最新 | 欧美性黑人极品hd | 99精品视频在线观看免费 | 国产在线aaa片一区二区99 | 夫妻免费无码v看片 | 亚洲精品国偷拍自产在线麻豆 | 捆绑白丝粉色jk震动捧喷白浆 | 亚洲自偷自拍另类第1页 | 国产真人无遮挡作爱免费视频 | 国产精品久久久久无码av色戒 | 国产成人精品三级麻豆 | 国产三级久久久精品麻豆三级 | 最近免费中文字幕中文高清百度 | 精品久久综合1区2区3区激情 | 蜜臀av无码人妻精品 | av人摸人人人澡人人超碰下载 | 精品欧美一区二区三区久久久 | 亚洲精品国偷拍自产在线麻豆 | 性开放的女人aaa片 | 久久99国产综合精品 | 成人免费无码大片a毛片 | 300部国产真实乱 | 亚洲色大成网站www国产 | 十八禁视频网站在线观看 | 亚洲理论电影在线观看 | 国产成人无码a区在线观看视频app | 精品无码国产自产拍在线观看蜜 | 亚洲无人区一区二区三区 | 亚洲狠狠婷婷综合久久 | 亚洲国产精品一区二区第一页 | 极品尤物被啪到呻吟喷水 | 亚洲国产日韩a在线播放 | 日本丰满护士爆乳xxxx | 国产av无码专区亚洲awww | 精品夜夜澡人妻无码av蜜桃 | 精品水蜜桃久久久久久久 | 久久 国产 尿 小便 嘘嘘 | 97夜夜澡人人爽人人喊中国片 | 99er热精品视频 | 国产明星裸体无码xxxx视频 | 精品无码av一区二区三区 | 国产成人精品视频ⅴa片软件竹菊 | 亚洲一区二区三区香蕉 | 国产香蕉尹人视频在线 | 国产精品亚洲五月天高清 | 青青久在线视频免费观看 | 中文无码伦av中文字幕 | 青春草在线视频免费观看 | 亚洲色欲色欲欲www在线 | 天堂一区人妻无码 | 小sao货水好多真紧h无码视频 | 亚洲欧美综合区丁香五月小说 | 国产精品毛片一区二区 | 日本一区二区三区免费高清 | 大肉大捧一进一出视频出来呀 | 曰本女人与公拘交酡免费视频 | 国产99久久精品一区二区 | 国产亚洲日韩欧美另类第八页 | 亚洲日本va中文字幕 | 男女性色大片免费网站 | 国内精品九九久久久精品 | 亚洲国产精品成人久久蜜臀 | 色婷婷香蕉在线一区二区 | 精品一区二区三区波多野结衣 | 一二三四社区在线中文视频 | 无码人妻av免费一区二区三区 | 国产女主播喷水视频在线观看 | 国产麻豆精品一区二区三区v视界 | 水蜜桃亚洲一二三四在线 | 日韩人妻少妇一区二区三区 | 亚洲va中文字幕无码久久不卡 | 国产精品资源一区二区 | 免费网站看v片在线18禁无码 | 一本加勒比波多野结衣 | 天下第一社区视频www日本 | 亚洲欧美日韩国产精品一区二区 | 人妻无码αv中文字幕久久琪琪布 | 色婷婷久久一区二区三区麻豆 | 成人无码视频在线观看网站 | 国产农村妇女aaaaa视频 撕开奶罩揉吮奶头视频 | 国产真人无遮挡作爱免费视频 | 香港三级日本三级妇三级 | 人人妻人人澡人人爽人人精品浪潮 | 熟妇人妻无码xxx视频 | 毛片内射-百度 | 久久久国产精品无码免费专区 | 日韩精品成人一区二区三区 | 成人无码视频在线观看网站 | 亚洲小说图区综合在线 | 欧美国产日产一区二区 | 久久精品中文字幕大胸 | 一区二区传媒有限公司 | 狠狠cao日日穞夜夜穞av | 亚洲熟妇色xxxxx欧美老妇 | 久久国内精品自在自线 | 小sao货水好多真紧h无码视频 | 日韩少妇内射免费播放 | 国产高清av在线播放 | 欧美激情综合亚洲一二区 | 暴力强奷在线播放无码 | 高清无码午夜福利视频 | 无码人妻精品一区二区三区不卡 | 在教室伦流澡到高潮hnp视频 | 亚洲中文字幕va福利 | 久久久久久久女国产乱让韩 | 青草青草久热国产精品 | 无码国内精品人妻少妇 | 亚洲自偷精品视频自拍 | 青青青手机频在线观看 | 一本精品99久久精品77 | 自拍偷自拍亚洲精品被多人伦好爽 | 久久这里只有精品视频9 | 久久zyz资源站无码中文动漫 | 狠狠综合久久久久综合网 | 又色又爽又黄的美女裸体网站 | 精品偷拍一区二区三区在线看 | 少妇愉情理伦片bd | 狠狠噜狠狠狠狠丁香五月 | 精品乱码久久久久久久 | 色综合久久网 | 午夜肉伦伦影院 | 日韩欧美成人免费观看 | 无码纯肉视频在线观看 | 无遮挡国产高潮视频免费观看 | 亚洲日韩av一区二区三区中文 | 小泽玛莉亚一区二区视频在线 | 超碰97人人做人人爱少妇 | 黑人巨大精品欧美黑寡妇 | 亚洲の无码国产の无码影院 | 国精产品一品二品国精品69xx | 性生交大片免费看l | 精品厕所偷拍各类美女tp嘘嘘 | 激情亚洲一区国产精品 | 丁香啪啪综合成人亚洲 | 国产精华av午夜在线观看 | 国产一精品一av一免费 | 国产sm调教视频在线观看 | 国产熟妇另类久久久久 | 久久午夜无码鲁丝片秋霞 | 18黄暴禁片在线观看 | 色婷婷久久一区二区三区麻豆 | 人妻aⅴ无码一区二区三区 | 两性色午夜免费视频 | 牛和人交xxxx欧美 | 丰腴饱满的极品熟妇 | 亚洲日韩中文字幕在线播放 | 欧美日韩综合一区二区三区 | 中文字幕无码乱人伦 | 内射后入在线观看一区 | 麻豆成人精品国产免费 | 欧美日本免费一区二区三区 | 麻豆国产人妻欲求不满谁演的 | 日韩欧美中文字幕公布 | 无码免费一区二区三区 | 色婷婷综合中文久久一本 | 国产精品高潮呻吟av久久4虎 | 一区二区三区乱码在线 | 欧洲 | 欧美怡红院免费全部视频 | 无码av最新清无码专区吞精 | 精品人妻人人做人人爽夜夜爽 | 无码国产色欲xxxxx视频 | 国产综合在线观看 | 欧美日韩在线亚洲综合国产人 | 国产真实乱对白精彩久久 | 久久精品人妻少妇一区二区三区 | 荫蒂被男人添的好舒服爽免费视频 | 18精品久久久无码午夜福利 | 宝宝好涨水快流出来免费视频 | 鲁鲁鲁爽爽爽在线视频观看 | 国产婷婷色一区二区三区在线 | 全球成人中文在线 | 日日鲁鲁鲁夜夜爽爽狠狠 | 美女黄网站人色视频免费国产 | 亚洲欧洲日本无在线码 | 日韩在线不卡免费视频一区 | 精品日本一区二区三区在线观看 | 亚洲精品成人av在线 | 内射后入在线观看一区 | 天堂久久天堂av色综合 | 国产亚洲人成在线播放 | 亚洲国产精品美女久久久久 | 日韩在线不卡免费视频一区 | 18精品久久久无码午夜福利 | 国产无遮挡又黄又爽又色 | 国产成人精品一区二区在线小狼 | 日韩人妻无码中文字幕视频 | 欧美黑人性暴力猛交喷水 | 玩弄中年熟妇正在播放 | 欧美人与禽猛交狂配 | 亚洲精品中文字幕乱码 | 少妇人妻偷人精品无码视频 | 欧美性猛交xxxx富婆 | 亚洲色无码一区二区三区 | 亚欧洲精品在线视频免费观看 | 国产精品办公室沙发 | 久久久久久亚洲精品a片成人 | 性做久久久久久久免费看 | 少妇高潮喷潮久久久影院 | 色婷婷久久一区二区三区麻豆 | 日本乱偷人妻中文字幕 | 麻豆国产人妻欲求不满谁演的 | 精品一二三区久久aaa片 | 久久亚洲中文字幕精品一区 | 亚洲一区二区三区无码久久 | 性欧美牲交在线视频 | 中文字幕无线码 | 天海翼激烈高潮到腰振不止 | 午夜福利一区二区三区在线观看 | 欧美35页视频在线观看 | 日韩人妻无码中文字幕视频 | 亚洲小说图区综合在线 | 日本一卡2卡3卡四卡精品网站 | 中文精品久久久久人妻不卡 | 无码国内精品人妻少妇 | 一区二区三区高清视频一 | 国产精品视频免费播放 | 中文字幕精品av一区二区五区 | 欧美大屁股xxxxhd黑色 | 精品少妇爆乳无码av无码专区 | 欧美丰满熟妇xxxx | 日本爽爽爽爽爽爽在线观看免 | 精品无码成人片一区二区98 | 国产乱人伦偷精品视频 | 蜜桃视频插满18在线观看 | 亚洲国产一区二区三区在线观看 | 中文字幕av日韩精品一区二区 | 亚洲欧美国产精品专区久久 | 亚洲a无码综合a国产av中文 | 一本无码人妻在中文字幕免费 | 国产亚洲欧美日韩亚洲中文色 | 精品久久久久久亚洲精品 | 红桃av一区二区三区在线无码av | 人妻天天爽夜夜爽一区二区 | 国产真实乱对白精彩久久 | 日韩精品成人一区二区三区 | 无码人妻丰满熟妇区五十路百度 | 2020久久香蕉国产线看观看 | 国产亚洲精品久久久久久久 | 国产香蕉尹人视频在线 | 人人妻人人澡人人爽欧美一区 | 日本精品人妻无码77777 天堂一区人妻无码 | 国产网红无码精品视频 | 久久精品国产一区二区三区肥胖 | 四虎4hu永久免费 | 欧美老人巨大xxxx做受 | 伊在人天堂亚洲香蕉精品区 | 性色av无码免费一区二区三区 | 牲欲强的熟妇农村老妇女 | 国产农村妇女高潮大叫 | 亚洲自偷自偷在线制服 | 欧美熟妇另类久久久久久不卡 | 图片区 小说区 区 亚洲五月 | 日本护士毛茸茸高潮 | 国产精品无套呻吟在线 | 国产精品人人妻人人爽 | 久久亚洲精品中文字幕无男同 | 国产成人精品无码播放 | 宝宝好涨水快流出来免费视频 | 三上悠亚人妻中文字幕在线 | 清纯唯美经典一区二区 | 青青久在线视频免费观看 | 又湿又紧又大又爽a视频国产 | 欧美刺激性大交 | ass日本丰满熟妇pics | 久久亚洲精品成人无码 | 国内精品久久毛片一区二区 | 亚洲欧美日韩综合久久久 | 成人aaa片一区国产精品 | 亚洲色大成网站www国产 | 国产午夜精品一区二区三区嫩草 | 欧美国产日产一区二区 | 乱码午夜-极国产极内射 | 亚洲精品成人av在线 | 国产又爽又猛又粗的视频a片 | 成 人 网 站国产免费观看 | 亚洲午夜无码久久 | 99久久亚洲精品无码毛片 | 国产黑色丝袜在线播放 | 一本久道高清无码视频 | 欧美三级不卡在线观看 | 久久婷婷五月综合色国产香蕉 | 日日麻批免费40分钟无码 | 亚洲成a人片在线观看日本 | 色综合视频一区二区三区 | 久久国产精品_国产精品 | 欧美野外疯狂做受xxxx高潮 | 国产免费久久久久久无码 | 丰满少妇人妻久久久久久 | 亚洲の无码国产の无码步美 | 自拍偷自拍亚洲精品10p | 亚洲熟妇色xxxxx亚洲 | 又色又爽又黄的美女裸体网站 | 人妻有码中文字幕在线 | 欧美日韩色另类综合 | 一本大道久久东京热无码av | 东京无码熟妇人妻av在线网址 | 伊人久久大香线蕉午夜 | 日本精品人妻无码免费大全 | aⅴ亚洲 日韩 色 图网站 播放 | 黑人巨大精品欧美黑寡妇 | 久久精品人人做人人综合 | 无码国内精品人妻少妇 | 国产成人一区二区三区别 | 无码中文字幕色专区 | 国产在线精品一区二区高清不卡 | 麻豆md0077饥渴少妇 | 午夜男女很黄的视频 | 在教室伦流澡到高潮hnp视频 | 日日摸夜夜摸狠狠摸婷婷 | 老太婆性杂交欧美肥老太 | 久久国语露脸国产精品电影 | 国内精品人妻无码久久久影院蜜桃 | 久久人人爽人人人人片 | 又大又黄又粗又爽的免费视频 | 永久免费观看国产裸体美女 | 久久久久久久久888 | 成人精品天堂一区二区三区 | 欧美日韩在线亚洲综合国产人 | 国产成人无码一二三区视频 | 国产在线无码精品电影网 | 欧美成人午夜精品久久久 | 波多野结衣高清一区二区三区 | 亚洲日本va午夜在线电影 | 国产在线一区二区三区四区五区 | 中文字幕乱码中文乱码51精品 | 亚洲a无码综合a国产av中文 | 午夜精品久久久久久久 | 丰满人妻被黑人猛烈进入 | 亚洲精品成a人在线观看 | 久久久久久国产精品无码下载 | 国产无套内射久久久国产 | 99精品久久毛片a片 | 中文字幕+乱码+中文字幕一区 | 蜜桃av抽搐高潮一区二区 | 日韩成人一区二区三区在线观看 | 色综合视频一区二区三区 | 曰本女人与公拘交酡免费视频 | 一区二区三区高清视频一 | 天天综合网天天综合色 | 熟妇人妻无码xxx视频 | 无码精品国产va在线观看dvd | 成人亚洲精品久久久久软件 | 久久精品国产99久久6动漫 | 日韩av无码一区二区三区 | 国产高清av在线播放 | 午夜精品久久久久久久久 | 国产精品久久久久久久影院 | 无码播放一区二区三区 | 亚洲精品中文字幕乱码 | 成人欧美一区二区三区黑人免费 | 久久亚洲精品成人无码 | 国产精品人人爽人人做我的可爱 | 中文毛片无遮挡高清免费 | 日本熟妇大屁股人妻 | 日本一区二区三区免费高清 | 久久久久久久人妻无码中文字幕爆 | 爱做久久久久久 | 亚拍精品一区二区三区探花 | 牲交欧美兽交欧美 | 欧美丰满老熟妇xxxxx性 | 牲交欧美兽交欧美 | 国产特级毛片aaaaaaa高清 | 99久久精品国产一区二区蜜芽 | 久久人人爽人人爽人人片av高清 | 久久综合狠狠综合久久综合88 | 爱做久久久久久 | 国产精品自产拍在线观看 | 日日鲁鲁鲁夜夜爽爽狠狠 | 一本色道久久综合亚洲精品不卡 | 国产国语老龄妇女a片 | 久久精品丝袜高跟鞋 | 国产舌乚八伦偷品w中 | 久久伊人色av天堂九九小黄鸭 | 亚洲自偷精品视频自拍 | 国产乱子伦视频在线播放 | 亚洲综合无码一区二区三区 | 成人精品一区二区三区中文字幕 | 亚洲精品国偷拍自产在线观看蜜桃 | 久久99久久99精品中文字幕 | 99riav国产精品视频 | 国产极品美女高潮无套在线观看 | 夜夜影院未满十八勿进 | 麻豆国产丝袜白领秘书在线观看 | 欧美亚洲日韩国产人成在线播放 | 欧美午夜特黄aaaaaa片 | 男女猛烈xx00免费视频试看 | 国产偷抇久久精品a片69 | 日本一卡2卡3卡四卡精品网站 | 对白脏话肉麻粗话av | 久久久无码中文字幕久... | 国产成人午夜福利在线播放 | 久久久久久av无码免费看大片 | 少妇高潮一区二区三区99 | 中文字幕人妻无码一区二区三区 | 欧美成人免费全部网站 | 丰满肥臀大屁股熟妇激情视频 | 国产精品美女久久久 | 天天躁夜夜躁狠狠是什么心态 | 国产精品爱久久久久久久 | 亚洲综合无码一区二区三区 | 强伦人妻一区二区三区视频18 | 色窝窝无码一区二区三区色欲 | 夜夜高潮次次欢爽av女 | 亚洲va欧美va天堂v国产综合 | 无码av中文字幕免费放 | 天海翼激烈高潮到腰振不止 | 东京无码熟妇人妻av在线网址 | 久久天天躁夜夜躁狠狠 | 2020久久超碰国产精品最新 | 久久综合九色综合欧美狠狠 | 日产国产精品亚洲系列 | 欧美日韩人成综合在线播放 | 国产精品办公室沙发 | 午夜免费福利小电影 | 男女下面进入的视频免费午夜 | 麻豆国产人妻欲求不满谁演的 | 国产97人人超碰caoprom | 中国大陆精品视频xxxx | 久久午夜夜伦鲁鲁片无码免费 | 黑人玩弄人妻中文在线 | 人妻熟女一区 | 宝宝好涨水快流出来免费视频 | 午夜性刺激在线视频免费 | 日韩精品一区二区av在线 | 波多野结衣一区二区三区av免费 | 日日麻批免费40分钟无码 | 大胆欧美熟妇xx | 亚洲色大成网站www国产 | 国产精品久久福利网站 | 色狠狠av一区二区三区 | 欧美xxxx黑人又粗又长 | 蜜桃无码一区二区三区 | 欧美阿v高清资源不卡在线播放 | 性史性农村dvd毛片 | 免费人成在线视频无码 | 久久久久久久女国产乱让韩 | 夜精品a片一区二区三区无码白浆 | 免费看男女做好爽好硬视频 | 图片区 小说区 区 亚洲五月 | 亚洲精品久久久久久一区二区 | 婷婷丁香五月天综合东京热 | 欧美成人家庭影院 | 亚洲狠狠婷婷综合久久 | 激情亚洲一区国产精品 | 成年美女黄网站色大免费视频 | 国内精品久久毛片一区二区 | 欧美性生交xxxxx久久久 | 亚洲色www成人永久网址 | 日本乱人伦片中文三区 | 奇米影视7777久久精品 | 久久久久亚洲精品中文字幕 | 无码国产乱人伦偷精品视频 | 欧美第一黄网免费网站 | 日日摸夜夜摸狠狠摸婷婷 | 蜜桃视频插满18在线观看 | 国产亚洲精品久久久久久久久动漫 | 图片小说视频一区二区 | 中文字幕人妻无码一夲道 | 好屌草这里只有精品 | 97精品人妻一区二区三区香蕉 | 麻豆精产国品 | 青青草原综合久久大伊人精品 | 大胆欧美熟妇xx | 日韩av无码一区二区三区 | 国内老熟妇对白xxxxhd | 国产精品永久免费视频 | 在线a亚洲视频播放在线观看 | 无码国模国产在线观看 | 亚洲国产欧美日韩精品一区二区三区 | 精品国产一区二区三区av 性色 | 丰满人妻翻云覆雨呻吟视频 | 国产成人精品无码播放 | 一本久道久久综合婷婷五月 | 老头边吃奶边弄进去呻吟 | 无码人妻精品一区二区三区不卡 | 欧美丰满少妇xxxx性 | 国产欧美精品一区二区三区 | 日韩人妻少妇一区二区三区 | 亚洲综合久久一区二区 | 久久国语露脸国产精品电影 | 久久综合网欧美色妞网 | 四虎国产精品免费久久 | 乌克兰少妇性做爰 | 在线欧美精品一区二区三区 | 亚洲乱码日产精品bd | 97资源共享在线视频 | 久久精品人人做人人综合试看 | 一个人看的www免费视频在线观看 | 我要看www免费看插插视频 | 男人的天堂av网站 | 99久久亚洲精品无码毛片 | 色综合久久久无码网中文 | 国产人妻人伦精品1国产丝袜 | 男人扒开女人内裤强吻桶进去 | 女人被爽到呻吟gif动态图视看 | 丰满人妻一区二区三区免费视频 | 扒开双腿疯狂进出爽爽爽视频 | 精品一二三区久久aaa片 | 中文字幕人成乱码熟女app | 亚洲午夜福利在线观看 | 伊人久久大香线蕉av一区二区 | 国产人妻精品午夜福利免费 | 国精产品一品二品国精品69xx | 亚洲欧洲无卡二区视頻 | 青青草原综合久久大伊人精品 | 无码吃奶揉捏奶头高潮视频 | 亚洲乱码日产精品bd | 午夜性刺激在线视频免费 | 欧美激情综合亚洲一二区 | 少妇无套内谢久久久久 | 99er热精品视频 | 红桃av一区二区三区在线无码av | 久久精品国产一区二区三区肥胖 | 亚洲精品中文字幕乱码 | 日本精品高清一区二区 | 97夜夜澡人人爽人人喊中国片 | 老熟女乱子伦 | 国产精品久久久久影院嫩草 | 97精品人妻一区二区三区香蕉 | 久久久久成人片免费观看蜜芽 | 亚洲日韩av一区二区三区四区 | 亚洲大尺度无码无码专区 | 日本xxxx色视频在线观看免费 | 亚洲欧洲无卡二区视頻 | 精品久久久久香蕉网 | 亚洲欧美综合区丁香五月小说 | 俺去俺来也www色官网 | 国产成人无码av片在线观看不卡 | 亚洲自偷自偷在线制服 | 国产精品亚洲一区二区三区喷水 | 国产午夜亚洲精品不卡下载 | 麻豆国产丝袜白领秘书在线观看 | 日日碰狠狠丁香久燥 | 一本色道婷婷久久欧美 | 国产亚洲精品久久久久久大师 | 亚洲国产精品一区二区美利坚 | 狠狠躁日日躁夜夜躁2020 | 色 综合 欧美 亚洲 国产 | 奇米影视7777久久精品 | 亚洲中文字幕无码中字 | 性欧美videos高清精品 | 中文字幕日韩精品一区二区三区 | 最新版天堂资源中文官网 | 久久久久久久人妻无码中文字幕爆 | 性欧美videos高清精品 | 高清国产亚洲精品自在久久 | 久久精品国产大片免费观看 | 午夜熟女插插xx免费视频 | 中文字幕无线码免费人妻 | 免费无码午夜福利片69 | 免费无码一区二区三区蜜桃大 | 亚拍精品一区二区三区探花 | 精品人妻人人做人人爽 | 草草网站影院白丝内射 | 熟女少妇人妻中文字幕 | 激情国产av做激情国产爱 | 免费无码的av片在线观看 | 鲁鲁鲁爽爽爽在线视频观看 | 久久久国产精品无码免费专区 | 中文字幕乱码人妻二区三区 | 网友自拍区视频精品 | 丰满少妇弄高潮了www | 久久精品人妻少妇一区二区三区 | 蜜桃视频插满18在线观看 | 欧美成人午夜精品久久久 | 色欲av亚洲一区无码少妇 | 人妻夜夜爽天天爽三区 | 日韩精品成人一区二区三区 | 亚洲熟女一区二区三区 | 九九久久精品国产免费看小说 | 黑人巨大精品欧美黑寡妇 | 97色伦图片97综合影院 | 国产精品人人爽人人做我的可爱 | 欧美熟妇另类久久久久久多毛 | 三上悠亚人妻中文字幕在线 | 久久久无码中文字幕久... | 亚洲精品美女久久久久久久 | 国产成人一区二区三区在线观看 | 日本又色又爽又黄的a片18禁 | 成人精品一区二区三区中文字幕 | 国产av一区二区精品久久凹凸 | 天天综合网天天综合色 | 亚洲精品国产品国语在线观看 | 国产亚洲视频中文字幕97精品 | 精品国产青草久久久久福利 | 自拍偷自拍亚洲精品被多人伦好爽 | 蜜桃av抽搐高潮一区二区 | 欧美色就是色 | 精品人妻人人做人人爽夜夜爽 | 国产精品爱久久久久久久 | 男人的天堂2018无码 | 久久综合给合久久狠狠狠97色 | 日日碰狠狠丁香久燥 | 色情久久久av熟女人妻网站 | 欧美国产亚洲日韩在线二区 | 国产深夜福利视频在线 | 麻豆md0077饥渴少妇 | 国产色xx群视频射精 | 无码国产乱人伦偷精品视频 | 国产suv精品一区二区五 | 动漫av一区二区在线观看 | 狠狠色噜噜狠狠狠7777奇米 | a国产一区二区免费入口 | 精品无码av一区二区三区 | 精品无码av一区二区三区 | 亚洲精品国偷拍自产在线麻豆 | 老头边吃奶边弄进去呻吟 | 久久久国产精品无码免费专区 | 久久综合久久自在自线精品自 | 鲁大师影院在线观看 | 日日摸夜夜摸狠狠摸婷婷 | 99久久精品日本一区二区免费 | 国产av一区二区三区最新精品 | 中文字幕无码免费久久99 | 日韩无套无码精品 | 无码中文字幕色专区 | 精品aⅴ一区二区三区 | 18禁黄网站男男禁片免费观看 | 初尝人妻少妇中文字幕 | 国产精品99爱免费视频 | 久久综合久久自在自线精品自 | av人摸人人人澡人人超碰下载 | 中文精品无码中文字幕无码专区 | 狠狠色欧美亚洲狠狠色www | 丰满妇女强制高潮18xxxx | 国产精品欧美成人 | 精品无码国产一区二区三区av | 无码播放一区二区三区 | 高潮毛片无遮挡高清免费视频 | 国产精品无码一区二区桃花视频 | 久久精品女人的天堂av | 少妇的肉体aa片免费 | 久久久久久久人妻无码中文字幕爆 | 中文字幕无码免费久久99 | 国产亚洲精品久久久久久久 | 亚洲中文字幕成人无码 | 精品日本一区二区三区在线观看 | 狂野欧美激情性xxxx | 一本久道高清无码视频 | 亚洲国产成人a精品不卡在线 | 夫妻免费无码v看片 | 帮老师解开蕾丝奶罩吸乳网站 | 永久黄网站色视频免费直播 | 中文字幕久久久久人妻 | 国产精品人人爽人人做我的可爱 | 色五月五月丁香亚洲综合网 | 人妻熟女一区 | 欧美 日韩 亚洲 在线 | 欧美xxxx黑人又粗又长 | 久久久久成人片免费观看蜜芽 | 亚洲日韩精品欧美一区二区 | 99久久久国产精品无码免费 | 久青草影院在线观看国产 | 97无码免费人妻超级碰碰夜夜 | 在线观看国产午夜福利片 | 亚洲aⅴ无码成人网站国产app | 水蜜桃色314在线观看 | 国产内射老熟女aaaa | 无码人妻av免费一区二区三区 | 一本无码人妻在中文字幕免费 | 蜜臀av无码人妻精品 | yw尤物av无码国产在线观看 | 精品久久8x国产免费观看 | 无码精品国产va在线观看dvd | 成人无码影片精品久久久 | 欧美性猛交内射兽交老熟妇 | 日韩人妻少妇一区二区三区 | 玩弄人妻少妇500系列视频 | 久久aⅴ免费观看 | 性啪啪chinese东北女人 | 中文字幕+乱码+中文字幕一区 | 国产精品久久久久久久影院 | 亚洲成a人片在线观看无码 | 日本丰满护士爆乳xxxx | 欧美日本免费一区二区三区 | 亚洲男人av天堂午夜在 | 亚洲国产日韩a在线播放 | 人妻少妇被猛烈进入中文字幕 | 久久午夜无码鲁丝片 | 国产精品怡红院永久免费 | 日本肉体xxxx裸交 | 国产成人无码午夜视频在线观看 | 久久亚洲精品成人无码 | 免费无码的av片在线观看 | 好爽又高潮了毛片免费下载 | 欧美精品一区二区精品久久 | 免费无码一区二区三区蜜桃大 | 国产精品亚洲综合色区韩国 | 精品一二三区久久aaa片 | 丰满人妻一区二区三区免费视频 | 国产情侣作爱视频免费观看 | 暴力强奷在线播放无码 | 欧美xxxx黑人又粗又长 | 熟妇女人妻丰满少妇中文字幕 | 极品尤物被啪到呻吟喷水 | 亚洲精品综合五月久久小说 | 自拍偷自拍亚洲精品10p | 伊人久久婷婷五月综合97色 | 中文字幕精品av一区二区五区 | 中文字幕无码免费久久9一区9 | 久久精品一区二区三区四区 | 亚洲中文字幕av在天堂 | 国产激情一区二区三区 | 日本精品人妻无码免费大全 | 精品成人av一区二区三区 | 亚洲 日韩 欧美 成人 在线观看 | 天天综合网天天综合色 | 国产香蕉尹人视频在线 | 国产综合在线观看 | 高清无码午夜福利视频 | 国产网红无码精品视频 | 夜夜影院未满十八勿进 | 97se亚洲精品一区 | 荫蒂添的好舒服视频囗交 | 中文字幕乱码中文乱码51精品 | 18精品久久久无码午夜福利 | 精品久久久中文字幕人妻 | 小鲜肉自慰网站xnxx | 亚洲精品一区二区三区大桥未久 | 国产真实乱对白精彩久久 | 大乳丰满人妻中文字幕日本 | 日韩精品a片一区二区三区妖精 | 色狠狠av一区二区三区 | 女人高潮内射99精品 | 国产尤物精品视频 | 强辱丰满人妻hd中文字幕 | 国产色视频一区二区三区 | 老太婆性杂交欧美肥老太 | 九月婷婷人人澡人人添人人爽 | 在线观看欧美一区二区三区 | 天干天干啦夜天干天2017 | 欧美精品免费观看二区 | | 日韩视频 中文字幕 视频一区 | 久久人人97超碰a片精品 | 永久免费观看美女裸体的网站 | 小鲜肉自慰网站xnxx | 国产精品美女久久久 | 国产三级精品三级男人的天堂 | 呦交小u女精品视频 | 日韩视频 中文字幕 视频一区 | 任你躁国产自任一区二区三区 | 无码人妻av免费一区二区三区 | 日日摸天天摸爽爽狠狠97 | 亚洲а∨天堂久久精品2021 | 无码任你躁久久久久久久 | 久久精品人人做人人综合试看 | 亚洲午夜福利在线观看 | 娇妻被黑人粗大高潮白浆 | 亚洲国产精品久久久久久 | 精品无人国产偷自产在线 | 国产99久久精品一区二区 | 丰满少妇高潮惨叫视频 | 蜜桃av抽搐高潮一区二区 | 伊人久久大香线焦av综合影院 | 亚洲国精产品一二二线 | 国产三级精品三级男人的天堂 | 精品国产精品久久一区免费式 | 亲嘴扒胸摸屁股激烈网站 | 亚洲精品一区二区三区在线观看 | 欧美国产日韩久久mv | 水蜜桃亚洲一二三四在线 | 欧美乱妇无乱码大黄a片 | 无码av免费一区二区三区试看 | 大肉大捧一进一出视频出来呀 | 熟女少妇人妻中文字幕 | 日韩av激情在线观看 | 一个人看的视频www在线 | 人妻与老人中文字幕 | av无码久久久久不卡免费网站 | 亚洲成a人片在线观看日本 | 最近免费中文字幕中文高清百度 | 黑森林福利视频导航 | 亚洲一区二区三区无码久久 | 狠狠色丁香久久婷婷综合五月 | 亚洲中文字幕乱码av波多ji | 无遮挡国产高潮视频免费观看 | 天天综合网天天综合色 | 成人一在线视频日韩国产 | 无码人妻久久一区二区三区不卡 | 一个人看的视频www在线 | 伦伦影院午夜理论片 | 精品厕所偷拍各类美女tp嘘嘘 | 18精品久久久无码午夜福利 | 十八禁真人啪啪免费网站 | 高清不卡一区二区三区 | 欧美亚洲日韩国产人成在线播放 | 日本精品人妻无码免费大全 | 日韩精品无码一本二本三本色 | www国产亚洲精品久久久日本 | 欧美人与善在线com | 日韩欧美群交p片內射中文 | 夜夜高潮次次欢爽av女 | 午夜时刻免费入口 | 国产精品美女久久久久av爽李琼 | 国产精品久久久午夜夜伦鲁鲁 | 激情内射亚州一区二区三区爱妻 | 理论片87福利理论电影 | 理论片87福利理论电影 | 亚洲高清偷拍一区二区三区 | 俄罗斯老熟妇色xxxx | 成熟人妻av无码专区 | 日产精品99久久久久久 | 国内精品一区二区三区不卡 | 少妇被黑人到高潮喷出白浆 | 粉嫩少妇内射浓精videos | 日韩人妻少妇一区二区三区 | 国产综合久久久久鬼色 | 婷婷五月综合激情中文字幕 | 麻豆md0077饥渴少妇 | 国产精品高潮呻吟av久久 | 人妻有码中文字幕在线 | av香港经典三级级 在线 | 欧美丰满老熟妇xxxxx性 | 国产情侣作爱视频免费观看 | 中文字幕人妻无码一区二区三区 | 麻豆国产丝袜白领秘书在线观看 | 久久精品视频在线看15 | 日日干夜夜干 | 免费看男女做好爽好硬视频 | 亚洲熟妇自偷自拍另类 | 久久综合给合久久狠狠狠97色 | 强伦人妻一区二区三区视频18 | 国内老熟妇对白xxxxhd | 乌克兰少妇xxxx做受 | 国产一区二区三区四区五区加勒比 | 东京热一精品无码av | 黑人巨大精品欧美黑寡妇 | 日日碰狠狠丁香久燥 | 国产 精品 自在自线 | 精品国偷自产在线视频 | 色 综合 欧美 亚洲 国产 | 亚洲欧洲日本无在线码 | 欧美黑人巨大xxxxx | 18黄暴禁片在线观看 | 无码人妻黑人中文字幕 | 精品亚洲成av人在线观看 | 久久久久人妻一区精品色欧美 | 99久久久无码国产aaa精品 | 亚洲色欲久久久综合网东京热 | 中文毛片无遮挡高清免费 | 激情内射日本一区二区三区 | 日日摸天天摸爽爽狠狠97 | 成人av无码一区二区三区 | 国产美女极度色诱视频www | 亚洲一区二区三区含羞草 | 中文字幕人妻无码一夲道 | 高潮毛片无遮挡高清免费 | 欧美成人午夜精品久久久 | 动漫av一区二区在线观看 | 亚洲国产高清在线观看视频 | 高清不卡一区二区三区 | 理论片87福利理论电影 | 丰满少妇熟乱xxxxx视频 | 天堂亚洲免费视频 | 国产明星裸体无码xxxx视频 | 久久亚洲日韩精品一区二区三区 | 97夜夜澡人人双人人人喊 | 无码av最新清无码专区吞精 | 蜜臀av在线播放 久久综合激激的五月天 | 国产成人无码区免费内射一片色欲 | 中文字幕乱码人妻无码久久 | 成人亚洲精品久久久久 | 高清无码午夜福利视频 | 天堂а√在线地址中文在线 | 国产成人精品无码播放 | 久久久久久a亚洲欧洲av冫 | 国产精品成人av在线观看 | 亚洲国产成人a精品不卡在线 | 亚洲精品中文字幕 | 欧美激情综合亚洲一二区 | 久久国产精品精品国产色婷婷 | 精品熟女少妇av免费观看 | 人妻中文无码久热丝袜 | 国产精品香蕉在线观看 | 波多野结衣av在线观看 | 国产人妻久久精品二区三区老狼 | 领导边摸边吃奶边做爽在线观看 | 亚洲日韩av一区二区三区中文 | 欧美精品国产综合久久 | 欧美日韩一区二区免费视频 | 97久久超碰中文字幕 | 真人与拘做受免费视频 | 国产 浪潮av性色四虎 | а√天堂www在线天堂小说 | 波多野结衣av一区二区全免费观看 | 熟女少妇人妻中文字幕 | 97人妻精品一区二区三区 | 一本无码人妻在中文字幕免费 | 亚洲欧洲日本无在线码 | 国产精品毛片一区二区 | 国产精品va在线观看无码 | 国产精品亚洲五月天高清 | 亚洲性无码av中文字幕 | 未满成年国产在线观看 | 国产乱人偷精品人妻a片 | 色婷婷香蕉在线一区二区 | 久久无码中文字幕免费影院蜜桃 | 国产超级va在线观看视频 | 国产极品视觉盛宴 | 中文字幕无线码免费人妻 | 成 人影片 免费观看 | 日韩av激情在线观看 | 免费无码av一区二区 | 国产成人无码a区在线观看视频app | 国产精品久久久久久亚洲毛片 | 亚洲中文字幕久久无码 | 青青青手机频在线观看 | 在线观看欧美一区二区三区 | 欧洲熟妇色 欧美 | 99国产欧美久久久精品 | 波多野结衣 黑人 | 色五月丁香五月综合五月 | 大胆欧美熟妇xx | 狂野欧美性猛xxxx乱大交 | 国产精品永久免费视频 | 自拍偷自拍亚洲精品被多人伦好爽 | 久久久久久久久蜜桃 | 中文久久乱码一区二区 | 国产高清不卡无码视频 | 少妇激情av一区二区 | 国产成人无码av一区二区 | 男人和女人高潮免费网站 | 成在人线av无码免费 | 亚洲中文字幕在线观看 | 色婷婷久久一区二区三区麻豆 | 成人一在线视频日韩国产 | 欧美亚洲日韩国产人成在线播放 | 亚洲aⅴ无码成人网站国产app | 好男人www社区 | 国产偷抇久久精品a片69 | 国产麻豆精品一区二区三区v视界 | 亚洲色偷偷男人的天堂 | 久久亚洲精品成人无码 | 色五月五月丁香亚洲综合网 | 熟女俱乐部五十路六十路av | 国产成人一区二区三区在线观看 | 午夜熟女插插xx免费视频 | 日日天日日夜日日摸 | 亚洲中文字幕成人无码 | 中国女人内谢69xxxx | 欧美丰满熟妇xxxx性ppx人交 | 久久99精品久久久久婷婷 | 红桃av一区二区三区在线无码av | 精品久久8x国产免费观看 | 日本乱偷人妻中文字幕 | 沈阳熟女露脸对白视频 | 久久精品人妻少妇一区二区三区 | 蜜臀aⅴ国产精品久久久国产老师 | 亚洲精品久久久久avwww潮水 | 亚洲无人区一区二区三区 | 欧美国产日产一区二区 | 18禁黄网站男男禁片免费观看 | 国产精品久久福利网站 | 正在播放东北夫妻内射 | 夜夜躁日日躁狠狠久久av | 亚洲国产av美女网站 | 奇米综合四色77777久久 东京无码熟妇人妻av在线网址 | 中文字幕无线码 | 国产女主播喷水视频在线观看 | 亚洲成a人片在线观看日本 | 免费人成网站视频在线观看 | 亚洲の无码国产の无码步美 | 国产绳艺sm调教室论坛 | 强奷人妻日本中文字幕 | 免费看少妇作爱视频 | 色婷婷香蕉在线一区二区 | 无码中文字幕色专区 | 双乳奶水饱满少妇呻吟 | 丰满妇女强制高潮18xxxx | 六十路熟妇乱子伦 | 亚洲成色www久久网站 | 日韩少妇白浆无码系列 | 日本一卡二卡不卡视频查询 | 欧美性生交活xxxxxdddd | 久久综合九色综合97网 | 精品乱码久久久久久久 | 欧美日韩视频无码一区二区三 | 99riav国产精品视频 | 成人亚洲精品久久久久软件 | 国产在热线精品视频 | 欧美日韩一区二区综合 | 精品厕所偷拍各类美女tp嘘嘘 | 九九久久精品国产免费看小说 | 少妇被黑人到高潮喷出白浆 | 亚洲娇小与黑人巨大交 | 又粗又大又硬又长又爽 | 国产真实伦对白全集 | 欧洲vodafone精品性 | 欧美精品一区二区精品久久 | 日韩欧美成人免费观看 | 国产熟妇高潮叫床视频播放 | 久久久久久a亚洲欧洲av冫 | 国产精品毛片一区二区 | a国产一区二区免费入口 | 国产熟妇高潮叫床视频播放 | 欧美日韩一区二区免费视频 | 欧美性生交活xxxxxdddd | 成熟女人特级毛片www免费 | 在线观看国产午夜福利片 | 无码av岛国片在线播放 | 欧美兽交xxxx×视频 | 精品国产国产综合精品 | 在线欧美精品一区二区三区 | 色综合久久88色综合天天 | 国产综合在线观看 | 高潮毛片无遮挡高清免费视频 | 黑人玩弄人妻中文在线 | 性色av无码免费一区二区三区 | 欧美三级a做爰在线观看 | 亚洲精品美女久久久久久久 | 任你躁国产自任一区二区三区 | 无码国产乱人伦偷精品视频 | 奇米影视7777久久精品 | 国产成人亚洲综合无码 | 在线播放无码字幕亚洲 | 国产xxx69麻豆国语对白 | 欧美性生交xxxxx久久久 | 最近免费中文字幕中文高清百度 | 男人扒开女人内裤强吻桶进去 | 人人妻人人澡人人爽欧美一区九九 | 免费男性肉肉影院 | 中文字幕无码av激情不卡 | 波多野结衣高清一区二区三区 | 亚洲无人区午夜福利码高清完整版 | 国产亚洲人成在线播放 | 久久www免费人成人片 | 精品成人av一区二区三区 | 蜜桃视频插满18在线观看 | 国产精品无码一区二区桃花视频 | 欧美亚洲日韩国产人成在线播放 | 国产亚av手机在线观看 | 内射白嫩少妇超碰 | 伊人久久大香线蕉av一区二区 | 无码纯肉视频在线观看 | 99精品无人区乱码1区2区3区 | 国产亚洲精品久久久ai换 | av在线亚洲欧洲日产一区二区 | av香港经典三级级 在线 | 成 人影片 免费观看 | 精品国产青草久久久久福利 | 亚洲乱码国产乱码精品精 | 色欲久久久天天天综合网精品 | 亚洲国产综合无码一区 | a片免费视频在线观看 | 国产熟妇高潮叫床视频播放 | 日日碰狠狠躁久久躁蜜桃 | 亚洲人成影院在线观看 | 人妻插b视频一区二区三区 | 小sao货水好多真紧h无码视频 | 欧美成人午夜精品久久久 | 亚洲 另类 在线 欧美 制服 | 精品人妻av区 | 国产高清不卡无码视频 | a片在线免费观看 | 麻豆国产人妻欲求不满 | 日本高清一区免费中文视频 | 亚洲 a v无 码免 费 成 人 a v | 中文字幕 亚洲精品 第1页 | 国产一区二区不卡老阿姨 | 熟妇人妻中文av无码 | 亚洲精品欧美二区三区中文字幕 | 国产亚洲人成在线播放 | 麻豆国产97在线 | 欧洲 | 国产成人精品优优av | 亚洲热妇无码av在线播放 | 久久99精品久久久久久动态图 | 久久久久免费看成人影片 | 久久久久免费看成人影片 | 小鲜肉自慰网站xnxx | 熟女体下毛毛黑森林 | 在线 国产 欧美 亚洲 天堂 | 成年女人永久免费看片 | 少妇性l交大片欧洲热妇乱xxx | 亚洲欧洲无卡二区视頻 | 熟妇人妻中文av无码 | 无码任你躁久久久久久久 | 狠狠色噜噜狠狠狠狠7777米奇 | 亚洲啪av永久无码精品放毛片 | 正在播放东北夫妻内射 | 99麻豆久久久国产精品免费 | 亚洲男人av天堂午夜在 | 久久精品国产一区二区三区肥胖 | 欧美精品一区二区精品久久 | 人人澡人人妻人人爽人人蜜桃 | 未满小14洗澡无码视频网站 | 亚洲成色www久久网站 | 蜜臀av在线观看 在线欧美精品一区二区三区 | 伊在人天堂亚洲香蕉精品区 | 在线精品国产一区二区三区 | 欧美精品国产综合久久 | 高中生自慰www网站 | 免费无码肉片在线观看 | 久久久亚洲欧洲日产国码αv | 国产精品无码一区二区三区不卡 | 天天拍夜夜添久久精品 | 亚洲欧美综合区丁香五月小说 | 色一情一乱一伦 | 中文字幕人成乱码熟女app | 2020最新国产自产精品 | 狂野欧美激情性xxxx | 久久国产精品偷任你爽任你 | 国产在线aaa片一区二区99 | 国产黑色丝袜在线播放 | 亚洲日韩一区二区 | 国产精品久久久一区二区三区 | 国产人成高清在线视频99最全资源 | 真人与拘做受免费视频 | 久久综合久久自在自线精品自 | 久久久久免费看成人影片 | 国产人妻精品一区二区三区 | 日日摸日日碰夜夜爽av | 任你躁在线精品免费 | 扒开双腿吃奶呻吟做受视频 | 麻豆果冻传媒2021精品传媒一区下载 | 日本乱偷人妻中文字幕 | 亚洲日韩av一区二区三区四区 | 精品无码成人片一区二区98 | 捆绑白丝粉色jk震动捧喷白浆 | 熟妇人妻激情偷爽文 | 国产一区二区三区影院 | 亚洲精品无码人妻无码 | 国产熟女一区二区三区四区五区 | 欧美性猛交xxxx富婆 | 性色欲情网站iwww九文堂 | 未满小14洗澡无码视频网站 | 国产成人无码a区在线观看视频app | 澳门永久av免费网站 | 国产精品久久久久久亚洲毛片 | 亚洲精品一区二区三区婷婷月 | 国产精品99久久精品爆乳 | 亚洲天堂2017无码中文 | 成人无码影片精品久久久 | 久久人人爽人人爽人人片av高清 | 少妇被黑人到高潮喷出白浆 | 国产亚洲tv在线观看 | 国产三级精品三级男人的天堂 | 在线播放亚洲第一字幕 | 久久人人爽人人爽人人片av高清 | 激情爆乳一区二区三区 | 狠狠色丁香久久婷婷综合五月 | 宝宝好涨水快流出来免费视频 | 国产在线精品一区二区三区直播 | 久在线观看福利视频 | 99久久精品午夜一区二区 | 国产成人无码av一区二区 | 国产精品99久久精品爆乳 | 老熟女重囗味hdxx69 | 岛国片人妻三上悠亚 | 亚洲狠狠婷婷综合久久 | v一区无码内射国产 | 亲嘴扒胸摸屁股激烈网站 | 99精品视频在线观看免费 | 亚洲爆乳精品无码一区二区三区 | 麻豆国产97在线 | 欧洲 | 日本熟妇浓毛 | 日本精品久久久久中文字幕 | av无码久久久久不卡免费网站 | 国产成人无码av在线影院 | 亚洲成av人片天堂网无码】 | 人妻aⅴ无码一区二区三区 | 欧美日韩综合一区二区三区 | 国产亚洲精品久久久久久久久动漫 | 欧美老人巨大xxxx做受 | 76少妇精品导航 | 国产三级精品三级男人的天堂 | 色老头在线一区二区三区 | 亚洲欧洲无卡二区视頻 | 免费网站看v片在线18禁无码 | 黑人玩弄人妻中文在线 | 国产精品久久久久久亚洲影视内衣 | aⅴ在线视频男人的天堂 | 丰满岳乱妇在线观看中字无码 | 国产成人精品视频ⅴa片软件竹菊 | 性欧美大战久久久久久久 | 98国产精品综合一区二区三区 | 久久99精品久久久久婷婷 | а√天堂www在线天堂小说 | 精品无码一区二区三区爱欲 | 丰满肥臀大屁股熟妇激情视频 | 国产sm调教视频在线观看 | 日韩视频 中文字幕 视频一区 | 免费无码一区二区三区蜜桃大 | 色综合久久久无码中文字幕 | 99精品久久毛片a片 | 国产精品久久久久久亚洲毛片 | 欧美日韩人成综合在线播放 | 成人性做爰aaa片免费看不忠 | 国产农村乱对白刺激视频 | 性欧美大战久久久久久久 | 人人妻人人澡人人爽人人精品浪潮 | 中文字幕av日韩精品一区二区 | 国产黑色丝袜在线播放 | 人人爽人人爽人人片av亚洲 | 国产麻豆精品精东影业av网站 | 人人妻人人藻人人爽欧美一区 | 97色伦图片97综合影院 | 精品厕所偷拍各类美女tp嘘嘘 | 欧洲熟妇精品视频 | 久久精品人人做人人综合 | 欧美日韩亚洲国产精品 | 色婷婷av一区二区三区之红樱桃 | 色欲久久久天天天综合网精品 | 久久精品人人做人人综合试看 |