精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

精通Hibernate:第一個Hibernate應用

開發 后端
本文詳解了創建Hibernate應用所用到的知識點,包括Helloapp應用的結構、Hibernate的配置文件、創建持久化類Customer、創建數據庫Schema 、創建對象-關系映射文件Customer.hbm.xml以及創建BusinessService類。

一、在Java應用中使用Hibernate的步驟

  • 創建Hibernate的配置文件
  • 創建持久化類
  • 創建對象-關系映射文件
  • 通過Hibernate API編寫訪問數據庫的代碼

二、Helloapp應用的結構

三、Hibernate的配置文件(hibernate.properties)

  1. hibernate.dialect=org.hibernate.dialect.MySQLDialect  
  2. hibernate.connection.driver_class=com.mysql.jdbc.Driver  
  3. hibernate.connection.url=jdbc:mysql://localhost:3306/SAMPLEDB  
  4. hibernate.connection.username=root  
  5. hibernate.connection.password=1234 
  6. hibernate.show_sql=true 

四、創建持久化類Customer

  • 持久化類符合JavaBean的規范,包含一些屬性,以及與之對應的getXXX()和setXXX()方法。
  • 持久化類有一個id屬性,用來惟一標識Customer類的每個對象。在面向對象術語中,這個id屬性被稱為對象標識符(OID,Object Identifier),通常它都用整數表示
  • Hibernate要求持久化類必須提供一個不帶參數的默認構造方法
  1. package mypack;  
  2. import java.io.Serializable;  
  3. import java.sql.Date;  
  4. import java.sql.Timestamp;  
  5.  
  6. public class Customer implements Serializable {  
  7.   private Long id;  
  8.   private String name;  
  9.   private String email;  
  10.   private String password;  
  11.   private int phone;  
  12.   private String address;  
  13.   private char sex;  
  14.   private boolean married;  
  15.   private String description;  
  16.   private byte[] image;  
  17.   private Date birthday;  
  18.   private Timestamp registeredTime;  
  19.  
  20.   public Customer(){}  
  21.  
  22.   public Long getId(){  
  23.     return id;  
  24.   }  
  25.  
  26.   private void setId(Long id){  
  27.     this.id = id;  
  28.   }  
  29.  
  30.   public String getName(){  
  31.     return name;  
  32.   }  
  33.  
  34.   public void setName(String name){  
  35.     this.name=name;  
  36.   }  
  37.  
  38.   public String getEmail(){  
  39.     return email;  
  40.   }  
  41.  
  42.   public void setEmail(String email){  
  43.     this.email =email ;  
  44.   }  
  45.  
  46.   public String getPassword(){  
  47.     return password;  
  48.   }  
  49.  
  50.   public void setPassword(String password){  
  51.       this.password =password ;  
  52.   }  
  53.  
  54.   public int getPhone(){  
  55.     return phone;  
  56.   }  
  57.  
  58.   public void setPhone(int phone){  
  59.     this.phone =phone ;  
  60.   }  
  61.  
  62.   public String getAddress(){  
  63.     return address;  
  64.   }  
  65.  
  66.   public void setAddress(String address){  
  67.     this.address =address ;  
  68.   }  
  69.   public char getSex(){  
  70.     return sex;  
  71.   }  
  72.  
  73.   public void setSex(char sex){  
  74.     this.sex =sex ;  
  75.   }  
  76.  
  77.   public boolean isMarried(){  
  78.     return married;  
  79.   }  
  80.  
  81.   public void setMarried(boolean married){  
  82.     this.married =married ;  
  83.   }  
  84.  
  85.   public String getDescription(){  
  86.       return description;  
  87.   }  
  88.  
  89.   public void setDescription(String description){  
  90.       this.description =description ;  
  91.   }  
  92.  
  93.   public byte[] getImage() {  
  94.         return this.image;  
  95.   }  
  96.  
  97.   public void setImage(byte[] image) {  
  98.         this.image = image;  
  99.   }  
  100.  
  101.   public Date getBirthday() {  
  102.         return this.birthday;  
  103.   }  
  104.  
  105.   public void setBirthday(Date birthday) {  
  106.         this.birthday = birthday;  
  107.   }  
  108.  
  109.   public Timestamp getRegisteredTime() {  
  110.         return this.registeredTime;  
  111.   }  
  112.  
  113.   public void setRegisteredTime(Timestamp registeredTime) {  
  114.         this.registeredTime = registeredTime;  
  115.   }  
  116.  

注意:

  • getXXX()和setXXX()方法可以采用任意的訪問級別,他的命名規則必須符合特定的命名規則,“get”和“set”后面緊跟屬性的名字,并且屬性名的首字母為大寫,如name屬性的get方法為getName()。
  • 如果持久化類的屬性為boolean類型,那么它的get方法名可以用get做前綴也可以用is做前綴。

五、創建數據庫Schema

  1. drop database if exists SAMPLEDB;  
  2. create database SAMPLEDB;  
  3. use SAMPLEDB;  
  4.  
  5. create table CUSTOMERS (  
  6.   ID bigint not null primary key,  
  7.   NAME varchar(15) not null,  
  8.   EMAIL varchar(128) not null,  
  9.   PASSWORD varchar(8) not null,    
  10.   PHONE int ,    
  11.   ADDRESS varchar(255),  
  12.   SEX char(1) ,  
  13.   IS_MARRIED bit,  
  14.   DESCRIPTION text,  
  15.   IMAGE blob,  
  16.   BIRTHDAY date,  
  17.   REGISTERED_TIME timestamp  
  18. ); 

#p#

六、創建對象-關系映射文件Customer.hbm.xml

  1. <?xml version="1.0"?>  
  2. <!DOCTYPE hibernate-mapping PUBLIC"-//Hibernate/Hibernate Mapping DTD 3.0//EN" "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">  
  3.  
  4. <hibernate-mapping>  
  5.   <class name="mypack.Customer" table="CUSTOMERS">  
  6.     <id name="id" column="ID" type="long">  
  7.       <generator class="increment"/>  
  8.     </id>  
  9.     <property name="name"  column="NAME"  type="string" not-null="true" />    
  10.     <property name="email"     column="EMAIL"     type="string" not-null="true" />   
  11.     <property name="password"  column="PASSWORD"  type="string" not-null="true"/>   
  12.     <property name="phone"     column="PHONE"     type="int" />   
  13.     <property name="address"   column="ADDRESS"   type="string" />   
  14.     <property name="sex"       column="SEX"       type="character"/>    
  15.     <property name="married"   column="IS_MARRIED"  type="boolean"/>        
  16.     <property name="description"   column="DESCRIPTION"  type="text"/>        
  17.     <property name="image"         column="IMAGE"        type="binary"/>  
  18.     <property name="birthday"      column="BIRTHDAY"     type="date"/>  
  19.     <property name="registeredTime" column="REGISTERED_TIME"  type="timestamp"/>    
  20.   </class>  
  21. </hibernate-mapping> 

<id>元素映射OID

<generator>子元素用來設定標識符生成器。Hibernate提供了提供了多種內置的實現。

<property>元素映射值類型屬性

  • name屬性:指定持久化類的屬性的名字。
  • column屬性:指定與類的屬性映射的表的字段名。
  • type屬性:指定Hibernate映射類型。Hibernate映射類型是Java類型與SQL類型的橋梁。

采用XML文件來配置對象-關系映射的優點:

  • Hibernate既不會滲透到上層域模型中,也不會滲透到下層數據模型中。
  • 軟件開發人員可以獨立設計域模型,不必強迫遵守任何規范。
  • 數據庫設計人員可以獨立設計數據模型,不必強迫遵守任何規范。
  • 對象-關系映射不依賴于任何程序代碼,如果需要修改對象-關系映射,只需修改XML文件,不需要修改任何程序,提高了軟件的靈活性,并且使維護更加方便。

#p#

七、創建BusinessService類

 

  1. package mypack;  
  2.  
  3. import javax.servlet.*;  
  4. import org.hibernate.*;  
  5. import org.hibernate.cfg.Configuration;  
  6. import java.io.*;  
  7. import java.sql.Date;  
  8. import java.sql.Timestamp;  
  9. import java.util.*;  
  10.  
  11. public class BusinessService{  
  12.   public static SessionFactory sessionFactory;  
  13.     
  14.   /** 初始化Hibernate,創建SessionFactory實例 */ 
  15.   static{  
  16.     try{  
  17.       // 根據默認位置的Hibernate配置文件的配置信息,創建一個Configuration實例  
  18.       Configuration config = new Configuration();  
  19.       //加載Customer類的對象-關系映射文件  
  20.       config.addClass(Customer.class);  
  21.       // 創建SessionFactory實例 */  
  22.       sessionFactory = config.buildSessionFactory();  
  23.     }catch(RuntimeException e){e.printStackTrace();throw e;}  
  24.   }  
  25.     
  26.   /** 查詢所有的Customer對象,然后調用printCustomer()方法打印Customer對象信息 */ 
  27.   public void findAllCustomers(ServletContext context,PrintWriter out) throws Exception{  
  28.     Session session = sessionFactory.openSession(); //創建一個會話  
  29.     Transaction tx = null;  
  30.     try {  
  31.       tx = session.beginTransaction(); //開始一個事務  
  32.       Query query=session.createQuery("from Customer as c order by c.name asc");  
  33.       List customers=query.list();  
  34.       for (Iterator it = customers.iterator(); it.hasNext();) {  
  35.          printCustomer(context,out,(Customer) it.next());  
  36.       }  
  37.  
  38.       tx.commit(); //提交事務  
  39.  
  40.     }catch (RuntimeException e) {  
  41.       if (tx != null) {  
  42.          tx.rollback();  
  43.       }  
  44.       throw e;  
  45.     } finally {  
  46.        session.close();  
  47.     }  
  48.   }  
  49.  
  50.   /** 持久化一個Customer對象 */ 
  51.   public void saveCustomer(Customer customer){  
  52.     Session session = sessionFactory.openSession();  
  53.     Transaction tx = null;  
  54.     try {  
  55.       tx = session.beginTransaction();  
  56.       session.save(customer);  
  57.       tx.commit();  
  58.  
  59.     }catch (RuntimeException e) {  
  60.       if (tx != null) {  
  61.         tx.rollback();  
  62.       }  
  63.       throw e;  
  64.     } finally {  
  65.       session.close();  
  66.     }  
  67.   }  
  68.  
  69.   /** 按照OID加載一個Customer對象,然后修改它的屬性 */ 
  70.   public void loadAndUpdateCustomer(Long customer_id,String address){  
  71.     Session session = sessionFactory.openSession();  
  72.     Transaction tx = null;  
  73.     try {  
  74.       tx = session.beginTransaction();  
  75.  
  76.       Customer c=(Customer)session.get(Customer.class,customer_id);  
  77.       c.setAddress(address);  
  78.       tx.commit();  
  79.  
  80.     }catch (RuntimeException e) {  
  81.       if (tx != null) {  
  82.         tx.rollback();  
  83.       }  
  84.       throw e;  
  85.     } finally {  
  86.       session.close();  
  87.     }  
  88.   }  
  89.  
  90.   /**刪除Customer對象 */ 
  91.   public void deleteCustomer(Customer customer){  
  92.     Session session = sessionFactory.openSession();  
  93.     Transaction tx = null;  
  94.     try {  
  95.       tx = session.beginTransaction();  
  96.       session.delete(customer);  
  97.       tx.commit();  
  98.  
  99.     }catch (RuntimeException e) {  
  100.       if (tx != null) {  
  101.         tx.rollback();  
  102.       }  
  103.       throw e;  
  104.     } finally {  
  105.       session.close();  
  106.     }  
  107.   }  
  108.     
  109.   /** 選擇向控制臺還是Web網頁輸出Customer對象的信息 */ 
  110.   private void printCustomer(ServletContext context,PrintWriter out,Customer customer)throws Exception{  
  111.      if(context!=null)  
  112.        printCustomerInWeb(context,out,customer);  
  113.      else 
  114.        printCustomer( out,customer);  
  115.   }  
  116.     
  117.   /** 把Customer對象的信息輸出到控制臺,如DOS 控制臺*/ 
  118.   private void printCustomer(PrintWriter out,Customer customer)throws Exception{  
  119.     byte[] buffer=customer.getImage();  
  120.     FileOutputStream fout=new FileOutputStream("photo_copy.gif");  
  121.     fout.write(buffer);  
  122.     fout.close();  
  123.  
  124.     out.println("------以下是"+customer.getName()+"的個人信息------");  
  125.     out.println("ID: "+customer.getId());  
  126.     out.println("口令: "+customer.getPassword());  
  127.     out.println("E-Mail: "+customer.getEmail());  
  128.     out.println("電話: "+customer.getPhone());  
  129.     out.println("地址: "+customer.getAddress());  
  130.     String sex=customer.getSex()=='M'"男":"女";  
  131.     out.println("性別: "+sex);  
  132.     String marriedStatus=customer.isMarried()? "已婚":"未婚";  
  133.     out.println("婚姻狀況: "+marriedStatus);  
  134.     out.println("生日: "+customer.getBirthday());  
  135.     out.println("注冊時間: "+customer.getRegisteredTime());  
  136.     out.println("自我介紹: "+customer.getDescription());  
  137.  
  138.   }  
  139.  
  140.   /** 把Customer對象的信息輸出到動態網頁 */ 
  141.   private void printCustomerInWeb(ServletContext context,PrintWriter out,Customer customer)throws Exception{  
  142.     //保存照片  
  143.     byte[] buffer=customer.getImage();  
  144.     String path=context.getRealPath("/");  
  145.     FileOutputStream fout=new FileOutputStream(path+"photo_copy.gif");  
  146.     fout.write(buffer);  
  147.     fout.close();  
  148.  
  149.     out.println("------以下是"+customer.getName()+"的個人信息------"+"<br>");  
  150.     out.println("ID: "+customer.getId()+"<br>");  
  151.     out.println("口令: "+customer.getPassword()+"<br>");  
  152.     out.println("E-Mail: "+customer.getEmail()+"<br>");  
  153.     out.println("電話: "+customer.getPhone()+"<br>");  
  154.     out.println("地址: "+customer.getAddress()+"<br>");  
  155.     String sex=customer.getSex()=='M'"男":"女";  
  156.     out.println("性別: "+sex+"<br>");  
  157.     String marriedStatus=customer.isMarried()? "已婚":"未婚";  
  158.     out.println("婚姻狀況: "+marriedStatus+"<br>");  
  159.     out.println("生日: "+customer.getBirthday()+"<br>");  
  160.     out.println("注冊時間: "+customer.getRegisteredTime()+"<br>");  
  161.     out.println("自我介紹: "+customer.getDescription()+"<br>");  
  162.     out.println("<img src='photo_copy.gif' border=0><p>");  
  163.   }  
  164.    public void test(ServletContext context,PrintWriter out) throws Exception{  
  165.  
  166.     Customer customer=new Customer();  
  167.     customer.setName("Tom");  
  168.     customer.setEmail("tom@yahoo.com");  
  169.     customer.setPassword("1234");  
  170.     customer.setPhone(55556666);  
  171.     customer.setAddress("Shanghai");  
  172.     customer.setSex('M');  
  173.     customer.setDescription("I am very honest.");  
  174.       
  175.     //設置Customer對象的image屬性,它是字節數組,存放photo.gif文件中的二進制數據  
  176.     //photo.gif文件和BusinessService.class文件位于同一個目錄下   
  177.     InputStream in=this.getClass().getResourceAsStream("photo.gif");  
  178.     byte[] buffer = new byte[in.available()];  
  179.     in.read(buffer);  
  180.     customer.setImage(buffer);  
  181.     //設置Customer對象的birthday屬性,它是java.sql.Date類型   
  182.     customer.setBirthday(Date.valueOf("1980-05-06"));  
  183.  
  184.     saveCustomer(customer);  
  185.  
  186.     findAllCustomers(context,out);  
  187.     loadAndUpdateCustomer(customer.getId(),"Beijing");  
  188.     findAllCustomers(context,out);  
  189.     deleteCustomer(customer);  
  190.   }  
  191.  
  192.   public static void main(String args[]) throws Exception {  
  193.     new BusinessService().test(null,new PrintWriter(System.out,true));  
  194.     sessionFactory.close();  
  195.   }  

 

 

#p#

saveCustomer()方法

該方法調用Session的save()方法,把Customer對象持久化到數據庫中。

  1. tx = session.beginTransaction();  
  2.  
  3.        session.save(customer);  
  4.  
  5.        tx.commit(); 

當運行session.save()方法時,Hibernate執行以下SQL語句:

  1. insert into CUSTOMERS (ID, NAME, EMAIL, PASSWORD, PHONE, ADDRESS, SEX,  
  2.  
  3.       IS_MARRIED,DESCRIPTION, IMAGE, BIRTHDAY, REGISTERED_TIME)   
  4.  
  5.       values(1,'Tom','tom@yahoo.com','1234',55556666,'Shanghai','M',0,'I am very honest.', ☺,'1980-05-06',null

在test()方法中并沒有設置Customer對象的id屬性,Hibernate會根據映射文件的配置,采用increment標識符生成器自動以遞增的方式為OID賦值。在Customer.hbm.xml文件中相關的映射代碼如下:

  1. <id name="id" column="ID" type="long">  
  2.  
  3.      <generator class="increment"/>  
  4.  
  5.   </id> 

findAllCustomers()方法

該方法通過Query接口查詢所有的Customer對象。

  1. tx = session.beginTransaction(); //開始一個事務  
  2.  
  3. Query query=session.createQuery("from Customer as c order by c.name asc");  
  4.  
  5. List customers=query.list();  
  6.  
  7. for (Iterator it = customers.iterator(); it.hasNext();) {  
  8.  
  9.   printCustomer(context,out,(Customer) it.next());  
  10.  
  11. }  
  12.  
  13. tx.commit(); //提交事務 

Session的createQuery()方法的參數“from Customer as c order by c.name asc”使用的是Hibernate查詢語言。運行Query.list()方法時, Hibernate執行以下SQL語句:

  1. select * from CUSTOMERS order by NAME asc; 

loadAndUpdateCustomer ()方法

該方法調用Session的get()方法,加載Customer對象,然后再修改Customer對象的屬性。

  1. tx = session.beginTransaction();  
  2.  
  3.       Customer c=(Customer)session.get(Customer.class,customer_id);  
  4.  
  5.       c.setAddress(address); //修改內存中Customer對象的address屬性  
  6.  
  7.       tx.commit(); 

以上代碼先調用Session的get()方法,它按照參數指定的OID從數據庫中檢索出匹配的Customer對象,Hibernate會執行以下SQL語句:

  1. select * from CUSTOMERS where ID=1

loadAndUpdateCustomer()方法接著修改Customer對象的address屬性。那么,Hibernate會不會同步更新數據庫中相應的CUSTOMERS表的記錄呢?答案是肯定的。Hibernate采用臟檢查機制,按照內存中的Customer對象的狀態的變化,來同步更新數據庫中相關的數據,Hibernate會執行以下SQL語句:

  1. update CUSTOMERS set NAME="Tom",EMAIL="Tom@yahoo.com"…ADDRESS="Beijing"…  
  2.  
  3. where ID=1

盡管只有Customer對象的address屬性發生了變化,但是Hibernate執行的update語句中會包含所有的字段。

deleteCustomer()方法

該方法調用Session的delete()方法,刪除特定的Customer對象:

  1. tx = session.beginTransaction();  
  2.  
  3.       session.delete(customer);  
  4.  
  5.       tx.commit(); 

運行session.delete()方法時,Hibernate根據Customer對象的OID,執行以下SQL delete語句:

  1. delete from CUSTOMERS where ID=1;&nbsp; 

八、效果圖

原文鏈接:http://blog.csdn.net/yu422560654/article/details/7028748 

【編輯推薦】

  1. Hibernate緩存何時使用和如何使用
  2. Hibernate連接Mysql中文亂碼處理
  3. Hibernate配置要點詳談
  4. Hibernate配置文件和映射元素解釋
  5. 詳解Hibernate攔截器與事件監聽器
責任編輯:林師授 來源: yu422560654的博客
相關推薦

2009-06-26 16:07:43

MyEclipse開發Hibernate程序

2012-02-08 14:24:35

HibernateJava

2009-09-25 10:25:54

Hibernate緩存

2021-04-07 13:38:27

Django項目視圖

2010-07-30 14:58:06

Flex應用

2023-05-19 08:49:58

SQLAlchemy數據庫

2018-08-22 17:32:45

2020-11-13 07:08:51

Spring Boot應用Spring

2012-02-08 12:17:38

HibernateJava

2012-02-08 13:34:08

HibernateJava

2015-04-15 11:28:04

Apple Watch殺手應用

2011-06-08 10:01:36

Windows Pho 應用程序

2009-05-13 09:20:12

Google App 應用收費

2011-06-08 10:24:38

Windows Pho 應用程序

2012-02-08 14:01:18

HibernateJava

2011-03-21 14:24:13

Debian 6

2011-03-03 21:04:08

bug程序員

2013-01-14 09:44:58

JavaScriptJSJS框架

2013-06-14 17:16:44

WP開發Windows PhoWP應用

2015-05-19 17:02:07

應用交付深信服
點贊
收藏

51CTO技術棧公眾號

日韩欧美精品在线观看视频| 日本亚洲欧洲色| 日本77777| 羞羞的视频在线看| 91在线码无精品| 国产精品老女人视频| 三级在线观看免费大全| 清纯唯美亚洲经典中文字幕| 欧美亚洲国产一区二区三区| 男女爱爱视频网站| 午夜小视频福利在线观看| 国产精品传媒精东影业在线| 欧美一区二区三区在线观看视频| 欧美激情第六页| 国产九九热视频| 很黄的网站在线观看| 国产福利精品一区| 精品国产百合女同互慰| 先锋影音欧美| 亚洲精品久久久久avwww潮水| 久久蜜桃av一区二区天堂| 精品国产99国产精品| 久久精品免费一区二区| 99reav在线| 福利一区福利二区| 国产精品视频大全| 国产超碰人人爽人人做人人爱| 午夜精品久久久久久久爽| 亚洲情侣在线| 国产精品sm| 国产乱码精品一区二区三区av | 日韩精品视频一区二区在线观看| 九九九九精品九九九九| 日韩不卡视频在线| 亚洲国产一成人久久精品| 亚洲欧洲中文天堂| 亚洲啪av永久无码精品放毛片| 精品亚洲a∨| 日本高清无吗v一区| 丁香花在线影院观看在线播放| 久久亚洲天堂| 中文乱码免费一区二区| 久久国产精彩视频| 欧美精品久久久久久久自慰| 在线观看a视频| 26uuu色噜噜精品一区二区| 91九色蝌蚪成人| 伊人网免费视频| 肉肉av福利一精品导航| 韩国欧美亚洲国产| 精品无码人妻一区二区三| 香蕉综合视频| 久久久精品国产| 婷婷激情四射网| 天天影视综合| 久久久av网站| 国产美女久久久久久| 不卡一区2区| 在线成人一区二区| 成人性生交大片免费看无遮挡aⅴ| 一本久久青青| 亚洲色图激情小说| 国产熟女一区二区| 在线观看操人| 欧美三级不卡| 久久亚洲国产成人| 亚洲精品久久久久久国| 91视频久久| 精品国产一区二区三区久久久| 国产精品一区二区亚洲| 天天做天天爱综合| 日韩视频精品在线| 青青操视频在线播放| 欧美日韩网址| 欧美亚洲午夜视频在线观看| 黄色在线观看国产| 欧美资源在线| 国产精品久久久久久久久影视| 中文字幕日本人妻久久久免费| 天堂av在线一区| 国产一区二区香蕉| 亚洲爱爱综合网| 99热这里都是精品| 日韩欧美在线观看强乱免费| 午夜老司机在线观看| 国产精品久久久久久久| 色偷偷9999www| 欧美三级在线免费观看| 亚洲精品精选| 国产精品夜间视频香蕉| av综合在线观看| 91视频com| 亚洲精品中字| 成人超碰在线| 欧美性视频一区二区三区| 污免费在线观看| 色婷婷久久久| 久久九九精品99国产精品| 日本污视频在线观看| 日韩电影免费在线| 91高跟黑色丝袜呻吟在线观看| 色婷婷av一区二区三| 欧美国产一区在线| 又大又硬又爽免费视频| 久久久人成影片一区二区三区在哪下载| 欧美日本韩国一区| ass精品国模裸体欣赏pics| 不卡视频在线| 2019av中文字幕| 国产精品久久久久久久久毛片| 成人一区二区三区中文字幕| 日韩精品不卡| 国内老司机av在线| 欧美色偷偷大香| 久久人妻少妇嫩草av无码专区| 日韩精品诱惑一区?区三区| 久久久久久69| 国产一区二区视频免费观看 | 亚洲视频在线一区| 久久久久久久久久久福利| 亚洲午夜免费| 日韩在线观看免费高清| 青青青国产在线| 国精品**一区二区三区在线蜜桃| 日本在线播放不卡| 欧美13videosex性极品| 日韩欧美一级片| 免费污网站在线观看| 亚洲精品1234| 91视频在线免费观看| 午夜视频在线免费观看| 色哟哟在线观看一区二区三区| 中文字幕在线视频日韩| 久久精品在线观看视频| 亚洲免费网站| 国产一区二区三区色淫影院| av中文字幕在线观看| 欧美日韩一区中文字幕| 成人免费无遮挡无码黄漫视频| 尹人成人综合网| 99精品欧美一区二区三区| 里番在线观看网站| 精品视频一区二区不卡| 国产真实乱人偷精品人妻| 国产欧美大片| 精品午夜一区二区三区| eeuss鲁一区二区三区| 日韩三级高清在线| 极品盗摄国产盗摄合集| 韩国午夜理伦三级不卡影院| 综合色婷婷一区二区亚洲欧美国产| 日韩欧美一区二区三区在线观看 | 亚洲精品成人无码毛片| 欧亚精品一区| 一区二区三区不卡视频在线观看| 午夜在线观看av| 少妇精品久久久一区二区三区| 97久久超碰福利国产精品…| 欧美h视频在线观看| 久草在线网址| 日韩欧美精品网站| 亚洲最大成人网站| 亚洲韩日在线| 久久大片网站| 日韩av大片站长工具| 亚洲成色999久久网站| 国产精品扒开腿做爽爽| 日韩精品免费视频人成| 手机看片福利永久国产日韩| 玖玖精品在线| 免费97视频在线精品国自产拍| 99视频国产精品免费观看a | 精品九九九九| 在线精品亚洲欧美日韩国产| 亚洲嫩模很污视频| 中文字幕在线观看精品| 欧美日韩一区二区在线观看 | 尤物在线免费视频| 国产一区二区三区国产| 黄黄视频在线观看| 136国产福利精品导航网址应用| 久久久免费在线观看| 深夜福利在线观看直播| 欧美丝袜丝交足nylons图片| 九九热视频在线免费观看| 国产激情视频一区二区在线观看| 欧美视频在线免费播放| 国产一区二区三区电影在线观看| 国产在线日韩在线| 爱看av在线入口| 亚洲天堂av电影| 国产叼嘿视频在线观看| 日韩欧美在线视频日韩欧美在线视频| 亚洲一级黄色录像| 国产激情精品久久久第一区二区| 91精品91久久久中77777老牛| 日韩免费看片| 日韩精品专区在线| 国产精品成人网站| 国产区在线观看成人精品| 永久免费看片在线观看| 三级在线观看一区二区| 隔壁人妻偷人bd中字| 成人亚洲一区| 精品乱色一区二区中文字幕| 亚洲国产天堂| 欧美亚洲另类激情另类| 99在线视频观看| 日本在线视频www| 激情久久99| 97视频在线观看免费| 成年在线观看免费人视频| 精品国产一区二区亚洲人成毛片 | 香蕉久久一区二区三区| 欧美三区在线视频| 日本天堂网在线| 精品久久久久久无| 国产chinese中国hdxxxx| 日韩和欧美一区二区| 日韩专区第三页| 日韩一区欧美| 欧美日韩精品免费观看视一区二区| 国产一区一区| 国产精品丝袜高跟| 高清电影一区| 538国产精品视频一区二区| 亚洲人成色77777| 国内精品久久久久国产盗摄免费观看完整版 | 天堂成人免费av电影一区| 欧美激情视频免费看| 欧美激情视频一区二区三区免费| 亚洲精品人成| 欧洲视频一区| 麻豆精品蜜桃一区二区三区| aiai久久| www.av一区视频| 日韩视频一二区| 91久久在线观看| 亚洲欧美综合久久久久久v动漫| 国产精品久久激情| av在线日韩| 国产精品欧美日韩久久| 国产亚洲一区二区手机在线观看 | 国产v日产∨综合v精品视频| 亚洲在线观看网站| 国产一区二区网址| 制服丝袜中文字幕第一页| 麻豆国产欧美日韩综合精品二区 | 青青草原免费观看| 亚洲视频综合在线| 国产大学生自拍| 亚洲精品久久久久久国产精华液| 丝袜美腿小色网| 亚洲精品高清在线观看| 久久亚洲av午夜福利精品一区| 一二三区精品福利视频| 久久这里只有精品免费| 亚洲无人区一区| 91久久国产视频| 精品久久久久久久中文字幕 | 成人免费无遮挡无码黄漫视频| 国产亚洲综合av| 中文字幕在线观看二区| 成人欧美一区二区三区1314| 91久久国产综合| 亚洲最大色网站| 日韩欧美一级视频| 在线看国产日韩| 一级片免费网站| 日韩欧美不卡在线观看视频| 日本高清视频www| 亚洲精品自产拍| 思思99re6国产在线播放| 久久成人18免费网站| 91福利区在线观看| 国产精品18久久久久久麻辣| 日本国产一区| 国产精品手机视频| 国产一区国产二区国产三区| 伊人久久青草| 一区二区三区在线观看www| 欧美日本二区| www.国产区| 国产一区二区三区免费播放| 国产白袜脚足j棉袜在线观看| 久久综合久久久久88| 秋霞欧美一区二区三区视频免费| 亚洲影院久久精品| 中文字幕av第一页| 日韩女优av电影在线观看| 青青草视频在线观看| 日韩最新中文字幕电影免费看| 超碰97国产精品人人cao| 国产91精品最新在线播放| 玖玖玖电影综合影院| 免费亚洲精品视频| 亚洲最新av| 国产精彩免费视频| 国产成人免费网站| 成人性生交大片免费看无遮挡aⅴ| 一区二区成人在线| 亚洲天堂网在线视频| 亚洲国产精品小视频| 蜜桃视频网站在线观看| 欧美一级视频免费在线观看| 成人免费91| 日韩精品欧美专区| 亚洲人成久久| 黄色a级三级三级三级| 久久久久久影视| 国产精品18p| 欧美日韩国产首页在线观看| 性xxxx视频| 欧美高清激情视频| 日本成人在线网站| 任我爽在线视频精品一| 亚洲黄色av| 国内av免费观看| 国产精品久久久久影院亚瑟| 五月天综合激情网| 亚洲精品在线电影| 国产美女在线观看| 国产精品最新在线观看| 蜜桃一区二区| 国产伦精品一区二区三区四区视频_| 国产精品一级片| 97在线观看免费高| 欧美精品在欧美一区二区少妇 | 日韩一区二区三区xxxx| 人人视频精品| 欧美极品一区二区| 国产亚洲综合精品| 亚洲黄色免费在线观看| 一区二区三区欧美| www.午夜激情| 久久91超碰青草是什么| 日本免费一区二区视频| 五月天综合婷婷| 激情五月播播久久久精品| 四虎国产成人精品免费一女五男| 在线观看欧美黄色| 福利成人在线观看| 国产精品丝袜高跟| 日韩一级毛片| 一级黄色在线播放| 综合av第一页| 99国产成人精品| 久久国产加勒比精品无码| 精品伊人久久| 国产乱子伦精品视频| 国产成人一区在线| 国产精品theporn动漫| 亚洲二区中文字幕| 天堂电影一区| 日本一区二区不卡高清更新| 日韩电影在线观看一区| 99自拍偷拍视频| 欧美一区二区网站| 欧美巨大xxxx做受沙滩| 国产伦精品一区二区三区四区免费| 亚洲小说欧美另类社区| 影音先锋人妻啪啪av资源网站| 狠狠爱在线视频一区| 国产中文在线观看| 国产精品视频一| 在线精品国产| www.四虎在线| 日韩欧美成人精品| 亚乱亚乱亚洲乱妇| 91亚色免费| 国产视频一区欧美| 高清国产在线观看| 日韩一二三区视频| 黄频免费在线观看| 午夜精品短视频| 久久精品免费观看| 劲爆欧美第一页| 日韩精品视频在线| 国产精品伦一区二区| 7777在线视频| 91免费观看视频| 中文字幕在线网址| 欧美激情第1页| 国产在线观看91一区二区三区| 中文av字幕在线观看| 亚洲高清在线视频| www.亚洲免费| 国产精品v欧美精品v日韩| 老司机一区二区三区| 国产稀缺精品盗摄盗拍| 亚洲精品国精品久久99热| 成人国产激情| 全黄性性激高免费视频| 亚洲国产精品精华液ab| 亚洲女人18毛片水真多| 国产精品美女久久久久久免费| 国产字幕视频一区二区| 亚洲精品视频网址| 亚洲国产精品嫩草影院久久| 成人免费黄色|