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

實例詳解Spring JDBC事務管理

開發(fā) 后端
本文以JDBC事務為例,介紹Spring的事務管理。Spring提供編程式的事務管理與聲明式的事務管理,提供提供了一致的編程模型。
JDBC事務管理

Spring提供編程式的事務管理(Programmatic transaction manage- ment)與聲明式的事務管理(Declarative transaction management),為不同的事務實現(xiàn)提供了一致的編程模型,這節(jié)以JDBC事務為例,介紹Spring的事務管理。

Spring對事務的支持

事務是一組原子(Atomic)操作的工作單元,以數(shù)據(jù)庫存取的實例來說,就是一組SQL指令,這一組SQL指令必須全部執(zhí)行成功,若因為某個原因未全部執(zhí)行成功(例如其中一行SQL有錯誤),則先前所有執(zhí)行過的SQL指令都會被撤消。

舉個簡單的例子,一個客戶從A銀行轉賬至B銀行,要作的動作為從A銀行的賬戶扣款、在B銀行的賬戶加上轉賬的金額,兩個動作必須成功,如果有一個動作失敗,則此次轉賬失敗。

事務還必須保持所參與資源的一致性(Consistent),例如在銀行賬戶的例子中,兩個賬戶的轉賬金額,B賬戶取款的金額不能大于A賬戶的存款金額。每個事務彼此之間必須是隔離的(Isolated),例如在A賬戶中可能有兩筆事務,同時進行存款與提款的動作,兩個事務基本上不需意識到彼此的存在。事務還必須是可持續(xù)的(Durable),在某一筆事務之后,這筆事務必須是被記錄下來的。

在這里將介紹JDBC如何使用事務管理。首先來看看事務的原子性實現(xiàn),在JDBC中,可以操作Connection的setAutoCommit() 方法,給定false參數(shù),在下達一連串的SQL語句后,自行執(zhí)行Connection的commit()來送出變更,如果中間發(fā)生錯誤,則執(zhí)行 rollback() 來撤消所有的執(zhí)行,例如:

try {

.....

connection.setAutoCommit(false);

.....

// 一連串SQL操作


connection.commit();

} catch(SQLException) {

// 發(fā)生錯誤,撤消所有變更


connection.rollback();

}

在Spring中對JDBC的事務管理加以封裝,Spring事務管理的抽象關鍵在于org.springframework.transaction.PlatformTransactionManager接口的實現(xiàn):

public interface PlatformTransactionManager {

TransactionStatus getTransaction(TransactionDefinition

definition) throws TransactionException;

void commit(TransactionStatus status)

throws TransactionException;

void rollback(TransactionStatus status)

throws TransactionException;

}

PlatformTransactionManager 接口有許多具體的事務實現(xiàn)類,例如DataSourceTransactionManager、 HibernateTransactionManager、JdoTransaction- Manager、JtaTransactionManager等,通過依賴于PlatformTransactionManager接口及各種的技術實現(xiàn),Spring在事務管理上可以讓開發(fā)人員使用一致的編程模型,即使所使用的是不同的事務管理技術。

TransactionException是Unchecked Exception.事務的失敗通常都是致命的錯誤,Spring不強迫您一定要處理,而是讓您自行選擇是否要捕捉異常。

getTransaction() 方法根據(jù)一個TransactionDefinition對象來回傳一個TransactionStatus對象,TransactionDefinition接口的實例定義了事務的隔離程度(Isolation level)、傳播行為(Propagation behavior)、超時(Timeout)、只讀(Read-only)等,TransactionStatus代表著一個新的事務發(fā)起或已經(jīng)存在的事務,您可以通過它來控制事務的執(zhí)行或調查的狀態(tài):

public interface TransactionStatus {

boolean isNewTransaction();

void setRollbackOnly();

boolean isRollbackOnly();

}

Spring提供編程式的事務管理(Programmatic transaction management)與聲明式的事務管理(Declarative transaction management):

編程式的事務管理

編程式的事務管理可以清楚地控制事務的邊界,也就是讓您自行實現(xiàn)事務開始時間、撤消操作的時機、結束時間等,可以實現(xiàn)細粒度的事務控制。

聲明式的事務管理

然而多數(shù)的情況下,事務并不需要細粒度的控制,而是采用聲明式的事務管理,好處是Spring事務管理的相關API可以不用介入程序之中,從對象的角度來看,它并不知道自己正被納入事務管理之中,在不需要事務管理的時候,只要在設置文件上修改一下設置,即可移去事務管理服務。

JDBC編程事務管理Spring提供兩種方式實現(xiàn)編程式的事務管理,一是直接使用PlatformTransaction- Manager實現(xiàn),二是使用org.springframework.transaction.support.Transaction- Template.

先來看看如何使用PlatformTransactionManager,在這里使用它的實現(xiàn)類 DataSourceTransactionManager,可以改寫一下之前幾節(jié)中的JdbcTemplateDemo項目,讓它具有事務管理功能,修改一下UserDAO類的insert() 方法來作示范:ProgrammaticTransactionDemo UserDAO.java

package onlyfun.caterpillar;

import java.util.Iterator;

import java.util.List;

import java.util.Map;

import javax.sql.DataSource;

import org.springframework.dao.DataAccessException;

import org.springframework.jdbc.core.JdbcTemplate;

import org.springframework.jdbc.

datasource.DataSourceTransactionManager;

import org.springframework.transaction.TransactionDefinition;

import org.springframework.transaction.TransactionStatus;

import org.springframework.transaction.

support.DefaultTransactionDefinition;

public class UserDAO implements IUserDAO {

private DataSourceTransactionManager transactionManager;

private DefaultTransactionDefinition def;

private JdbcTemplate jdbcTemplate;



public void setDataSource(DataSource dataSource) {

jdbcTemplate = new JdbcTemplate(dataSource);

transactionManager =

new DataSourceTransactionManager(dataSource);

// 建立事務的定義


def = new DefaultTransactionDefinition();

def.setPropagationBehavior(

TransactionDefinition.PROPAGATION_REQUIRED);

}



public void insert(User user) {

String name = user.getName();

int age = user.getAge().intValue();



TransactionStatus status =

transactionManager.getTransaction(def);

try {

jdbcTemplate.update("INSERT INTO user (name,age) "

+ "VALUES('" + name + "'," + age + ")");

// 下面的SQL有錯誤,用以測試事務


jdbcTemplate.update("INSER INTO user (name,age) "

+ "VALUES('" + name + "'," + age + ")");

}

catch(DataAccessException e) {

transactionManager.rollback(status);

throw e;

}

transactionManager.commit(status);

}

public User find(Integer id) {

List rows = jdbcTemplate.queryForList(

"SELECT * FROM user WHERE id=" + id.intValue());



Iterator it = rows.iterator();

if(it.hasNext()) {

Map userMap = (Map) it.next();

Integer i = new Integer(

userMap.get("id").toString());

String name = userMap.get("name").toString();

Integer age = new Integer(

userMap.get("age").toString());

User user = new User();



user.setId(i);

user.setName(name);

user.setAge(age);



return user;

}

return null;

}

}

在 insert()方法中使用了DataSourceTransactionManager來進行事務管理,如果發(fā)生了異常,則catch區(qū)塊中會進行事務的Rollback,在insert() 方法中故意寫入錯誤的SQL(注意INSERT方法少寫了一個T),因此實際上數(shù)據(jù)并不會被儲存至數(shù)據(jù)庫中。

要使用MySQL數(shù)據(jù)庫進行事務處理,必須建立支持事務的表格類型,例如InnoDB的表格類型,這里用來建立表格的SQL如下所示:

CREATE TABLE user (

id INT(11) NOT NULL auto_increment PRIMARY KEY,

name VARCHAR(100) NOT NULL default '',

age INT

) TYPE = InnoDB;

另一個實現(xiàn)編程式事務管理的方法是使用TransactionTemplate,它需要一個TransactionManager實例,如下所示:

TransactionTemplate transactionTemplate =

new TransactionTemplate(transactionManager);

...

transactionTemplate.execute(new TransactionCallback() {

public Object doInTransaction(TransactionStatus status) {

return jdbcTemplate.update("INSERT INTO user (name,age) "

+ "VALUES('" + name + "'," + age + ")");

}

});

如果發(fā)生了異常,則會進行Rollback,否則提交事務,如果沒有回傳值,則也可以使用TransactionCallbackWithoutResult:

transactionTemplate.execute(

new TransactionCallbackWithoutResult() {

public void doInTransactionWithoutResult(

TransactionStatus status) {

. ...

}

});

5.3.3 JDBC聲明事務管理

Spring聲明式的事務管理依賴它的AOP框架來完成。使用聲明事務管理的好處是,事務管理不能侵入您所開發(fā)的組件,具體來說,DAO對象不會意識到正在事務管理之中,事實上也應當如此,因為事務管理是屬于系統(tǒng)層面的服務,而不是業(yè)務邏輯的一部分,如果想要改變事務管理策略的話,也只需要在定義文件中重新配置。

舉個例子來說,可以將5.2.1節(jié)中的JdbcTemplateDemo 項目修改一下,在不修改UserDAO類的情況下,可以為它加入事務管理的服務,一個簡單的方法是使用 TransactionProxyFactoryBean,指定要介入的事務管理對象及其方法,這需要在定義文件中修改,如下所示:

DeclarativeTransactionDemo beans-config.xml

<?xml version="1.0" encoding="UTF-8"?>

<beans xmlns="http://www.springframework.org/schema/beans"

xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"

xsi:schemaLocation=
"http://www.springframework.org/schema/beans

http://www.springframework.org/schema/beans/spring-beans-2.0.xsd"
>



<bean id="dataSource"

class=
"org.springframework.jdbc.

→ datasource.DriverManagerDataSource"


destroy-method="close">

<property name="driverClassName"

value="com.mysql.jdbc.Driver"/>

<property name="url"

value="jdbc:mysql://localhost:3306/demo"/>

<property name="username" value="caterpillar"/>

<property name="password" value="123456"/>

</bean>



<bean id="transactionManager"

class=
"org.springframework.jdbc.

→ datasource.DataSourceTransactionManager"
>

<property name="dataSource" ref="dataSource"/>

</bean>



<bean id="userDAO"

class="onlyfun.caterpillar.UserDAO">

<property name="dataSource" ref="dataSource"/>

</bean>



<bean id="userDAOProxy"

class=
"org.springframework.transaction.

→ interceptor.TransactionProxyFactoryBean"
>

<property name="proxyInterfaces">

<list>

<value>onlyfun.caterpillar.IUserDAO</value>

</list>

</property>

<property name="target" ref="userDAO"/>

<property name="transactionManager"

ref="transactionManager"/>

<property name="transactionAttributes">

<props>

<prop key="insert*">PROPAGATION_REQUIRED</prop>

</props>

</property>

</bean>

</beans>

TransactionProxyFactoryBean需要一個TransactionManager,由于這里使用的是JDBC,所以使用 DataSourceTransactionManager,TransactionProxyFactoryBean是個代理對象,"target" 屬性指定要代理的對象,事務管理會自動介入指定的方法前后,這里使用 "transactionAttributes" 屬性指定,"insert*" 表示指定方法名稱以insert開頭的都要納入事務管理,您也可以指定方法全名,如果在方法執(zhí)行過程中發(fā)生錯誤,則所有先前的操作自動撤回,否則正常提交。

在"insert*" 等方法上指定了 "PROPAGATION_REQUIRED",表示在目前的事務中執(zhí)行操作,如果事務不存在就建立一個新的,相關的常數(shù)意義都可以在API文件的 TransactionDefinition接口中找到。您可以加上多個事務定義,中間使用逗號 "," 區(qū)隔,例如可以加上只讀,或者是指定某個異常發(fā)生時撤回操作:

PROPAGATION_REQUIRED,readOnly,-MyCheckedException

MyCheckedException前面加上 "-" 時,表示發(fā)生指定異常時撤消操作,如果前面加上 "+",表示發(fā)生異常時立即提交。

由于"userDAO"被"userDAOProxy"代理了,所以要做的是取得"userDAOProxy",而不是"userDAO",例如:

DeclarativeTransactionDemo SpringDAODemo.java

package onlyfun.caterpillar;

import org.springframework.context.ApplicationContext;

import org.springframework.context.

support.ClassPathXmlApplicationContext;

public class SpringDAODemo {

public static void main(String[] args) {

ApplicationContext context =

new ClassPathXmlApplicationContext(

"beans-config.xml");



User user = new User();



user.setName("caterpillar");

user.setAge(new Integer(30));



IUserDAO userDAO =

(IUserDAO) context.getBean("userDAOProxy");



userDAO.insert(user);



user = userDAO.find(new Integer(1));



System.out.println("name: " + user.getName());

}

}

您也可以設置不同的TransactionInterceptor來得到更多的管理細節(jié),例如:

<?xml version="1.0" encoding="UTF-8"?>

<beans xmlns="http://www.springframework.org/schema/beans"

xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"

xsi:schemaLocation=
"http://www.springframework.org/schema/beans

http://www.springframework.org/schema/beans/spring-beans-2.0.xsd"
>



<bean id="dataSource"

class=
"org.springframework.jdbc.

→ datasource.DriverManagerDataSource"


destroy-method="close">

<property name="driverClassName"

value="com.mysql.jdbc.Driver"/>

<property name="url"

value="jdbc:mysql://localhost:3306/demo"/>

<property name="username" value="caterpillar"/>

<property name="password" value="123456"/>

</bean>

<bean id="transactionManager"

class=
"org.springframework.jdbc.

→ datasource.DataSourceTransactionManager"
>

<property name="dataSource" ref="dataSource"/>

</bean>



<bean id="userDAO"

class="onlyfun.caterpillar.UserDAO">

<property name="dataSource" ref="dataSource"/>

</bean>

<bean id="transactionInterceptor"

class=
"org.springframework.transaction.

→ interceptor.TransactionInterceptor"
>

<property name="transactionManager" ref="transactionManager"/>

<property name="transactionAttributeSource"

value=
"onlyfun.caterpillar.UserDAO.insert*=

→ PROPAGATION_REQUIRED "
/>

</bean>



<bean id="userDAOProxy"

class=
"org.springframework.aop.

→ framework.ProxyFactoryBean"
>

<property name="proxyInterfaces">

<list>

<value>onlyfun.caterpillar.IUserDAO</value>

</list>

</property>

<property name="target" ref="userDAO"/>

<property name="interceptorNames">

<list>

<value>transactionInterceptor</value>

</list>

</property>

</bean>

同樣的,由于不再于設置文件中設置代理對象,所以直接取得"userDAO"實例進行操作即可。

【編輯推薦】

  1. Spring 3.0即將發(fā)布 新增Spring表達式語言
  2. Spring+JPA,下一個人氣組合?
  3. OSGi與Spring的整合
  4. Spring之父評價甲骨文收購Sun:對Java影響不大
  5. 淺談ASP.NET Ajax中調用JavaScript的服務
責任編輯:王觀 來源: 中國IT實驗
相關推薦

2023-03-27 10:40:09

2023-10-08 08:28:10

Spring事務管理

2009-06-17 14:57:11

Spring事務管理

2009-06-30 16:57:42

Spring事務管理

2014-08-25 09:12:47

Spring事務管理

2010-03-29 13:34:15

ibmdwSpring

2009-09-25 12:59:53

Hibernate事務

2010-03-23 08:46:40

Spring

2009-02-11 13:08:29

事務提交事務管理Spring

2009-02-11 11:14:31

事務管理事務開始Spring

2009-06-17 14:43:47

Spring框架Spring事務管理

2025-02-08 10:56:18

2009-06-03 10:20:11

Hibernate事務管理配置

2009-09-23 17:48:00

Hibernate事務

2009-09-29 09:44:52

Hibernate事務

2010-10-22 11:47:30

sql server存

2025-02-21 08:00:00

事務管理SpringBootJava

2009-07-15 13:41:00

JDBC實例

2023-05-06 07:29:49

Spring事務傳播

2022-08-04 08:46:16

單體架構微服務事務管理
點贊
收藏

51CTO技術棧公眾號

日韩精品四区| 日韩精品麻豆| av在线一区二区三区| 青青青国产精品一区二区| jizz中文字幕| 国产精品亚洲欧美一级在线| 亚洲一线二线三线视频| 久久精品人人做人人爽电影| 中文字幕日韩国产| 欧美韩日精品| 亚洲精品日韩久久久| 中国黄色片免费看| 女人天堂av在线播放| 91亚洲精品一区二区乱码| 国产精品久久久久久久9999| 2018天天弄| 亚洲综合小说图片| 在线不卡欧美精品一区二区三区| 国产原创popny丨九色| 91在线视频| 丁香婷婷综合色啪| 国产精品丝袜视频| 日本特黄一级片| 日韩av自拍| 亚洲精品福利在线| 久久婷婷中文字幕| 日韩伦理三区| 亚洲成年人影院| 在线观看欧美一区| 精品资源在线看| caoporn国产精品| 成人女保姆的销魂服务| av网站中文字幕| 亚洲五月婷婷| 久久亚洲欧美日韩精品专区| 欧美日韩高清丝袜| 国内精品麻豆美女在线播放视频| 69av一区二区三区| 在线观看免费黄网站| 女人让男人操自己视频在线观看| 亚洲欧美二区三区| 亚洲一区二区免费视频软件合集| 日韩中文字幕免费观看| 国产精品一二三区在线| 国产精品欧美亚洲777777| 狠狠人妻久久久久久| 亚洲区欧美区| 欧美巨乳美女视频| 亚洲精品一区二区三区在线播放| 国产精品免费大片| 亚洲毛片在线观看| 91av在线免费| 欧美电影在线观看免费| 亚洲第一二三四五区| av在线免费观看不卡| 成人永久在线| 91精品国产免费| 日本美女视频一区| 亚洲精品自拍| 884aa四虎影成人精品一区| 亚洲最大综合网| 99久久婷婷国产综合精品首页| 日本精品免费观看高清观看| 国产免费人做人爱午夜视频| 樱桃视频成人在线观看| 色综合久久综合中文综合网| 久久久久久久久久久免费视频| 日韩欧美精品一区二区三区| 欧美视频在线免费看| 日本一本二本在线观看| 二区三区不卡| 在线观看视频一区| 校园春色 亚洲色图| 久久久久久久性潮| 91精品在线一区二区| 超碰中文字幕在线观看| 成人中文字幕视频| 精品一区二区三区四区在线| 91精品人妻一区二区三区| 欧美色网址大全| 日韩在线免费视频观看| 一区视频免费观看| 日韩天堂av| 日本免费久久高清视频| 在线免费av片| 国产91色综合久久免费分享| 国产在线播放一区二区| 久久天堂电影| 1024亚洲合集| 男女日批视频在线观看| 欧美香蕉视频| 91麻豆精品国产91久久久更新时间| 人妻换人妻仑乱| 日韩精品社区| 日韩在线中文视频| 久视频在线观看| 久久尤物视频| 成人免费网视频| 天堂网在线中文| 久久在线观看免费| 国产成人精品免费看在线播放| 波多野结衣久久| 欧美性做爰猛烈叫床潮| 国产精品无码自拍| 欧美军人男男激情gay| 中文字幕日韩高清| 久久精品视频久久| 美国毛片一区二区| 国产高清精品一区二区| 岛国视频免费在线观看| 亚洲男人天堂av| 伊人成色综合网| 久久国产精品美女| 亚洲欧美色婷婷| 欧美黑人精品一区二区不卡| 久久综合图片| 国产免费一区| 国产黄色在线网站| 91黄色免费观看| www.555国产精品免费| 欧美xxav| 国产成人精品av在线| 亚洲第一视频在线| 亚洲丝袜制服诱惑| 日本新janpanese乱熟| 国产成人澳门| 久久99国产精品自在自在app| 欧美日韩 一区二区三区| av高清不卡在线| 日韩欧美一级在线| 少妇精品视频在线观看| 国产亚洲精品成人av久久ww| 五月天综合激情| 成人福利视频在线| 四虎4hu永久免费入口| 国产一区二区主播在线| 亚洲乱亚洲乱妇无码| 黄色片视频网站| 岛国一区二区在线观看| 在线视频一二三区| 亚洲影视资源| 中文字幕在线看视频国产欧美在线看完整| 久久久久久少妇| 成人av在线播放网址| 97久久国产亚洲精品超碰热| 自拍偷拍亚洲| 精品国产一区久久久| 中文字幕一区二区三区四区视频 | 成人免费毛片日本片视频| 欧美在线亚洲| 91精品天堂| 欧美14一18处毛片| 欧美不卡一区二区| 日本熟妇色xxxxx日本免费看| 国产白丝精品91爽爽久久| 日本天堂免费a| 91综合久久爱com| 欧美激情精品久久久久| 国产91绿帽单男绿奴| 亚洲国产视频网站| v天堂中文在线| 国产日韩欧美在线播放不卡| 欧美二区三区在线| a欧美人片人妖| 亚洲欧美日韩国产中文专区| 欧美a视频在线观看| 国产日韩欧美不卡| 五月天av在线播放| 四虎成人精品永久免费av九九| 成人av资源在线播放| 2024短剧网剧在线观看| 精品国产污网站| 国内免费精品视频| 久久你懂得1024| 91女神在线观看| 欧美福利网址| 久久超碰亚洲| 国产精品诱惑| 欧美国产在线视频| 亚洲 另类 春色 国产| 欧美网站在线观看| 污污视频网站在线免费观看| 国产乱码一区二区三区| 免费一级特黄特色毛片久久看| 夜色77av精品影院| 成人免费淫片视频软件| 美女高潮视频在线看| 一区二区三欧美| 国产成人麻豆精品午夜在线| 精品久久久久久久久久久| 波多野结衣一二三四区| 国产精品一区在线| 成人黄色片视频| 中文字幕一区二区av | 欧美日韩水蜜桃| 亚洲xxxxx| 日韩激情电影免费看| 中文字幕在线看视频国产欧美在线看完整 | 91亚洲国产精品| 成人女同在线观看| 在线播放国产一区中文字幕剧情欧美 | 亚洲精品国产熟女久久久| 久久国产精品99精品国产 | 视频一区视频二区中文| 日本丰满大乳奶| 亚洲精品国产动漫| 亚洲综合在线播放| 欧美日韩精品免费观看视完整| 久久九九国产精品怡红院 | 91麻豆国产在线观看| 亚洲一区二区在线视频观看| 在线亚洲欧美| 天堂av在线中文| 激情五月综合| 国产在线精品一区二区三区| 韩国精品视频在线观看| 51精品在线观看| 国产福利在线播放麻豆| 亚洲人在线视频| 十八禁一区二区三区| 欧美另类变人与禽xxxxx| 久久久成人免费视频| 一区二区三区免费观看| 91制片厂在线| 国产欧美一区二区精品忘忧草| 国产精品扒开腿做爽爽爽a片唱戏| 国内精品在线播放| 精品久久久噜噜噜噜久久图片| 黄色av成人| 日本道在线视频| 97精品国产福利一区二区三区| 欧美精品二区三区四区免费看视频 | 欧美日韩一区二区高清| 亚洲一卡二卡三卡| 精品免费视频| 日本高清一区| 天堂资源在线亚洲| 国产一区二区三区奇米久涩| 日本一区二区乱| 91在线免费网站| 9999精品免费视频| 成人性生交大片免费看视频直播 | 欧美午夜电影在线播放| 久久久久女人精品毛片九一| 五月天婷婷综合| 日本熟妇一区二区| 婷婷夜色潮精品综合在线| www.av视频在线观看| 亚洲午夜久久久久中文字幕久| 国产精品久久久精品四季影院| 亚洲欧洲av色图| 日本激情视频一区二区三区| 国产精品护士白丝一区av| 青青草华人在线视频| 日本一区二区在线不卡| 欧美成人短视频| 国产精品毛片大码女人| 国产人与禽zoz0性伦| 亚洲天堂免费在线观看视频| 2025国产精品自拍| 悠悠色在线精品| 国产精品111| 精品国产乱码久久久久久天美| 少妇一级淫片免费放中国| 午夜av一区二区三区| 天堂网中文字幕| 日本精品视频一区二区| 91久久久久国产一区二区| 制服.丝袜.亚洲.中文.综合| 国产成人免费看一级大黄| 亚洲第一视频网站| 全部免费毛片在线播放网站| 亚洲一级免费视频| dj大片免费在线观看| 久久久久女教师免费一区| 蜜桃视频在线观看免费视频| 欧美最猛性xxxxx(亚洲精品)| 成人黄色免费观看| 亚洲一区二区三区成人在线视频精品| 91精品日本| 欧美不卡三区| 99久久久久久中文字幕一区| 激情视频小说图片| 国产精品嫩草99av在线| 中文字幕第88页| 国产69精品久久777的优势| 好吊一区二区三区视频| 国产精品入口麻豆九色| 九九视频免费观看| 日韩欧美在线一区| 国产精品一级视频| 亚洲精品av在线播放| 免费av不卡| 1769国产精品| 91国产一区| 久久久久久久久久久久久久一区| 日韩av自拍| 欧美黑人经典片免费观看| 免费成人你懂的| 50一60岁老妇女毛片| 中文字幕一区二区三区在线播放 | av大片在线| 欧美在线亚洲一区| 欧美第一在线视频| 欧美一区三区二区在线观看| 欧美精品一级| 色播五月综合网| 久久影院视频免费| 国产成人无码aa精品一区| 91精品91久久久中77777| 风流少妇一区二区三区91| 国产一区二区三区高清在线观看 | 国产精品第100页| 国产主播性色av福利精品一区| 欧美性视频在线播放| 久久性天堂网| 成人无码www在线看免费| 亚洲免费在线看| 一级久久久久久| 日韩精品视频在线免费观看| 日本色护士高潮视频在线观看| 国产精品99久久久久久人| 久久丝袜视频| 欧美激情亚洲天堂| 久久电影网站中文字幕| 强伦人妻一区二区三区| 亚洲国产成人精品视频| av在线资源观看| 色综久久综合桃花网| 日韩性xxx| 免费看国产精品一二区视频| 亚洲大胆在线| 国产黑丝在线视频| 亚洲三级免费观看| 91亚洲国产成人久久精品麻豆| 亚洲性视频网站| 日韩av超清在线观看| 欧美日韩一区二区视频在线| 99精品视频免费全部在线| 日本少妇xxxx| 亚洲一区二区精品久久av| 国产女同91疯狂高潮互磨| 日韩视频免费在线| 粉嫩av一区二区三区四区五区| 日本欧美色综合网站免费| 久久精品伊人| 亚洲区自拍偷拍| 欧美综合一区二区| a中文在线播放| 国产精品视频1区| 欧美成免费一区二区视频| 日本中文字幕二区| 国产精品不卡一区| 91欧美日韩麻豆精品| 久久影视电视剧免费网站清宫辞电视| **精品中文字幕一区二区三区| 国产精品波多野结衣| 国内精品免费在线观看| 丁香花五月激情| 欧美成人一区二区三区| 黄色影院在线看| 精品乱码一区二区三区| 亚洲一区欧美激情| 免费一级做a爰片久久毛片潮| 欧美午夜在线观看| 日本高清中文字幕在线| 91久久综合亚洲鲁鲁五月天| 一区二区三区在线观看免费| 亚洲熟女一区二区三区| 午夜视频一区在线观看| 国产午夜精品一区理论片| 国产在线一区二区三区| 欧美激情无毛| 亚洲AV无码国产精品| 在线观看免费一区| 美女隐私在线观看| 丁香婷婷久久久综合精品国产| 99精品欧美| 欧美aaa级片| 日韩一区二区三免费高清| 欧美xxxx黑人又粗又长| 久久影视中文粉嫩av| 蜜桃传媒麻豆第一区在线观看| 日韩一级片av| 日韩的一区二区| 亚洲伦理久久| 日本中文字幕网址| 国产精品天天摸av网| 亚洲精选一区二区三区| 欧美亚洲成人精品| 国产精品久久久久久久久妇女| 国产香蕉精品视频| 在线观看三级视频欧美| 人人超在线公开视频| 日韩福利影院| 国产不卡视频一区| 国产日韩久久久| 欧美高清在线视频观看不卡| 精品国产日韩欧美| 一级黄色免费视频|