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

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > java >内容正文

java

[Java]jdbc[转]

發布時間:2025/6/17 java 65 豆豆
生活随笔 收集整理的這篇文章主要介紹了 [Java]jdbc[转] 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
[Java]jdbc[轉]

?

>>http://www.cnblogs.com/xiohao/p/3507483.html

>>http://www.cnblogs.com/hongten/archive/2011/03/29/1998311.html

>>http://www.cnblogs.com/lee/archive/2007/08/25/869656.html

JDBC連接各種數據庫方法

1)連接Oracle 8/8i/9i/10g/11g(thin模式)Class.forName("oracle.JDBC.driver.OracleDriver").newInstance();String url="JDBC:oracle:thin:@localhost:1521:orcl" //orcl為Oracle數據庫的SID String user="test";String password="test";Connection con=DriverManager.getConnection(url,user,password);2)連接DB2數據庫Class.forName("com.ibm.db2.jcc.DB2Driver");String url="JDBC:db2://localhost:5000/testDb";String user="test"; String password="test";Connection con=DriverManager.getConnection(url,user,password);3)連接MySQL數據庫Class.forName("com.mysql.jdbc.Driver");String url="JDBC:mysql://localhost:8080/testDB";String user="test"; String password="test";Connection con=DriverManager.getConnection(url,user,password);4)連接SQL Server2000數據庫Class.forName("com.microsoft.JDBC.sqlserver.SQLServerDriver");String url="JDBC:microsoft:sqlserver://localhost:1433;DatabaseName=testDb";String user="test"; String password="test";Connection con=DriverManager.getConnection(url,user,password);5)連接PostgreSQL數據庫Class.forName("org.postgresql.Driver");String url="JDBC:postgresql://localhost/testDb";String user="test"; String password="test";Connection con=DriverManager.getConnection(url,user,password);6)連接Access數據庫Class.forName("sun.jdbc.odbc.JdbcOdbcDriver");String url="JDBC:odbc:Driver={Microsoft Access Driver (*.mdb)};DBQ="+application.getRealPath("/Data/testDb/mdb");Connection conn=DriverManager.getConnection(url,"","");7連接Sybase數據庫Class.forName("com.sybase.JDBC.SybDriver");String url="JDBC:sybase:Tds:localhost:5007/testDb";Properties pro=System.getProperties();pro.put("user","userId");pro.put("password","user_password");Connection con=DriverManager.getConnection(url,pro);8連接informix數據庫Class.forName("com.informix.JDBC.ifxDriver");String url="JDBC:informix-sqli:localhost:1533/testDb:INFORMIXSERVER=myserver"user=testUser;password=testpassword"; Connection con=DriverManager.getConnection(url);

完整java開發中JDBC連接數據庫代碼和步驟

JDBC連接數據庫 ?創建一個以JDBC連接數據庫的程序,包含7個步驟1、加載JDBC驅動程序: 在連接數據庫之前,首先要加載想要連接的數據庫的驅動到JVM(Java虛擬機), 這通過java.lang.Class類的靜態方法forName(String className)實現。 例如: try{ //加載MySql的驅動類 Class.forName("com.mysql.jdbc.Driver") ; }catch(ClassNotFoundException e){ System.out.println("找不到驅動程序類 ,加載驅動失敗!"); e.printStackTrace() ; } 成功加載后,會將Driver類的實例注冊到DriverManager類中。 2、提供JDBC連接的URL ?連接URL定義了連接數據庫時的協議、子協議、數據源標識。 ?書寫形式:協議:子協議:數據源標識 協議:在JDBC中總是以jdbc開始 子協議:是橋連接的驅動程序或是數據庫管理系統名稱。 數據源標識:標記找到數據庫來源的地址與連接端口。 例如:(MySql的連接URL) jdbc:mysql: //localhost:3306/test?useUnicode=true&characterEncoding=gbk ; useUnicode=true:表示使用Unicode字符集。如果characterEncoding設置為 gb2312或GBK,本參數必須設置為true 。characterEncoding=gbk:字符編碼方式。 3、創建數據庫的連接 ?要連接數據庫,需要向java.sql.DriverManager請求并獲得Connection對象, 該對象就代表一個數據庫的連接。 ?使用DriverManager的getConnectin(String url , String username , String password )方法傳入指定的欲連接的數據庫的路徑、數據庫的用戶名和 密碼來獲得。 例如: //連接MySql數據庫,用戶名和密碼都是root String url = "jdbc:mysql://localhost:3306/test" ; String username = "root" ; String password = "root" ; try{ Connection con = DriverManager.getConnection(url , username , password ) ; }catch(SQLException se){ System.out.println("數據庫連接失敗!"); se.printStackTrace() ; } 4、創建一個Statement ?要執行SQL語句,必須獲得java.sql.Statement實例,Statement實例分為以下3 種類型: 1、執行靜態SQL語句。通常通過Statement實例實現。 2、執行動態SQL語句。通常通過PreparedStatement實例實現。 3、執行數據庫存儲過程。通常通過CallableStatement實例實現。 具體的實現方式: Statement stmt = con.createStatement() ; PreparedStatement pstmt = con.prepareStatement(sql) ; CallableStatement cstmt = con.prepareCall("{CALL demoSp(? , ?)}") ; 5、執行SQL語句 Statement接口提供了三種執行SQL語句的方法:executeQuery 、executeUpdate 和execute 1、ResultSet executeQuery(String sqlString):執行查詢數據庫的SQL語句 ,返回一個結果集(ResultSet)對象。 2、int executeUpdate(String sqlString):用于執行INSERT、UPDATE或 DELETE語句以及SQL DDL語句,如:CREATE TABLE和DROP TABLE等 3、execute(sqlString):用于執行返回多個結果集、多個更新計數或二者組合的 語句。 具體實現的代碼: ResultSet rs = stmt.executeQuery("SELECT * FROM ...") ; int rows = stmt.executeUpdate("INSERT INTO ...") ; boolean flag = stmt.execute(String sql) ; 6、處理結果 兩種情況: 1、執行更新返回的是本次操作影響到的記錄數。 2、執行查詢返回的結果是一個ResultSet對象。 ? ResultSet包含符合SQL語句中條件的所有行,并且它通過一套get方法提供了對這些 行中數據的訪問。 ? 使用結果集(ResultSet)對象的訪問方法獲取數據: while(rs.next()){ String name = rs.getString("name") ; String pass = rs.getString(1) ; // 此方法比較高效 } (列是從左到右編號的,并且從列1開始) 7、關閉JDBC對象 操作完成以后要把所有使用的JDBC對象全都關閉,以釋放JDBC資源,關閉順序和聲 明順序相反: 1、關閉記錄集 2、關閉聲明 3、關閉連接對象 if(rs != null){ // 關閉記錄集 try{ rs.close() ; }catch(SQLException e){ e.printStackTrace() ; } } if(stmt != null){ // 關閉聲明 try{ stmt.close() ; }catch(SQLException e){ e.printStackTrace() ; } } if(conn != null){ // 關閉連接對象 try{ conn.close() ; }catch(SQLException e){ e.printStackTrace() ; } }

?

?

jdbc

什么是JDBC? Java語言訪問數據庫的一種規范,是一套API JDBC (Java Database Connectivity) API,即Java數據庫編程接口,是一組標準的Java語言中的接口和類,使用這些接口和類,Java客戶端程序可以訪問各種不同類型的數據庫。比如建立數據庫連接、執行SQL語句進行數據的存取操作。JDBC規范采用接口和實現分離的思想設計了Java數據庫編程的框架。接口包含在java.sql及javax.sql包中,其中java.sql屬于JavaSE,javax.sql屬于JavaEE。這些接口的實現類叫做數據庫驅動程序,由數據庫的廠商或其它的廠商或個人提供。為了使客戶端程序獨立于特定的數據庫驅動程序,JDBC規范建議開發者使用基于接口的編程方式,即盡量使應用僅依賴java.sql及javax.sql中的接口和類。JDBC驅動程序: 什么是JDBC驅動程序? 這些是各個數據庫廠家根據JDBC的規范制作的JDBC實現類 JDBC驅動程序的四種類型: 1. 第一種類型的驅動程序的實現是通過將JDBC的調用全部委托給其它編程接口來實現的,比如ODBC。這種類型的驅動程序需要安裝本地代碼庫,即依賴于本地的程序,所以便攜性較差。比如JDBC-ODBC橋驅動程序 2. 第二種類型的驅動程序的實現是部分基于Java語言的。即該驅動程序一部分是用Java語言編寫,其它部分委托本地的數據庫的客戶端代碼來實現。同類型1的驅動一樣,該類型的驅動程序也依賴本地的程序,所以便攜性較差 3. 第三種類型的驅動程序的實現是全部基于JAVA語言的。該類型的驅動程序通常由某個中間件服務器提供,這樣客戶端程序可以使用數據庫無關的協議和中間件服務器進行通信,中間件服務器再將客戶端的JDBC調用轉發給數據庫進行處理 4. 第四種類型的驅動程序的實現是全部基于JAVA語言的。該類型的驅動程序中包含了特定數據庫的訪問協議,使得客戶端可以直接和數據庫進行通信JDBC類結構:DriverManagerDriver DriverConnection ConnectionStatement StatementResultset ResultsetDriverManager:這個是一個實現類,它是一個工廠類,用來生產Driver對象的 這個類的結構設計模式為工廠方法 Driver:這是驅動程序對象的接口,它指向一個實實在在的數據庫驅動程序對象,那么這個數據庫驅動程序對象是從哪里來的呢? DriverManager工廠中有個方法:getDriver(String URL),通過這個方法可以得到驅動程序對象,這個方法是在各個數據庫廠商按JDBC規范設計的數據庫驅動程序包里的類中靜態實現的,也就是在靜態塊中 Connection:這個接口可以制向一個數據庫連接對象,那么如何得到這個連接對象呢? 是通過DriverManager工廠中的getConnection(String URL)方法得到的 Statement:用于執行靜態的SQL語句的接口,通過Connection中的createStatement方法得到的 Resultset:用于指向結果集對象的接口,結果集對象是通過Statement中的execute等方法得到的JAVA使用JDBC訪問數據庫的步驟: 1. 得到數據庫驅動程序 2. 創建數據庫連接 3. 執行SQL語句 4. 得到結果集 5. 對結果集做相應的處理(增,刪,改,查) 6. 關閉資源:這里釋放的是DB中的資源設置classpath: 1. 在java文件中起的包名一定要是工程基目錄下的子目錄,classpath:基目錄 2. .jar包,需要將這個.jar包的路徑包括這個文件的全名添加到classpath中來 Oracle連接字符串的書寫格式: “oracle:jdbc:thin:@ip:1521: 數據庫名”,”數據庫用戶名”,”數據庫密碼”簡單的例子: package moudule1.first;import java.sql.*;public class FirstJdbc {public static void main(String[] args){String sql="select * from yuchen_user";Connection con=null;Statement st=null;ResultSet rs=null;try{ Class.forName("oracle.jdbc.driver.OracleDriver");con=DriverManager.getConnection("jdbc:oracle:thin:@127.0.0.1:1521:name", "scott","tiger");st=con.createStatement();rs=st.executeQuery(sql);while(rs.next()){System.out.println(rs.getInt("id"));System.out.println(rs.getString("name"));}}catch(Exception e){e.printStackTrace();}finally{try{con.close();}catch(Exception e){}try{st.close();}catch(Exception e){}try{rs.close();}catch(Exception e){}}}}常用數據庫的驅動程序及JDBC URL: Oracle數據庫: 驅動程序包名:ojdbc14.jar 驅動類的名字:oracle.jdbc.driver.OracleDriverJDBC URL:jdbc:oracle:thin:@dbip:port:databasename說明:驅動程序包名有可能會變JDBC URL中黑色字體部分必須原封不動的保留,為該驅動識別的URL格式。紅色字體部分需要根據數據庫的安裝情況填寫。其中各個部分含義如下:dbip –為數據庫服務器的IP地址,如果是本地可寫:localhost或127.0.0.1。port –為數據庫的監聽端口,需要看安裝時的配置,缺省為1521。databasename –為數據庫的SID,通常為全局數據庫的名字。舉例如果要訪問本地的數據庫allandb,端口1521,那么URL寫法如下:jdbc:oracle:thin:@localhost:1521:allandb 下載地址如下: http://www.oracle.com/technology/software/tech/java/sqlj_jdbc/index.html

SQL Server數據庫驅動程序包名:msbase.jar mssqlserver.jar msutil.jar驅動類的名字:com.microsoft.jdbc.sqlserver.SQLServerDriverJDBC URL:jdbc:microsoft:sqlserver://dbip:port;DatabaseName=databasename 說明:驅動程序包名有可能會變JDBC URL中黑色字體部分必須原封不動的保留,為該驅動識別的URL格式。紅色字體部需要根據數據庫的安裝情況填寫。其中各個部分含義如下:dbip –為數據庫服務器的IP地址,如果是本地可寫:localhost或127.0.0.1。port –為數據庫的監聽端口,需要看安裝時的配置,缺省為1433。databasename –數據庫的名字。舉例如果要訪問本地的數據庫allandb,端口1433,那么URL寫法如下:jdbc: microsoft: sqlserver:@localhost:1433; DatabaseName =allandb下載地址:http://www.microsoft.com/downloads/details.aspx
MySQL數據庫驅動程序包名:mysql
-connector-java-3.1.11-bin.jar驅動類的名字:com.mysql.jdbc.DriverJDBC URL:jdbc:mysql://dbip:port/databasename 說明:驅動程序包名有可能會變JDBC URL中黑色字體部分必須原封不動的保留,為該驅動識別的URL格式。紅色字體部需要根據數據庫的安裝情況填寫。其中各個部分含義如下:dbip –為數據庫服務器的IP地址,如果是本地可寫:localhost或127.0.0.1。port –為數據庫的監聽端口,需要看安裝時的配置,缺省為3306。databasename –數據庫的名字。舉例如果要訪問本地的數據庫allandb,端口1433,那么URL寫法如下:jdbc:mysql://localhost:3306/allandb下載地址:http://dev.mysql.com/downloads/connector/j/
Access數據庫驅動程序包名:該驅動程序包含在JavaSE中,不需要額外安裝。驅動類的名字:sun.jdbc.odbc.JdbcOdbcDriverJDBC URL:jdbc:odbc:datasourcename說明:該驅動只能工作在Windows系統中,首先需要在操作系統中建立一個可以訪問Access數據庫的本地數據源(ODBC),如果名字為allandb,那么URL寫法如下:jdbc:odbc:allandbPreparedStatement接口: 預編譯的sql語句對象 作用: 解決了書寫sql語句時一些特殊的字符與sql保留字符沖突的問題,非常方便
/** *知識點: *PreparedStatement接口及方法的使用 *程序目標: *java文件: *PreparedInsert.java:連接數據庫,插入一條數據 *JdbcUtil.java:實現一個工具類,功能:1.連接數據庫 2.關閉資源 */package moudule1.preparedstatement;import java.sql.*; import moudule1.com.*;public class PreparedInsert {public static void main(String[] args){String sql="insert into yuchen_user (id,name) values (?,?)";System.out.println(sql);Connection con=null;PreparedStatement ps=null;try{con=JdbcUtil.getConnection();ps=con.prepareStatement(sql);ps.setInt(1,2);ps.setString(2,"zhangsan");ps.executeUpdate();ps.setInt(1,3);ps.setString(2,"lisi");ps.executeUpdate();}catch(Exception e){e.printStackTrace();}finally{JdbcUtil.close(con,ps);}}}package moudule1.com;import java.sql.*;public class JdbcUtil{public static Connection getConnection() throws Exception{Class.forName("oracle.jdbc.driver.OracleDriver");return DriverManager.getConnection("jdbc:oracle:thin:@127.0.0.1:1521:name", "scott","tiger");}public static void close(Connection con,Statement st){close(con);close(st);}public static void close(Connection con,Statement st,ResultSet rs){close(con,st);close(rs);}public static void close(Connection con){try{con.close();}catch(Exception e){}}public static void close(Statement st){try{st.close();}catch(Exception e){}}public static void close(ResultSet rs){try{rs.close();}catch(Exception e){}}}數據庫的增刪改查的例子: /** *知識點: *JDBC+SQL+ORACLE *程序目標: *UserDao.java:實現了數據庫的增刪改查 *JdbcUtil.java:工具類,有連庫和關閉資源的方法 */package moudule1.idus;import java.sql.*; import moudule1.com.*;public class UserDao{private String sql;private Connection con;private Statement st;private ResultSet rs;public UserDao(){sql=null;con=null;st=null;rs=null;}public void insert(){sql="insert into yuchen_user (id,name) values(";sql+="4,'zhouwu')";System.out.println(sql);try{con=JdbcUtil.getConnection();st=con.createStatement();st.executeUpdate(sql);}catch(Exception e){e.printStackTrace();}finally{JdbcUtil.close(con,st);}}public void delete(){sql="delete from yuchen_user where id=2";System.out.println(sql);try{con=JdbcUtil.getConnection();st=con.createStatement();st.executeUpdate(sql);}catch(Exception e){e.printStackTrace();}finally{JdbcUtil.close(con,st);}}public void update(){sql="update yuchen_user set name='liumang' where id=1";System.out.println(sql);try{con=JdbcUtil.getConnection();st=con.createStatement();st.executeUpdate(sql);}catch(Exception e){e.printStackTrace();}finally{JdbcUtil.close(con,st);}}public void select(){sql="select * from yuchen_user";System.out.println(sql);try{con=JdbcUtil.getConnection();st=con.createStatement();rs=st.executeQuery(sql);while(rs.next()){System.out.println(rs.getInt(1));System.out.println(rs.getString(2));}}catch(Exception e){e.printStackTrace();}finally{JdbcUtil.close(con,st,rs);}}public static void main(String[] args){UserDao ud=new UserDao();ud.select();ud.insert();ud.select();ud.update();ud.select();ud.delete();ud.select();}}一些常用的方法: /** *知識點: *execute方法,getResultSet(),getUpdateCount() *程序目標: *JdbcUtil.java:工具類,連接數據庫,關閉資源 *sqlExecutor.java:命令行參數輸入sql語句,并執行該語句 */ package moudule1.fangfa;import java.sql.*; import moudule1.com.*;public class sqlExecutor{public static void main(String[] args){Connection con=null;Statement st=null;try{con=JdbcUtil.getConnection();st=con.createStatement();boolean str=st.execute(args[0]);if(str){ResultSet rs=st.getResultSet();while(rs.next()){System.out.println(rs.getInt("id")+":"+rs.getString("name"));}rs.close();}else{int row=st.getUpdateCount();System.out.println(row);}}catch(Exception e){e.printStackTrace();}finally{JdbcUtil.close(con,st);}}} 2. 補充JDBC連接MySQL加載及注冊JDBC驅動程序 Class.forName("com.mysql.jdbc.Driver"); Class.forName("com.mysql.jdbc.Driver").newInstance(); JDBC URL 定義驅動程序與數據源之間的連接 標準語法: <protocol(主要通訊協議)>:<subprotocol(次要通訊協議,即驅動程序名稱)>:<data source identifier(數據源)> MySQL的JDBC URL格式: jdbc:mysql//[hostname][:port]/[dbname][?param1=value1][&param2=value2]…. 示例:jdbc:mysql://localhost:3306/sample_db?user=root&password=your_password 常見參數: user 用戶名 password 密碼 autoReconnect 聯機失敗,是否重新聯機(true/false) maxReconnect 嘗試重新聯機次數 initialTimeout 嘗試重新聯機間隔 maxRows 傳回最大行數 useUnicode 是否使用Unicode字體編碼(true/false) characterEncoding 何種編碼(GB2312/UTF-8/…) relaxAutocommit 是否自動提交(true/false) capitalizeTypeNames 數據定義的名稱以大寫表示 建立連接對象 String url="jdbc:mysql://localhost:3306/sample_db?user=root&password=your_password"; Connection con = DriverManager.getConnection(url); 建立SQL陳述式對象(Statement Object) Statement stmt = con.createStatement(); 執行SQL語句 executeQuery() String query = "select * from test"; ResultSet rs=stmt.executeQuery(query); 結果集ResultSet while(rs.next()) {rs.getString(1);rs.getInt(2);} executeUpdate() String upd="insert into test (id,name) values(1001,xuzhaori)"; int con=stmt.executeUpdate(upd); execute() 示例: try{ } catch(SQLException sqle) { } finally { }Java類型和SQL類型 技術手冊P421 PreparedStatement(預編語句) PreparedStatement stmt = conn.prepareStatement("insert into test(id,name)values(?,?)"); stmt.setInt(1,id); stmt.setString(2,name); 注:一旦設定語句的參數值后,就可以多次執行改語句,直到調用clearParameters()方法將他清除為止 CallableStatement(預儲程序)技術手冊P430 JDBC2.0使用 ResultSet對象中的光標上下自由移動 Statement stmt = con.createStatement (ResultSet.TYPE_SCROLL_SENSITIVE, ResultSet.CONCUR_READ_ONLY); ResultSet rs=stmt.executeQuery("select * from test");public Statement createStatement(int resultSetType,int resultSetConcuttency) throws SQLExceptionresultSetType TYPE_FORWARD_ONLY 只能使用next()方法。 TYPE_SCROLL_SENSITIVE 可以上下移動,可以取得改變后的值。 TYPE_SCROLL_INSENSITIVE 可以上下移動。 resultSetConcuttency CONCUR_READ_ONLY 只讀 CONCUR_UPDATABLE ResultSet對象可以執行數據庫的新增、修改、和移除直接使用ResultSet對象執行更新數據 新增數據 Statement stmt=con.createStatement(ResultSet.TYPE_SCROLL_SENSITIVE,ResultSet.CONCUR_PUDATABLE); ResultSet uprs=stmt.executeQuery("select * from test"); uprs.moveToInsertRow(); uprs.updateInt(1,1001); uprs.updateString(2,"許召日"); uprs.insertRow; 更新數據 Statement stmt=con.createStatement(ResultSet.TYPE_SCROLL_SENSITIVE,ResultSet.CONCUR_PUDATABLE); ResultSet uprs=stmt.executeQuery("select * from test"); uprs.last(); uprs.updateString("name","xuzhaori"); uprs.updateRow; 刪除數據 Statement stmt=con.createStatement(ResultSet.TYPE_SCROLL_SENSITIVE,ResultSet.CONCUR_PUDATABLE); ResultSet uprs=stmt.executeQuery("select * from test"); uprs.absolute(4); uprs.deleteRow();批處理 con.setAutoCommit(false); 關閉自動認可模式 Statement stmt=con.createStatement(); int[] rows; stmt.addBatch("insert into test values(1001,xuzhaori)"); stmt.addBatch("insert into test values(1002,xuyalin)"); rows=stmt.executeBatch(); con.commit(); 沒有任何錯誤,執行批處理stmt.executeBatch();JNDI-數據源(Data Source)與連接池(Connection Pool) Tomcat的JDBC數據源設置 技術手冊P439 連接池工具-Proxool Var 0.8.3 技術手冊P446 設置web.xml <?xml version="1.0" encoding="ISO-8859-1"?> <!--<?xml version="1.0" encoding="GB2312"?>--><web-app xmlns="http://java.sun.com/xml/ns/j2ee" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://java.sun.com/xml/ns/j2ee/web-app_2_4.xsd" version="2.4"> …. <servlet> <servlet-name>ServletConfigurator</servlet-name> <servlet-class>org.logicalcobwebs.proxool.configuration.ServletConfigurator</servlet-class><init-param> <param-name>propertyFile</param-name> <param-value>WEB-INF/classes/Proxool.properties</param-value> </init-param> <load-on-startup>1</load-on-startup> </servlet> 后端統計端口添加下列 <servlet> <servlet-name>Admin</servlet-name> <servlet-class>org.logicalcobwebs.proxool.admin.servlet.AdminServlet</servlet-class> </servlet><servlet-mapping> <servlet-name>Admin</servlet-name> <url-pattern>/Admin</url-pattern> </servlet-mapping>….</web-app>配置Proxool.properties jdbc-0.proxool.alias=JSPBook jdbc-0.proxool.driver-class=com.mysql.jdbc.Driver jdbc-0.proxool.driver-url=jdbc:mysql://localhost:3306/sample_db?user=root&password=browser&useUnicode=true&characterEncoding=UTF-8 jdbc-0.proxool.maximum-connection-count=10 jdbc-0.proxool.prototype-count=4 jdbc-0.proxool.house-keeping-test-sql=select CURRENT_DATE jdbc-0.proxool.verbose=true jdbc-0.proxool.statistics=10s,1m,1d 后端統計接口添加此行 jdbc-0.proxool.statistics-log-level=DEBUG 使用Proxool連接池 Connection con = DriverManager.getConnection("proxool.JSPBook"); Statement stmt = con.createStatement(ResultSet.TYPE_SCROLL_SENSITIVE, ResultSet.CONCUR_UPDATABLE); String query = "SELECT * FROM employee"; ResultSet rs = stmt.executeQuery(query);

?

JDBC事務提交和回滾示例

以下是使用事務提交和回滾描述的例子。基于對環境和數據庫安裝在前面的章節中做此示例代碼已學習過。復制過去下面的例子中JDBCExample.java,編譯并運行,如下所示://STEP 1. Import required packages import java.sql.*;public class JDBCExample {// JDBC driver name and database URLstatic final String JDBC_DRIVER = "com.mysql.jdbc.Driver"; static final String DB_URL = "jdbc:mysql://localhost/EMP";// Database credentialsstatic final String USER = "username";static final String PASS = "password";public static void main(String[] args) {Connection conn = null;Statement stmt = null;try{//STEP 2: Register JDBC driverClass.forName("com.mysql.jdbc.Driver");//STEP 3: Open a connectionSystem.out.println("Connecting to database...");conn = DriverManager.getConnection(DB_URL,USER,PASS);//STEP 4: Set auto commit as false.conn.setAutoCommit(false);//STEP 5: Execute a query to create statment with// required arguments for RS example.System.out.println("Creating statement...");stmt = conn.createStatement(ResultSet.TYPE_SCROLL_INSENSITIVE,ResultSet.CONCUR_UPDATABLE);//STEP 6: INSERT a row into Employees tableSystem.out.println("Inserting one row....");String SQL = "INSERT INTO Employees " +"VALUES (106, 20, 'Rita', 'Tez')";stmt.executeUpdate(SQL); //STEP 7: INSERT one more row into Employees tableSQL = "INSERT INTO Employees " +"VALUES (107, 22, 'Sita', 'Singh')";stmt.executeUpdate(SQL);//STEP 8: Commit data here.System.out.println("Commiting data here....");conn.commit();//STEP 9: Now list all the available records.String sql = "SELECT id, first, last, age FROM Employees";ResultSet rs = stmt.executeQuery(sql);System.out.println("List result set for reference....");printRs(rs);//STEP 10: Clean-up environment rs.close();stmt.close();conn.close();}catch(SQLException se){//Handle errors for JDBC se.printStackTrace();// If there is an error then rollback the changes.System.out.println("Rolling back data here....");try{if(conn!=null)conn.rollback();}catch(SQLException se2){se2.printStackTrace();}//end try }catch(Exception e){//Handle errors for Class.forName e.printStackTrace();}finally{//finally block used to close resourcestry{if(stmt!=null)stmt.close();}catch(SQLException se2){}// nothing we can dotry{if(conn!=null)conn.close();}catch(SQLException se){se.printStackTrace();}//end finally try}//end trySystem.out.println("Goodbye!"); }//end mainpublic static void printRs(ResultSet rs) throws SQLException{//Ensure we start with first row rs.beforeFirst();while(rs.next()){//Retrieve by column nameint id = rs.getInt("id");int age = rs.getInt("age");String first = rs.getString("first");String last = rs.getString("last");//Display valuesSystem.out.print("ID: " + id);System.out.print(", Age: " + age);System.out.print(", First: " + first);System.out.println(", Last: " + last);}System.out.println();}//end printRs() }//end JDBCExample

現在讓我們來編譯上面的例子如下: C:\>javac JDBCExample.java C:\> 當運行JDBCExample,它會產生以下結果:C:\>java JDBCExample Connecting to database... Creating statement... Inserting one row.... Commiting data here.... List result set for reference.... ID: 100, Age: 18, First: Zara, Last: Ali ID: 101, Age: 25, First: Mahnaz, Last: Fatma ID: 102, Age: 30, First: Zaid, Last: Khan ID: 103, Age: 28, First: Sumit, Last: Mittal ID: 106, Age: 20, First: Rita, Last: Tez ID: 107, Age: 22, First: Sita, Last: Singh Goodbye! C:\>

?老師的例子:

JdbcDemo.java

package jdbc;import java.sql.Connection; import java.sql.DriverManager; import java.sql.PreparedStatement; import java.sql.SQLException;public class JdbcDemo {/*** @param args*/public static void main(String[] args) {// TODO Auto-generated method stub String username = "test";String password = "123456";String url = "jdbc:oracle:thin:@localhost:1521:orcl";//localhost 127.0.0.1 orclConnection conn = null;try {Class.forName("oracle.jdbc.driver.OracleDriver"); //加載驅動conn = DriverManager.getConnection(url,username,password); /* //String sql = "insert into demo(id,name,sex,address,birthday)
       values(2,'張三1','1','南京1',to_date('2014-12-12','yyyy-mm-dd'))";
int id = 3;String name = "李四";String sex = "1";String address = "北京";String birthday = "2012-12-12";String sql = "insert into demo(id,name,sex,address,birthday)
       values("+id+",'"+name+"','"+sex+"','"+address+"',
       to_date('"+birthday+"','yyyy-mm-dd'))";System.out.println(sql);Statement st = conn.createStatement();st.executeUpdate(sql);sql = "delete from demo where id="+id;
*//*String sql = "select id,name,sex,address,
to_char(birthday,'yyyy-mm-dd') birthday from demo";Statement st = conn.createStatement();ResultSet rs = st.executeQuery(sql);while(rs.next()){int id = rs.getInt("id");String name = rs.getString("name");String sex = rs.getString("sex");String address = rs.getString("address");String birthday = rs.getString("birthday");System.out.println(id);}rs.close();st.close();conn.close();
*/ /* int id = 4;String name = "李四";String sex = "1";String address = "北京";String birthday = "2012-12-12";String sql = "insert into demo(id,name,sex,address,birthday)
values(?,?,?,?,to_date('"+birthday+"','yyyy-mm-dd'))";PreparedStatement pst = conn.prepareStatement(sql);pst.setInt(1, id);pst.setString(2, name);pst.setString(3, sex);pst.setString(4, address);pst.executeUpdate();
*///1.手動提交conn.setAutoCommit(false);int id = 6;String name = "李四";String sex = "1";String address = "北京";String birthday = "2012-12-12";String sql = "insert into demo(id,name,sex,address,birthday)
values(?,?,?,?,to_date('"+birthday+"','yyyy-mm-dd'))";PreparedStatement pst = conn.prepareStatement(sql);pst.setInt(1, id);pst.setString(2, name);pst.setString(3, sex);pst.setString(4, address);pst.executeUpdate();id = 7;sql = "insert into demo(id,name,sex,address,birthday)
values(?,?,?,?,to_date('"+birthday+"','yyyy-mm-dd'))";pst = conn.prepareStatement(sql);pst.setInt(1, id);pst.setString(2, name);pst.setString(3, sex);pst.setString(4, address);pst.executeUpdate();conn.commit();} catch (ClassNotFoundException e) {// TODO Auto-generated catch block e.printStackTrace();} catch(SQLException sqle){sqle.printStackTrace();try {conn.rollback(); //回滾} catch (SQLException e) {// TODO Auto-generated catch block e.printStackTrace();}}}}





































































































?

ConnDB.java

package jdbc;import java.sql.Connection; import java.sql.DriverManager; import java.sql.SQLException;public class ConnDB {private String username = "test";private String password = "123456";private String url =
"jdbc:oracle:thin:@localhost:1521:orcl";private Connection conn;public Connection getConn() {try {Class.forName
(
"oracle.jdbc.driver.OracleDriver");conn =
DriverManager.getConnection
          (url,username,password);}
catch (ClassNotFoundException e) { e.printStackTrace();} catch(SQLException sqle){sqle.printStackTrace();}return conn;}}






















































































































































































?

DemoDao.java

package jdbc.dao;import java.sql.Connection; import java.sql.PreparedStatement; import java.sql.ResultSet; import java.sql.SQLException; import java.util.ArrayList; import java.util.HashMap; import java.util.Iterator; import java.util.List; import java.util.Map;import jdbc.ConnDB; import jdbc.pojo.Demo;public class DemoDao {/*** 新增* @param demo*/public void add(Demo demo){ConnDB db = new ConnDB();Connection conn = db.getConn();String sql = "insert into demo(id,name,sex,address,birthday)
values(?,?,?,?,to_date('"+demo.getBirthday()+"','yyyy-mm-dd'))";try {PreparedStatement pst = conn.prepareStatement(sql);pst.setInt(1, demo.getId());pst.setString(2, demo.getName());pst.setString(3, demo.getSex());pst.setString(4, demo.getAddress());pst.executeUpdate();pst.close();conn.close();} catch (SQLException e) {// TODO Auto-generated catch block e.printStackTrace();}}public void update(Demo demo){ConnDB db = new ConnDB();Connection conn = db.getConn();String sql = "update demo set name=?,sex=?,address=?,birthday=
to_date('"+demo.getBirthday()+"','yyyy-mm-dd') where id=?";try {PreparedStatement pst = conn.prepareStatement(sql);pst.setString(1, demo.getName());pst.setString(2, demo.getSex());pst.setString(3, demo.getAddress());pst.setInt(4, demo.getId());pst.executeUpdate();pst.close();conn.close();} catch (SQLException e) {// TODO Auto-generated catch block e.printStackTrace();}} public void delete(int id){ConnDB db = new ConnDB();Connection conn = db.getConn();String sql = "delete from demo where id=?";try {PreparedStatement pst = conn.prepareStatement(sql); pst.setInt(1, id); pst.executeUpdate(); pst.close();conn.close();} catch (SQLException e) {// TODO Auto-generated catch block e.printStackTrace();}}public Demo getDemoById(int id){ConnDB db = new ConnDB();Connection conn = db.getConn();Demo demo = new Demo();String sql = "select id,name,sex,address,
to_char(birthday,'yyyy-mm-dd') birthday from demo where id=?";try {PreparedStatement pst = conn.prepareStatement(sql); pst.setInt(1, id);ResultSet rs = pst.executeQuery();if(rs.next()){demo.setId(rs.getInt("id"));demo.setName(rs.getString("name"));demo.setSex(rs.getString("sex"));demo.setAddress(rs.getString("address"));demo.setBirthday(rs.getString("birthday"));} pst.close();conn.close();} catch (SQLException e) {// TODO Auto-generated catch block e.printStackTrace();}return demo;}public Map getDemoMap(int id){Map hm = new HashMap();ConnDB db = new ConnDB();Connection conn = db.getConn();Demo demo = new Demo();String sql = "select id,name,sex,address,
to_char(birthday,'yyyy-mm-dd') birthday from demo where id=?";try {PreparedStatement pst = conn.prepareStatement(sql); pst.setInt(1, id);ResultSet rs = pst.executeQuery();if(rs.next()){hm.put("id",rs.getInt("id"));hm.put("name",rs.getString("name"));hm.put("sex",rs.getString("sex"));hm.put("address",rs.getString("address"));hm.put("birthday",rs.getString("birthday"));} pst.close();conn.close();} catch (SQLException e) {// TODO Auto-generated catch block e.printStackTrace();}return hm;}public List getAllDemo(){List list = new ArrayList();ConnDB db = new ConnDB();Connection conn = db.getConn();Demo demo;String sql = "select id,name,sex,address,
to_char(birthday,'yyyy-mm-dd') birthday from demo";try {PreparedStatement pst = conn.prepareStatement(sql); ResultSet rs = pst.executeQuery();while(rs.next()){demo = new Demo();demo.setId(rs.getInt("id"));demo.setName(rs.getString("name"));demo.setSex(rs.getString("sex"));demo.setAddress(rs.getString("address"));demo.setBirthday(rs.getString("birthday"));list.add(demo);} pst.close();conn.close();} catch (SQLException e) {// TODO Auto-generated catch block e.printStackTrace();}return list;}public static void main(String[] args){Demo demo = new Demo();/*demo.setId(8);demo.setName("張炸1");demo.setSex("0");demo.setAddress("上海1");demo.setBirthday("2012-2-2");*/DemoDao dd = new DemoDao();Map hm = dd.getDemoMap(2);System.out.println(hm.get("name"));List list = dd.getAllDemo();Iterator itr = list.iterator();while(itr.hasNext()){demo = (Demo)itr.next();//System.out.println(demo.getName()); }}}

?

Demo.java

package jdbc.pojo;public class Demo {private int id;private String name;private String sex;private String address;private String birthday;public int getId() {return id;}public void setId(int id) {this.id = id;}public String getName() {return name;}public void setName(String name) {this.name = name;}public String getSex() {return sex;}public void setSex(String sex) {this.sex = sex;}public String getAddress() {return address;}public void setAddress(String address) {this.address = address;}public String getBirthday() {return birthday;}public void setBirthday(String birthday) {this.birthday = birthday;}}




































































































































































?

?

posted on 2014-12-19 10:41 1iqueen 閱讀(...) 評論(...) 編輯 收藏

轉載于:https://www.cnblogs.com/lkboy/p/4173375.html

總結

以上是生活随笔為你收集整理的[Java]jdbc[转]的全部內容,希望文章能夠幫你解決所遇到的問題。

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

国产日韩在线一区 | 中日韩男男gay无套 日韩精品一区二区三区高清免费 | 日韩视频1 | 黄色在线看网站 | 深爱五月激情五月 | 国产精品成人自产拍在线观看 | 99亚洲精品在线 | 91亚洲夫妻| 久久久精品欧美一区二区免费 | 国内外激情视频 | 亚洲精品国产精品乱码在线观看 | 久久精品国产一区二区 | 最新国产精品久久精品 | 一区二区三区高清在线观看 | 在线日韩亚洲 | www国产亚洲精品久久麻豆 | 黄色小视频在线观看免费 | 天天干婷婷 | 五月天六月丁香 | 婷婷激情av| 欧美成人h版在线观看 | 亚洲黄色在线 | 日韩欧美视频免费看 | 99婷婷狠狠成为人免费视频 | 免费看的黄色 | 美腿丝袜av | 亚洲永久精品在线 | 特黄特色特刺激视频免费播放 | 久久久久久久久福利 | 久久高清视频免费 | 色综合婷婷| 99视频免费 | 99久久久久国产精品免费 | 国产视频日本 | 日韩久久精品一区二区三区 | 成年人看片网站 | 久久精品99国产精品亚洲最刺激 | 人人澡人人添人人爽一区二区 | 久久久精品午夜 | 国产国产人免费人成免费视频 | 欧美日韩国产亚洲乱码字幕 | 久9在线 | 免费看一级黄色大全 | 玖玖在线视频观看 | 国产二区视频在线观看 | 日韩免费在线播放 | 亚洲成成品网站 | 国产不卡一 | 免费黄色网址网站 | 男女拍拍免费视频 | 91免费视频黄 | 狠狠色丁香婷婷 | 欧美色插 | 欧美午夜性生活 | 国产精品一区久久久久 | 日韩免费区 | 免费视频区 | 91传媒免费观看 | 国产色在线观看 | 亚洲精品视频中文字幕 | 日日摸日日 | 欧美成天堂网地址 | 亚洲日韩精品欧美一区二区 | 国产精品久久久久久久久久久久午夜 | 综合久久网 | 欧美污网站 | 久久综合九色九九 | 91黄视频在线观看 | 96亚洲精品久久久蜜桃 | 精品国产不卡 | 色婷婷综合久色 | 天天爽综合网 | 少妇性xxx | 国产精品久久久久影视 | 久久韩国免费视频 | 久久精品国产精品亚洲 | 精品久久久久免费极品大片 | 2023年中文无字幕文字 | 久久免费视频99 | 有码中文在线 | 日韩在线首页 | 色婷婷激婷婷情综天天 | 波多野结衣在线观看一区二区三区 | av电影中文字幕在线观看 | 一本一道久久a久久精品蜜桃 | 久久激情视频免费观看 | 久久99国产精品免费 | 日韩高清一二区 | 天天操天天射天天插 | 91探花在线 | 天天爽天天射 | 婷婷丁香色 | 国产 日韩 在线 亚洲 字幕 中文 | 国精产品永久999 | 亚洲国产欧美在线看片xxoo | 婷婷.com| 成人av免费网站 | 91插插插免费视频 | 国产精品免费久久久久 | 一级性生活片 | 手机看片1042| 99在线热播| 午夜av在线电影 | 国产在线一卡 | 四川bbb搡bbb爽爽视频 | 国产三级午夜理伦三级 | 国产精品v欧美精品v日韩 | 中文字幕在线观看的网站 | 免费在线成人av电影 | 精品国产一区二区三区在线观看 | 中文乱码视频在线观看 | 久久伦理电影 | 欧美久久久久久久久 | 国产老熟 | 成年免费在线视频 | 久久免费99精品久久久久久 | 激情影音先锋 | 99精品国产99久久久久久福利 | 激情影音| 欧美成人免费在线 | 日本久久久久久久久久久 | 99在线精品视频观看 | 国产乱对白刺激视频不卡 | 日韩中文在线播放 | 国产精品久久久久久久久久久久午夜片 | 久草视频视频在线播放 | 国产精品久久影院 | 亚洲国产高清在线观看视频 | 日韩亚洲在线视频 | 狠狠网亚洲精品 | 毛片播放网站 | 黄色的网站免费看 | 亚洲aⅴ在线 | 国产日产精品一区二区三区四区的观看方式 | 中文久久精品 | 亚洲手机天堂 | 福利视频午夜 | 米奇狠狠狠888 | 亚洲激情在线观看 | 精品国产三级a∨在线欧美 免费一级片在线观看 | 亚洲午夜精品久久久久久久久 | 韩日精品在线 | 亚洲精品在线网站 | 欧美日韩视频免费看 | 国产色妞影院wwwxxx | 91精品一区二区三区蜜臀 | 国语自产偷拍精品视频偷 | 三级小视频在线观看 | 成 人 黄 色 视频免费播放 | 在线观看视频你懂的 | 81精品国产乱码久久久久久 | 九九在线高清精品视频 | av片无限看 | 久久69av | 日韩高清在线观看 | 亚洲三级毛片 | 福利网在线 | 国产综合在线视频 | 综合色婷婷 | 中文字幕刺激在线 | 日韩中文字幕免费视频 | 成人免费视频网站 | 久久图 | 国产v在线播放 | 免费麻豆视频 | 午夜精品久久久久久 | 99精品区 | 天干啦夜天干天干在线线 | 日韩网站一区二区 | 久久人人爽人人爽人人片 | 色婷婷www| 91成人精品观看 | 国产日韩视频在线观看 | 国产在线超碰 | 亚洲精品中文在线资源 | 黄污在线观看 | 国产香蕉av| 69视频国产 | 精品久久视频 | 国产成人av综合色 | 高潮久久久久久 | 国产精品亚洲片夜色在线 | 欧美a在线免费观看 | 97在线视频观看 | 91久久电影| 国产一区在线免费观看视频 | 免费久久片 | 亚洲精品看片 | 欧美亚洲三级 | 尤物九九久久国产精品的分类 | 亚洲黄网站 | 91精品亚洲影视在线观看 | 香蕉影院在线播放 | 99精品久久久久久久久久综合 | 国产天天综合 | 亚洲三级在线免费观看 | 27xxoo无遮挡动态视频 | 日日爽天天操 | 麻豆影视在线免费观看 | 精品欧美一区二区三区久久久 | 国产精品成久久久久三级 | 日韩免费在线网站 | 激情伊人五月天久久综合 | 99久久久久久久 | 最新在线你懂的 | 久久久免费看视频 | 国产爽视频 | a黄色| 在线草| 国产精品久久电影网 | www.五月婷 | 亚洲精品午夜久久久 | 狠狠做六月爱婷婷综合aⅴ 日本高清免费中文字幕 | 最近更新好看的中文字幕 | 91夫妻自拍 | 在线一二区 | 成人在线视频你懂的 | 日韩在线 | 国产成人精品综合久久久 | 四虎影视8848dvd| 人人插人人看 | 人人舔人人射 | 2024国产在线| 精品中文字幕在线观看 | 国产成人一区二区三区 | 少妇性aaaaaaaaa视频 | 9999在线| 久久久天天操 | 精品久久久国产 | 99综合影院在线 | 亚洲va在线va天堂va偷拍 | 韩日精品在线观看 | 亚洲精品自在在线观看 | 欧美aa在线观看 | www.亚洲黄色 | 欧美a在线免费观看 | 婷婷 综合 色 | 狠狠躁夜夜躁人人爽视频 | 久久久久亚洲精品 | 韩国一区二区三区在线观看 | 四虎永久免费 | 五月激情片 | 国产乱老熟视频网88av | 久久精品国产精品亚洲精品 | 久久精品中文字幕少妇 | 久久精品久久久久 | 天天干天天摸天天操 | 成人av电影免费观看 | 色香天天 | 成人国产精品 | 国产精品手机在线观看 | 在线观看麻豆av | 四虎成人网 | 中文字幕在线免费看线人 | 免费国产一区二区 | 在线视频麻豆 | 久久综合亚洲鲁鲁五月久久 | 国产中文字幕视频在线 | 国产一区 在线播放 | 成人精品国产免费网站 | 国产一区欧美在线 | 91欧美视频网站 | 成人欧美一区二区三区黑人麻豆 | 中文字幕av专区 | 91专区在线观看 | 中文字幕日韩伦理 | 狠狠躁日日躁狂躁夜夜躁av | 黄色在线视频网址 | 视频一区二区免费 | 一区二区三区在线免费观看视频 | 欧美久草视频 | 久久久精品欧美 | 啪啪av在线| 欧美色噜噜 | 日韩黄在线观看 | 免费三级黄 | 日本久久久久久 | 欧美-第1页-屁屁影院 | 黄色一级在线免费观看 | 久久激情五月激情 | 欧美一二三区在线播放 | 国产色综合天天综合网 | 黄色av免费电影 | 日韩视频在线播放 | 国产午夜视频在线观看 | 亚洲香蕉视频 | 免费高清在线一区 | 亚洲色五月 | 玖玖视频| 狂野欧美激情性xxxx欧美 | 成人小视频免费在线观看 | 97超在线| 国产精品久久久久久久久久久久午夜片 | 伊人宗合| 伊人在线视频 | 欧美a级成人淫片免费看 | 亚洲电影一区二区 | 国产在线精品一区二区 | 黄色免费国产 | 99在线视频免费观看 | 在线精品国产 | av免费观看网址 | 精品国精品自拍自在线 | 免费成人在线观看视频 | 国产黄色免费看 | 久精品视频在线 | www麻豆视频 | 又黄又刺激的视频 | 国产不卡一 | 97夜夜澡人人双人人人喊 | av免费电影网站 | 精品视频在线免费观看 | 久久有精品 | 国产精品久久久久久久久久99 | 麻豆视频在线 | 亚洲精品一区二区三区高潮 | 精品在线你懂的 | 视频一区在线播放 | 久久人人艹 | www.色国产 | 日本三级久久久 | 69中文字幕 | a久久久久久 | 国产伦精品一区二区三区无广告 | 成人av在线影视 | 久久99久久久久久 | 久久久国产精品一区二区中文 | 婷婷丁香九月 | 一区二区三区影院 | 欧美一区二区视频97 | 欧美久久久一区二区三区 | 99久久精品国产免费看不卡 | 97成人在线免费视频 | 人人藻人人澡人人爽 | 亚洲一级黄色大片 | 欧美日韩裸体免费视频 | 国产亚洲精品久久久久动 | 色视频一区| 婷婷网在线 | 99免费国产 | 色老板在线 | 国产a级片免费观看 | 激情电影在线观看 | 在线观看岛国片 | 91人人揉日日捏人人看 | 97色资源 | 日韩午夜在线播放 | 黄网在线免费观看 | 一级精品视频在线观看宜春院 | 国产精品人人做人人爽人人添 | 久久天堂影院 | 国产精品福利小视频 | 在线播放一区二区三区 | a成人v在线 | 亚洲精品久久激情国产片 | 亚洲高清在线精品 | 天天综合区 | 久久久久久久久久久久久久免费看 | 99色在线视频 | 在线播放亚洲 | 国产精品丝袜久久久久久久不卡 | 97小视频| 最近中文字幕久久 | 中文字幕成人av | 久久夜色精品亚洲噜噜国4 午夜视频在线观看欧美 | 久久精品久久久久 | 成人黄色大片在线观看 | 国产电影黄色av | 视频直播国产精品 | 日本三级国产 | 久草视频在线看 | 国产91精品一区二区麻豆亚洲 | 香蕉免费在线 | 激情深爱五月 | 不卡国产在线 | 亚洲视频免费在线看 | 美女av免费看 | 久久综合毛片 | 久久免费视频2 | 久久a v视频| 五月天激情在线 | 久久精品久久精品久久精品 | 免费日韩一区二区三区 | 久久久久久中文字幕 | 国产精品久久久久久久久久久久 | 日本黄色免费播放 | 久久99免费 | 久99久在线视频 | 久久久激情网 | 精品国产综合区久久久久久 | 在线免费试看 | 国产永久免费观看 | 国产精品手机播放 | 亚洲天天干 | 欧美日韩精品在线观看 | 97色在线视频 | 久草视频在线新免费 | 国产精品欧美久久久久无广告 | 国产黄色片免费在线观看 | 女人18片毛片90分钟 | 黄色影院在线免费观看 | 天天草综合网 | 午夜精品一区二区三区可下载 | 激情欧美一区二区免费视频 | 人人干人人干人人干 | 免费观看www7722午夜电影 | 嫩嫩影院理论片 | 亚洲一区精品人人爽人人躁 | 亚洲精品视频 | 婷婷丁香狠狠爱 | 毛片3 | 久久综合中文字幕 | 麻豆久久久久 | 亚洲激情综合网 | 亚洲最大av网 | 天天操夜夜曰 | 国产一二三区在线观看 | 国色天香永久免费 | 亚洲人久久久 | 天堂av在线中文在线 | 国产色婷婷在线 | 久久久久久蜜桃一区二区 | 五月婷在线 | 久久精精品视频 | 久久久久久毛片精品免费不卡 | 黄色大全视频 | 国产免费观看高清完整版 | 欧美久久影院 | 玖草影院 | 色综合天天综合 | 日韩成人黄色av | 永久免费精品视频网站 | 天天干天天弄 | 精品久久久亚洲 | 91精品在线免费观看视频 | 国产3p视频| 麻豆国产精品一区二区三区 | 国产精品美女久久久久久久网站 | 天天操夜夜曰 | 日韩亚洲欧美中文字幕 | 国产精品一区二区三区在线看 | 久99热| 国产美女精彩久久 | 精品久久久久久综合日本 | 人人射人人爱 | 四虎成人精品 | av在线电影播放 | 在线观看的av | 亚洲精区二区三区四区麻豆 | 超碰97人人干 | 亚洲国产wwwccc36天堂 | 免费日韩一区二区三区 | 亚洲最大的av网站 | 久久久免费精品视频 | 色激情五月 | 五月婷久 | 成人精品国产 | 色开心 | 久久久九色精品国产一区二区三区 | 欧美日韩一区二区在线观看 | 六月丁香色婷婷 | 国产精品ⅴa有声小说 | 欧美91精品久久久久国产性生爱 | 在线免费观看麻豆 | 在线观看视频免费大全 | av成人在线播放 | 国产精品一区久久久久 | 日韩丝袜在线 | 99精品久久精品一区二区 | 婷婷丁香激情综合 | 久久久在线视频 | 精品国产成人在线影院 | 欧美一区二区三区四区夜夜大片 | 中文字幕在线看视频国产中文版 | www.黄色| 亚洲精品66| 亚洲精品理论片 | www.人人草 | 欧美精品久久久久久久久免 | 国产精品女人网站 | 狠狠的干 | 国产视频99 | 国产亚洲精品久久久久久无几年桃 | 国产黑丝袜在线 | 亚洲a成人v| 中文字幕高清视频 | 四虎www com | 天天色播| 91tv国产成人福利 | 免费在线一区二区三区 | 97超碰在线人人 | 免费在线观看a v | 一区中文字幕在线观看 | 久久夜色精品亚洲噜噜国4 午夜视频在线观看欧美 | 人人爽网站 | 成人欧美一区二区三区黑人麻豆 | 午夜视频在线观看一区二区三区 | 日韩美一区二区三区 | 国产精品久久久久毛片大屁完整版 | 色视频网站在线观看一=区 a视频免费在线观看 | 久久久久久久久毛片 | 在线国产欧美 | 国产一区成人 | 欧美精品中文在线免费观看 | 字幕网在线观看 | av中文字幕网 | 久久夜av| 久久深夜福利免费观看 | 午夜精品福利影院 | 亚洲在线视频免费 | 日韩欧美视频免费看 | 国产精品一区二区精品视频免费看 | 激情五月六月婷婷 | 亚洲成aⅴ人在线观看 | 四虎国产精品免费 | 亚洲精品美女久久久久 | 久久一区二区三区日韩 | 久久精品麻豆 | 四虎在线视频免费观看 | 中文字幕在线观看完整版电影 | 久久久久免费网站 | 国产福利在线免费观看 | 国产精品99久久免费黑人 | 亚洲片在线 | 亚洲精品视频大全 | 欧美精品三级 | 天天色天天综合网 | 精品国产一区二区三区久久久久久 | 国产亚洲字幕 | 五月婷婷色综合 | 国产精品精品国产婷婷这里av | 九九在线播放 | 国产又粗又猛又黄视频 | 91亚洲精品在线观看 | 摸bbb搡bbb搡bbbb| 在线观看色网站 | 午夜三级在线 | 久久精品一二三区 | 曰韩精品| 麻豆你懂的 | 中文字幕成人网 | 亚洲一级片在线观看 | 麻豆高清免费国产一区 | 久久成人免费视频 | 亚洲一区精品人人爽人人躁 | 天天干天天草天天爽 | 91在线看视频 | 免费毛片一区二区三区久久久 | 午夜免费福利视频 | 18国产精品白浆在线观看免费 | 91理论电影 | 午夜12点 | 久久精品亚洲精品国产欧美 | 国产精品久久99综合免费观看尤物 | 日韩网站在线看片你懂的 | 精品免费| 色七七亚洲影院 | 午夜精品一区二区三区在线视频 | 麻豆视频在线免费看 | 国产精品国产毛片 | 天天射网站 | 91经典在线 | 欧美最猛性xxxx | 久草国产精品 | 日本久久影视 | 热久久国产 | 又黄又爽又湿又无遮挡的在线视频 | a在线视频v视频 | 久久66热这里只有精品 | 国产99区| 91av手机在线| 丁香婷五月 | 久久精品99国产国产精 | 国产精品久久久久久高潮 | 在线观看日韩av | 国产区网址 | a黄在线观看 | 夜夜爽88888免费视频4848 | 色姑娘综合天天 | 国产精品不卡视频 | 国产在线美女 | 91黄色小网站 | 亚洲砖区区免费 | 免费av在线网站 | 奇米先锋 | 国产免费观看av | 色干干 | 99视频精品全国免费 | 久久99久久99精品中文字幕 | 中文字幕精品www乱入免费视频 | 在线观看日韩中文字幕 | 午夜精品久久久久久久99婷婷 | 成人在线播放av | 97精品国产91久久久久久久 | 最近中文字幕高清字幕在线视频 | 国产一区二区在线观看免费 | 免费中文字幕在线观看 | 亚洲国产影院 | 在线黄色观看 | 一级黄色大片在线观看 | 九九九九色 | 99爱这里只有精品 | 天天干天天干天天操 | 色多多污污在线观看 | 天天拍夜夜拍 | 久久精品国产一区二区三 | 国产精品久久一区二区三区不卡 | 日韩欧美一区二区三区在线 | 久久国产精品成人免费浪潮 | av免费看在线| 日韩网站一区二区 | 久久久久久久久久影院 | 国产人成在线视频 | 国产高清av免费在线观看 | 成人黄色小说在线观看 | 99精品免费久久久久久久久日本 | 欧美日韩国产一区二区三区 | 国产在线免费av | www夜夜| 欧美日韩国产色综合一二三四 | 成人小视频在线观看免费 | 天天干夜夜想 | 亚洲欧美日韩国产 | 日韩久久精品一区二区三区 | 精品福利国产 | 日本久久久久久科技有限公司 | 久久伊人婷婷 | 欧美日视频 | 精品极品在线 | 久久综合婷婷综合 | 蜜桃av久久久亚洲精品 | 国产精品麻豆免费版 | 欧美大片在线看免费观看 | 99热国产在线中文 | 在线中文字幕av观看 | 久久99精品国产麻豆宅宅 | 欧美激情视频一二区 | 天天色天天操综合 | 中文字幕色婷婷在线视频 | 久久ww| 91黄色成人 | 在线免费高清一区二区三区 | 久久久久国产精品免费免费搜索 | 91精品中文字幕 | 免费看短| 2019中文 | 久久精品视频免费 | 免费高清影视 | 国产精品不卡 | 精品一区二区免费 | 高清视频一区 | 一区三区在线欧 | 久草手机视频 | 午夜av剧场 | 91中文字幕 | 国产偷v国产偷∨精品视频 在线草 | 日本精品一区二区 | 日本中文字幕久久 | 国产一级二级在线播放 | 久久久亚洲麻豆日韩精品一区三区 | 日本老少交 | 国产精品欧美一区二区 | 色香com.| 天天色天天骑天天射 | 狠狠色狠狠色综合日日小说 | 色综合久久精品 | 成人网页在线免费观看 | 久久久精品午夜 | 精品黄色在线 | 国产精品国产自产拍高清av | 日韩欧美不卡 | 久久综合九色99 | 日操操 | 99热在 | 久久久精品一区二区三区 | 中文字幕日韩有码 | 久99久中文字幕在线 | 97色婷婷成人综合在线观看 | 婷婷中文字幕 | 九草视频在线观看 | 激情五月婷婷激情 | 欧美日韩亚洲在线 | 狠狠干狠狠艹 | 中文字幕久久精品 | 国产青青青 | 亚洲精品乱码久久久久 | www.午夜视频 | 久久y | 欧美激情视频一二区 | 成年人免费电影 | 成人av影院在线观看 | 久久精品亚洲精品国产欧美 | 日日干天天操 | av在线播放不卡 | 亚洲精品国产精品国 | 亚洲精品视频免费在线观看 | 成人免费视频在线观看 | 国产三级香港三韩国三级 | 国产日韩在线看 | 特级西西444www大精品视频免费看 | www.天天射.com | 婷婷午夜天 | 欧美成人h版电影 | 成年人看片网站 | 国产一级大片在线观看 | 9幺看片| 国产精品久久久一区二区三区网站 | 日韩在线免费看 | 亚洲黄色影院 | 色视频在线观看 | 国产精品av久久久久久无 | 狠狠色丁香婷婷综合最新地址 | 婷婷激情在线观看 | 奇米影音四色 | 亚洲欧美日韩一二三区 | 久久精品一区二区 | 国产在线视频一区 | 国产高清av免费在线观看 | 国产系列 在线观看 | 国产在线观看a | 日韩欧美在线免费观看 | 国产精品久久一卡二卡 | 久久久久久久国产精品视频 | 91成人在线观看高潮 | 日韩精品免费 | 色综合天天射 | 美女网站一区 | 久久午夜影院 | 特级毛片在线观看 | 美女一级毛片视频 | 黄色aaaaa | 国产视频99 | 亚洲精品一区二区三区新线路 | 97精品国产一二三产区 | 久草免费新视频 | 日韩欧美一区二区在线播放 | 中文字幕中文字幕中文字幕 | 九色视频自拍 | 亚洲精品视频在线观看免费视频 | 久久久国产一区二区三区四区小说 | 超碰在线人 | 欧美一级日韩三级 | 精品中文字幕在线 | 99精品免费视频 | 国产黄av| 欧美日韩精品在线视频 | 丁香视频 | 久久精品国产成人精品 | 欧美伊人网| 国产视频观看 | 日韩欧美精品一区二区三区经典 | 久久视频国产 | 五月婷婷中文 | 欧美乱熟臀69xxxxxx | 欧美一级黄色视屏 | 欧美福利网站 | 热久久免费视频 | 欧美日韩高清在线观看 | 少妇视频一区 | 中文字幕激情 | 久久一区二区免费视频 | 97福利 | 国产精品久久久久久久久久99 | 日韩精品一区二区三区高清免费 | 一区二区电影在线观看 | 天天干天天拍天天操 | 美女视频黄免费 | 久久特级毛片 | 日韩欧美一区二区三区免费观看 | 国际精品久久久久 | 久久精品综合视频 | 欧美成人精品三级在线观看播放 | 免费视频一区 | 国产精品99久久免费黑人 | 国产一区二区三区视频在线 | 国产精品片 | 黄色www免费 | 国产不卡一区二区视频 | 国产高清在线观看av | 97视频人人澡人人爽 | 91在线看黄| 国产91亚洲 | 国产老熟| www.黄色片网站 | 一二三精品视频 | 国产亚洲精品美女 | 日韩国产欧美视频 | 中文字幕av全部资源www中文字幕在线观看 | 欧美色图狠狠干 | 国产一级免费观看视频 | 在线黄网站 | 成人av电影免费 | av中文字幕在线播放 | 久久亚洲综合国产精品99麻豆的功能介绍 | 成人日批视频 | 美国av大片 | 色99网| 97超碰在线久草超碰在线观看 | 亚洲性xxxx | 99国产在线 | www亚洲精品 | 人人艹视频 | 亚洲精品美女在线观看 | 日韩三级.com| 91香蕉国产在线观看软件 | 精品视频成人 | 国产1区在线观看 | 超碰日韩| 久草视频在线播放 | 亚洲伦理一区二区 | 五月在线视频 | 国产在线播放一区二区三区 | 日韩中文字幕国产 | 91精品91| 亚洲精品日韩av | 成人97人人超碰人人99 | 亚洲高清不卡av | 婷婷六月中文字幕 | 99在线精品视频在线观看 | 免费精品视频在线观看 | 99色资源 | 超碰99人人 | 日韩免费高清在线 | 久热这里有精品 | 亚洲欧美国产视频 | 久久久资源网 | 欧美日韩一区二区久久 | 高清免费在线视频 | 色婷婷福利视频 | 最近中文字幕在线中文高清版 | 99精品欧美一区二区蜜桃免费 | 日韩av网页 | 99久久精品国产观看 | 亚洲综合色站 | 精品久久久久国产 | 中文字幕在线观看资源 | 国产性天天综合网 | 九九九热精品免费视频观看 | 97av在线| av网址在线播放 | 国产999精品久久久久久绿帽 | 国产91免费在线观看 | 久久精品久久精品久久精品 | 欧美做受高潮电影o | 又长又大又黑又粗欧美 | 九九免费观看视频 | 五月天国产精品 | 日韩欧美精品在线观看视频 | 婷婷六月丁香激情 | 免费观看丰满少妇做爰 | 精品久久在线 | 久久精品香蕉视频 | 欧美一二三区在线观看 | 精品久久久久久亚洲综合网 | 国产久草在线观看 | 亚洲国产片色 | 亚洲日韩欧美视频 | 最新久久久| av短片在线观看 | 国产不卡网站 | 在线观看视频黄 | 九九热免费在线视频 | av解说在线 | 久久露脸国产精品 | 亚洲电影一级黄 | 国产手机在线观看 | 麻豆传媒在线免费看 | 日本在线视频网址 | 91色吧| 久久久免费看片 | 园产精品久久久久久久7电影 | 午夜手机看片 | 中文字幕欧美日韩va免费视频 | 日b视频国产 | 狠狠插天天干 | 色婷婷久久久 | 国产精品美女久久久久久久久久久 | 国产免费国产 | 手机在线永久免费观看av片 | 亚洲三级视频 | 在线观看不卡的av | 不卡的av在线播放 | 久久你懂得| a级片久久| 久久99久久99精品 | 成人在线一区二区 | 五月婷婷狠狠 | 亚洲国产精品久久久 | 国产中文字幕在线视频 | 久久精品视频免费播放 | 蜜臀一区二区三区精品免费视频 | 婷婷六月天在线 | 伊人亚洲综合网 | 国产一区二区久久久 | 992tv在线 | 又爽又黄又无遮挡网站动态图 | 亚洲午夜激情网 | 日韩在线免费视频 | 999成人网| 热久久这里只有精品 | 91在线观看高清 | 99热超碰| 国产专区日韩专区 | av网站在线观看免费 | 午夜美女wwww | 天天色天天色天天色 | 久久99国产精品久久99 | 中文字幕成人 | 伊人狠狠色| 日日操操 | 欧美小视频在线观看 | 久久国产精品一区二区三区 | 亚洲美女精品区人人人人 | 精品美女在线观看 | 2018好看的中文在线观看 | 亚洲天堂自拍视频 | 狠狠躁日日躁 | 亚洲砖区区免费 | 亚洲精品www. | 亚洲欧美国产精品va在线观看 | 久久综合中文字幕 | 中文字幕 成人 | 日韩精品一区二区三区电影 | 狠狠色丁香婷婷综合久小说久 | 制服丝袜天堂 | 久久国产成人午夜av影院宅 | 国产精品乱码一区二区视频 | av高清在线 | 成人av电影在线观看 | 国产亚洲精品日韩在线tv黄 | 亚洲三级网 | 美女网站在线免费观看 | 成人观看视频 | 免费高清看电视网站 | 日韩欧美在线观看一区 | 久久一久久 | 安徽妇搡bbbb搡bbbb | www黄色| 中文字幕在线第一页 | 色婷婷国产 | 久久精品视频免费 | 欧洲在线免费视频 | 乱男乱女www7788 | 久久高清毛片 | 久久99久久久久久 | 全黄网站 | 国产精品九九九 | 在线国产一区二区三区 | 欧美色一色| 精品 激情| 亚洲 欧洲av | 国产99久久九九精品免费 | 99在线高清视频在线播放 | 黄色www免费| 日本黄色一级电影 | 三级动态视频在线观看 | 麻豆国产在线视频 | 成年人免费在线看 | 成人av在线一区二区 | 成人高清在线观看 | av成人免费在线观看 | 国产亚洲精品久久久久久网站 | 久久久免费精品国产一区二区 | 国产高清视频免费 | 91色九色| 日本中文字幕在线电影 | 亚洲五月六月 | 色综合久久久久久中文网 | 高潮久久久久久 | 中文字幕在线看视频国产 | 91黄色免费网站 | 97香蕉超级碰碰久久免费软件 | 免费电影一区二区三区 | 毛片一级免费一级 | 99国产精品久久久久久久久久 | 97成人在线 | 亚洲天堂在线观看完整版 | 亚洲精品综合在线 | 日韩三级一区 | 99爱视频| 久久久久久久久久久综合 | 韩国在线一区 | 中文字幕一区二区三区四区视频 | 国产做a爱一级久久 | 美女黄视频免费看 | 激情综合网在线观看 | 2023av在线| 在线观看aa | 中文字幕三区 | 久久综合狠狠综合 | 日韩一区二区三区高清免费看看 | 最新中文字幕在线播放 | 在线免费视频你懂的 | 国产一区二区在线观看免费 | 日韩丝袜视频 | avwww在线观看 | adc在线观看 | 中文字幕色婷婷在线视频 |