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

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 前端技术 > javascript >内容正文

javascript

Spring Data JDBC通用DAO实现–迄今为止最轻量的ORM

發布時間:2023/12/3 javascript 56 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Spring Data JDBC通用DAO实现–迄今为止最轻量的ORM 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

我很高興宣布Spring Data JDBC存儲庫項目的第一個版本。 這個開放源代碼庫的目的是為基于Spring框架中 JdbcTemplate關系數據庫提供通用,輕量且易于使用的DAO實現,與項目的Spring Data 框架兼容。

設計目標

  • 輕巧,快速且開銷低。 只有少數幾個類, 沒有XML,注釋,反射
  • 這不是成熟的ORM 。 沒有關系處理,延遲加載,臟檢查,緩存
  • 在幾秒鐘內實現CRUD
  • 對于JPA過大的小型應用程序
  • 在需要簡單性或考慮將來遷移到JPA時使用
  • 對數據庫方言差異的最小化支持(例如,透明的結果分頁)

特征

每個DAO為以下內容提供內置支持:

  • 通過RowMapper抽象到域對象/從域對象映射
  • 生成的和用戶定義的主鍵
  • 提取生成的密鑰
  • 復合(多列)主鍵
  • 不變的領域對象
  • 分頁(請求結果子集)
  • 按幾列排序(與數據庫無關)
  • 對多對一關系的可選支持
  • 支持的數據庫(連續測試):
    • 的MySQL
  • 通過SqlGenerator類可以輕松擴展到其他數據庫方言。
  • 通過ID輕松檢索記錄

API

與Spring Data PagingAndSortingRepository抽象兼容, 所有這些方法都為您實現

public interface PagingAndSortingRepository<T, ID extends Serializable> extends CrudRepository<T, ID> {T save(T entity);Iterable<T> save(Iterable<? extends T> entities);T findOne(ID id);boolean exists(ID id);Iterable<T> findAll();long count();void delete(ID id);void delete(T entity);void delete(Iterable<? extends T> entities);void deleteAll();Iterable<T> findAll(Sort sort);Page<T> findAll(Pageable pageable); }

還完全支持Pageable和Sort參數,這意味著您可以通過任意屬性免費獲得分頁和排序 。 例如,假設您有userRepository擴展了PagingAndSortingRepository<User, String>接口(由庫為您實現),并且在應用某種排序后,您請求了USERS表的第5頁,每頁10個:

Page<User> page = userRepository.findAll(new PageRequest(5, 10,new Sort(new Order(DESC, "reputation"),new Order(ASC, "user_name"))) );

Spring Data JDBC存儲庫庫會將此調用轉換為(PostgreSQL語法):

SELECT * FROM USERS ORDER BY reputation DESC, user_name ASC LIMIT 50 OFFSET 10

…甚至(Derby語法):

SELECT * FROM (SELECT ROW_NUMBER() OVER () AS ROW_NUM, t.*FROM (SELECT *FROM USERSORDER BY reputation DESC, user_name ASC) AS t) AS a WHERE ROW_NUM BETWEEN 51 AND 60

無論使用哪個數據庫,都將獲得Page<User>對象作為回報(您仍然必須自己提供RowMapper<User>才能將其從ResultSet轉換為域對象。如果您還不了解Spring Data項目,則Page<T>是一個很棒的抽象,不僅封裝了List<User> ,而且還提供了元數據,例如記錄總數,我們當前所在的頁面等。

使用理由

  • 由于將來您的代碼將僅依賴于Spring Data Commons傘項目中的PagingAndSortingRepository和CrudRepository定義的方法, PagingAndSortingRepository您可以自由地從JdbcRepository實現(從該項目)切換到: JpaRepository , MongoRepository , GemfireRepository或GraphRepository 。 它們都實現相同的通用API。 當然,不要指望從JDBC切換到JPA或MongoDB就像切換導入的JAR依賴項一樣簡單-但是至少您可以通過使用相同的DAO API最小化影響。
  • 您需要一個快速,簡單的JDBC包裝器庫。 JPA甚至MyBatis都不過分
  • 如果需要,您想完全控制生成的SQL
  • 您想使用對象,但是不需要延遲加載,關系處理,多級緩存,臟檢查……您需要CRUD等等
  • 您想干嗎
  • 您已經在使用Spring甚至JdbcTemplate ,但仍然覺得手工工作過多
  • 您的數據庫表很少

入門

有關更多示例和工作代碼,請不要忘記檢查項目測試 。

先決條件

Maven坐標:

<dependency><groupId>com.blogspot.nurkiewicz</groupId><artifactId>jdbcrepository</artifactId><version>0.1</version> </dependency>

不幸的是,該項目尚未在Maven中央存儲庫中 。 目前,您可以通過克隆將庫安裝在本地存儲庫中:

$ git clone git://github.com/nurkiewicz/spring-data-jdbc-repository.git $ git checkout 0.1 $ mvn javadoc:jar source:jar install

為了啟動您的項目,必須存在DataSource bean并啟用事務管理。 這是最小的MySQL配置:

@EnableTransactionManagement @Configuration public class MinimalConfig {@Beanpublic PlatformTransactionManager transactionManager() {return new DataSourceTransactionManager(dataSource());}@Beanpublic DataSource dataSource() {MysqlConnectionPoolDataSource ds = new MysqlConnectionPoolDataSource();ds.setUser("user");ds.setPassword("secret");ds.setDatabaseName("db_name");return ds;}}

具有自動生成的密鑰的實體

假設您有一個具有自動生成的密鑰(MySQL語法)的數據庫表:

CREATE TABLE COMMENTS (id INT AUTO_INCREMENT,user_name varchar(256),contents varchar(1000),created_time TIMESTAMP NOT NULL,PRIMARY KEY (id) );

首先,您需要創建到該表的域對象User映射(就像在任何其他ORM中一樣):

public class Comment implements Persistable<Integer> {private Integer id;private String userName;private String contents;private Date createdTime;@Overridepublic Integer getId() {return id;}@Overridepublic boolean isNew() {return id == null;}//getters/setters/constructors/... }

除了標準的Java樣板之外,您還應該注意實現Persistable<Integer> ,其中Integer是主鍵的類型。 Persistable<T>是一個來自Spring Data項目的接口,這是我們對您的域對象的唯一要求。

最后,我們準備創建CommentRepository DAO:

@Repository public class CommentRepository extends JdbcRepository<Comment, Integer> {public CommentRepository() {super(ROW_MAPPER, ROW_UNMAPPER, "COMMENTS");}public static final RowMapper<Comment> ROW_MAPPER = //see belowprivate static final RowUnmapper<Comment> ROW_UNMAPPER = //see below@Overrideprotected Comment postCreate(Comment entity, Number generatedId) {entity.setId(generatedId.intValue());return entity;} }

首先,我們使用@Repository批注標記DAO bean。 它啟用持久性異常轉換。 通過CLASSPATH掃描也可以發現此類帶注釋的bean。

如您所見,我們擴展了JdbcRepository<Comment, Integer> ,它是該庫的中心類,提供了所有PagingAndSortingRepository方法的實現。 它的構造函數具有三個必需的依賴項: RowMapper , RowUnmapper和表名。 您也可以提供ID列名,否則使用默認的"id" 。

如果您曾經使用過Spring的JdbcTemplate ,則應該熟悉RowMapper界面。 我們需要以某種方式將ResultSet列提取到一個對象中。 畢竟,我們不想使用原始的JDBC結果。 這很簡單:

public static final RowMapper<Comment> ROW_MAPPER = new RowMapper<Comment>() {@Overridepublic Comment mapRow(ResultSet rs, int rowNum) throws SQLException {return new Comment(rs.getInt("id"),rs.getString("user_name"),rs.getString("contents"),rs.getTimestamp("created_time"));} };

RowUnmapper來自此庫,它本質上與RowMapper相反:接收一個對象并將其轉換為Map 。 庫稍后使用此映射來構造SQL CREATE / UPDATE查詢:

private static final RowUnmapper<Comment> ROW_UNMAPPER = new RowUnmapper<Comment>() {@Overridepublic Map<String, Object> mapColumns(Comment comment) {Map<String, Object> mapping = new LinkedHashMap<String, Object>();mapping.put("id", comment.getId());mapping.put("user_name", comment.getUserName());mapping.put("contents", comment.getContents());mapping.put("created_time", new java.sql.Timestamp(comment.getCreatedTime().getTime()));return mapping;} };

如果您從不更新數據庫表(僅讀取插入在其他位置的一些參考數據),則可以跳過RowUnmapper參數或使用MissingRowUnmapper 。

最后一個難題是postCreate()回調方法,該方法在插入對象后調用。 您可以使用它來檢索生成的主鍵并更新域對象(如果域對象是不可變的,則返回新的主鍵)。 如果不需要它,就不要重寫postCreate() 。 根據此示例,檢查JdbcRepositoryGeneratedKeyTest以獲取有效的代碼。

到目前為止,您可能會覺得與JPA或Hibernate相比,有很多手工工作。 但是,眾所周知,各種JPA實現和其他ORM框架都會引入大量開銷并顯示一些學習曲線。 這個微小的庫有意讓用戶承擔一些責任,以避免復雜的映射,反射,注釋……并非總是需要的所有隱式性。 該項目無意替代成熟穩定的ORM框架。 相反,它試圖填補原始JDBC和ORM之間的利基,其中簡單性和低開銷是關鍵特征。

具有手動分配的密鑰的實體

在此示例中,我們將看到如何處理具有用戶定義的主鍵的實體。 讓我們從數據庫模型開始:

CREATE TABLE USERS (user_name varchar(255),date_of_birth TIMESTAMP NOT NULL,enabled BIT(1) NOT NULL,PRIMARY KEY (user_name) );

…和User域模型:

public class User implements Persistable<String> {private transient boolean persisted;private String userName;private Date dateOfBirth;private boolean enabled;@Overridepublic String getId() {return userName;}@Overridepublic boolean isNew() {return !persisted;}public User withPersisted(boolean persisted) {this.persisted = persisted;return this;}//getters/setters/constructors/...}

注意,添加了特殊的persisted瞬態標志。 來自Spring Data項目的CrudRepository.save()合同要求一個實體知道它是否已經保存( isNew() )方法–沒有單獨的create()和update()方法。 對于自動生成的鍵(參見上面的Comment ),實現isNew()很簡單,但是在這種情況下,我們需要一個額外的瞬態字段。 如果您討厭這種解決方法,并且只插入數據而從不更新,則始終可以從isNew()返回true 。

最后是我們的DAO, UserRepository bean:

@Repository public class UserRepository extends JdbcRepository<User, String> {public UserRepository() {super(ROW_MAPPER, ROW_UNMAPPER, "USERS", "user_name");}public static final RowMapper<User> ROW_MAPPER = //...public static final RowUnmapper<User> ROW_UNMAPPER = //...@Overrideprotected User postUpdate(User entity) {return entity.withPersisted(true);}@Overrideprotected User postCreate(User entity, Number generatedId) {return entity.withPersisted(true);} }

"USERS"和"user_name"參數指定表名稱和主鍵列名稱。 我將保留mapper和unmapper的詳細信息(請參閱源代碼 )。 但是請注意postUpdate()和postCreate()方法。 它們確保一旦對象被持久保存,就設置了persisted標志,以便隨后對save()調用將更新現有實體,而不是嘗試重新插入它。

根據此示例,檢查JdbcRepositoryManualKeyTest以獲得有效的代碼。

復合主鍵

我們還支持復合主鍵(由幾列組成的主鍵)。 以該表為例:

CREATE TABLE BOARDING_PASS (flight_no VARCHAR(8) NOT NULL,seq_no INT NOT NULL,passenger VARCHAR(1000),seat CHAR(3),PRIMARY KEY (flight_no, seq_no) );

我希望您注意到Peristable<T>的主鍵類型:

public class BoardingPass implements Persistable<Object[]> {private transient boolean persisted;private String flightNo;private int seqNo;private String passenger;private String seat;@Overridepublic Object[] getId() {return pk(flightNo, seqNo);}@Overridepublic boolean isNew() {return !persisted;}//getters/setters/constructors/...}

不幸的是,我們不支持將所有ID值封裝在一個對象中的小數值類(就像JPA使用@IdClass ),因此您必須使用Object[]數組。 定義DAO類類似于我們已經看到的內容:

public class BoardingPassRepository extends JdbcRepository<BoardingPass, Object[]> {public BoardingPassRepository() {this("BOARDING_PASS");}public BoardingPassRepository(String tableName) {super(MAPPER, UNMAPPER, new TableDescription(tableName, null, "flight_no", "seq_no"));}public static final RowMapper<BoardingPass> ROW_MAPPER = //...public static final RowUnmapper<BoardingPass> UNMAPPER = //...}

需要注意的兩件事:我們擴展了JdbcRepository<BoardingPass, Object[]>并且按預期提供了兩個ID列名稱: "flight_no", "seq_no" 。 我們通過提供由Object[]包裹的flight_no和seq_no (必須seq_no順序)值來查詢此類DAO:

BoardingPass pass = repository.findOne(new Object[] {"FOO-1022", 42});

毫無疑問,這在實踐中很麻煩,因此我們提供了微小的輔助方法,您可以靜態導入:

import static com.blogspot.nurkiewicz.jdbcrepository.JdbcRepository.pk; //...BoardingPass foundFlight = repository.findOne(pk("FOO-1022", 42));

根據此示例,檢查JdbcRepositoryCompoundPkTest以獲取工作代碼。

交易次數

該庫與事務管理完全正交。 每個存儲庫的每種方法都需要運行事務,具體取決于您進行設置。 通常,您將@Transactional放在服務層上(稱為DAO bean)。 我不建議將@Transactional放在每個DAO bean上 。

快取

Spring Data JDBC存儲庫庫不提供任何緩存抽象或支持。 但是, 在Spring中使用緩存抽象將@Cacheable層添加@Cacheable DAO或服務之上非常簡單。 另請參見: Spring中的@Cacheable開銷 。

會費

..總是歡迎。 不要猶豫, 提交錯誤報告并提出請求 。 現在最大的缺失功能是對MSSQL和Oracle數據庫的支持。 如果有人可以看一下,那就太好了。

測試中

該庫已使用Travis( )。 測試套件包括265個測試 (53個不同的測試,每個測試針對5個不同的數據庫運行:MySQL,PostgreSQL,H2,HSQLDB和Derby。

在填寫錯誤報告或提交新功能時,請嘗試包括支持測試用例。 每個拉取請求都會在單獨的分支上自動進行測試。

建造

分叉后, 正式的存儲庫構建就像運行一樣簡單:

$ mvn install

您將在JUnit測試執行過程中注意到大量異常。 這個是正常的。 一些測試是針對僅在Travis CI服務器上可用的MySQL和PostgreSQL運行的。 當這些數據庫服務器不可用時,只需跳過整個測試:
結果:

Tests run: 265, Failures: 0, Errors: 0, Skipped: 106

異常堆棧跟蹤來自根AbstractIntegrationTest 。

設計

庫僅包含少數幾個類,如下圖所示:

JdbcRepository是實現所有PagingAndSortingRepository方法的最重要的類。 每個用戶存儲庫都必須擴展此類。 同樣,每個這樣的存儲庫必須至少實現RowMapper和RowUnmapper (僅當您要修改表數據時)。

SQL生成委托給SqlGenerator 。 PostgreSqlGenerator. 和DerbySqlGenerator用于與標準生成器不DerbySqlGenerator的數據庫。

執照

該項目是在Apache許可的 2.0版下發布的 (與Spring框架相同)。

參考: NoBlogDefFound博客中JCG合作伙伴 Tomasz Nurkiewicz 為程序員提供的概率分布 。

翻譯自: https://www.javacodegeeks.com/2013/01/spring-data-jdbc-generic-dao-implementation-most-lightweight-orm-ever.html

總結

以上是生活随笔為你收集整理的Spring Data JDBC通用DAO实现–迄今为止最轻量的ORM的全部內容,希望文章能夠幫你解決所遇到的問題。

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

精品国产乱码久久久久久1区二区 | 少妇性aaaaaaaaa视频 | 国产.精品.日韩.另类.中文.在线.播放 | 黄色一级在线视频 | 91在线视频免费91 | 久久久国产一区二区三区四区小说 | 在线观看国产v片 | 国产精品一区二区av麻豆 | 日本免费一二三区 | 99精品国产aⅴ | 久久精品免费播放 | 国产精品久久久久一区 | 国产群p| 国产日韩高清在线 | 国产在线精品一区二区三区 | 91成人小视频| 成人欧美日韩国产 | 黄色国产在线 | 精品久久99 | 欧美色图88 | 国产成人精品999 | 在线天堂视频 | 久久这里只精品 | 国产精品一区二区三区久久久 | 国产视频日韩视频欧美视频 | 久色婷婷 | 激情五月婷婷网 | 成人aⅴ视频 | 在线a视频免费观看 | 五月婷婷中文网 | 国产精品一区二区三区电影 | 一级成人免费 | 97在线免费视频观看 | 日韩在线一区二区免费 | www.五月天婷婷.com | 久久免费视频网站 | 国产成人av网址 | av资源免费看 | 成人一级电影在线观看 | 日韩欧美在线不卡 | 免费看一级黄色 | 天天曰天天曰 | 波多野结衣亚洲一区二区 | 99超碰在线播放 | 国产99视频在线观看 | 日韩综合视频在线观看 | 99久久爱 | 国产精品国产三级国产不产一地 | 久久伦理| 午夜色性片| 久久久久久久久久久精 | 激情综合五月网 | 日本最新高清不卡中文字幕 | 亚洲综合视频在线 | 成片人卡1卡2卡3手机免费看 | 国产精品黄色在线观看 | 91桃色视频 | 成人午夜剧场在线观看 | 久草视频在线资源 | 亚洲国产精品电影在线观看 | 不卡在线一区 | 成人性生交视频 | 蜜臀一区二区三区精品免费视频 | 亚洲一区 影院 | 九九av | 国产伦精品一区二区三区四区视频 | 五月婷婷六月综合 | 福利视频区 | 精品国产免费人成在线观看 | av手机在线播放 | 免费视频久久久久久久 | 日韩中文字幕在线看 | 91成人天堂久久成人 | 五月天六月色 | 国产精品av免费在线观看 | 日本最新高清不卡中文字幕 | 在线有码中文 | 天海冀一区二区三区 | 国产91aaa| 国产精品一区二区免费看 | 狠狠干婷婷 | 久草在线视频新 | 亚洲精品国产精品久久99 | 中文字幕资源网在线观看 | 久久精品久久精品 | 成人黄色电影视频 | 91人人澡人人爽人人精品 | 最近免费中文字幕mv在线视频3 | 成人午夜电影在线 | 美女在线黄 | 免费观看v片在线观看 | 久热免费在线 | 中文字幕在线看视频国产中文版 | 久久亚洲婷婷 | 精品少妇一区二区三区在线 | 免费日韩一区二区三区 | 五月花婷婷 | 波多野结衣一区二区 | 欧美久久久一区二区三区 | 玖玖玖精品 | 日韩在线播放视频 | 97人人看 | 激情视频在线高清看 | 天天天天天天天操 | 国产精品 久久 | 国产成人精品国内自产拍免费看 | 91精品国产乱码久久桃 | 久久伦理视频 | 日日碰夜夜爽 | 欧美午夜a | 国产免费二区 | 国产中文字幕在线播放 | 久久影视精品 | 日韩欧美精品一区二区 | 欧美日高清视频 | 免费成视频 | 91cn国产在线| 国产91精品久久久久久 | 久久久免费少妇 | 国产精品99在线观看 | 欧美另类高清 videos | 97电影院网| 久章操| 久久人人添人人爽添人人88v | a黄色影院 | 久久精品3 | av日韩在线网站 | 国产精品mm| 日本资源中文字幕在线 | 亚洲国产精品一区二区尤物区 | 黄色在线观看免费 | 国产又粗又猛又色又黄视频 | 六月丁香久久 | 日韩色综合 | a'aaa级片在线观看 | 日韩字幕在线观看 | 综合久久久久久久久 | 91成人久久 | 国产精品免费在线播放 | 国产生活一级片 | 美女网站久久 | 成年人在线免费看片 | 欧美日韩免费在线观看视频 | 韩日精品在线 | 97碰在线 | 色婷婷福利视频 | 色妞色视频一区二区三区四区 | 精品美女在线视频 | 亚洲精品午夜一区人人爽 | 国产欧美日韩视频 | 国产精品久久久久一区 | 91porny九色91啦中文 | 毛片网站免费 | 亚洲伊人av | 国产在线精品一区二区三区 | 亚洲日本欧美在线 | 精品久久久久久久久久岛国gif | 91综合久久一区二区 | 97免费视频在线播放 | 五月婷婷综合在线观看 | 五月激情亚洲 | 久久综合狠狠综合久久狠狠色综合 | 最近的中文字幕大全免费版 | 中文字幕日本特黄aa毛片 | 日韩成人黄色av | 久草网视频 | 看片黄网站 | 福利二区视频 | 亚洲精品中文字幕视频 | a黄在线观看| 91精品久久久久久久久久入口 | 久久性生活片 | 成人在线免费小视频 | 狠狠色香婷婷久久亚洲精品 | 狠狠色狠狠色合久久伊人 | 五月婷婷开心中文字幕 | 国产精品成人自产拍在线观看 | 在线观看日韩一区 | 日p视频 | 久久久久在线视频 | 欧美日韩国产一区二区三区 | 色婷婷www | 日本一区二区三区视频在线播放 | 国产一区二区在线免费 | 人人添人人澡 | 一区二区三区免费播放 | 亚洲日本精品视频 | 黄色三级网站在线观看 | 久草av在线播放 | 欧美黄污视频 | 不卡视频一区二区三区 | 91亚洲精品国产 | 日本乱视频 | 在线v片免费观看视频 | 久久人人97超碰精品888 | 91视频免费网址 | 狠狠色丁香久久综合网 | av久久在线| 四虎永久免费网站 | 狠狠操综合网 | 色综合久久久久网 | 黄色亚洲精品 | 正在播放国产一区 | 992tv人人草 黄色国产区 | 国产精品 中文在线 | av韩国在线 | 久久99视频 | 国产精品18久久久久久不卡孕妇 | 骄小bbw搡bbbb揉bbbb | 天天做日日爱夜夜爽 | 天天综合成人网 | 亚洲欧洲av在线 | 欧美激情另类文学 | 久久伊人色综合 | 在线观看免费日韩 | 色噜噜狠狠狠狠色综合 | 激情av一区二区 | 国产黄| 久久一线 | 国产午夜精品一区二区三区嫩草 | 国产91九色视频 | 天天爽网站 | 伊人久久婷婷 | 制服丝袜一区二区 | 香蕉在线观看视频 | 日韩欧美一区二区三区视频 | 国内精品久久久久久久久 | 色九九在线 | 亚洲精品视频一二三 | 国产成人av一区二区三区在线观看 | 婷婷五综合 | 国产欧美综合在线观看 | 一区久久久 | 中文在线a√在线 | 久久理论电影网 | 国产在线高清 | 在线观看中文字幕一区 | 人人爱人人爽 | 91桃色免费视频 | 精品在线看 | 国产精品视频永久免费播放 | 久草爱 | av电影在线不卡 | 黄色av电影免费观看 | 色综合天天干 | 亚洲91中文字幕无线码三区 | 亚洲综合导航 | 国产综合精品久久 | 美女精品在线 | 日本在线观看中文字幕无线观看 | 不卡中文字幕av | 天天爱av导航 | 中文在线中文资源 | 亚洲成人欧美 | 亚洲欧美视频一区二区三区 | 精品国产乱子伦一区二区 | 日本狠狠干 | 久久精品99国产精品亚洲最刺激 | 国产人免费人成免费视频 | 亚洲精品免费观看视频 | 国产美女视频黄a视频免费 久久综合九色欧美综合狠狠 | 在线免费看片 | 在线看片一区 | 欧美亚洲国产精品久久高清浪潮 | 精品国产欧美一区二区 | 国产视频 亚洲精品 | 欧美一区二区三区在线播放 | 日韩亚洲在线 | 狠狠操电影网 | 青青河边草免费直播 | 色狠狠婷婷 | 国产一级黄色片免费看 | 国产三级在线播放 | 欧美韩日在线 | 在线97| 国产成人精品女人久久久 | 欧美精品久久久久久久久久 | 99视频偷窥在线精品国自产拍 | 精品欧美小视频在线观看 | 一级成人在线 | 狠狠色丁香婷婷综合最新地址 | 国产午夜麻豆影院在线观看 | 午夜精品一区二区三区在线 | 国产精品成久久久久三级 | 国产精品视频免费在线观看 | 久久精品网 | 国产在线探花 | 成人黄色在线视频 | 久久艹在线 | 久久免费毛片视频 | 丁香av | 国产做a爱一级久久 | 天天骚夜夜操 | 成人小视频免费在线观看 | 成人手机在线视频 | 一区二区三区四区免费视频 | 国产在线观看 | 91精品无人成人www | 久久久久久激情 | 亚洲精品一区二区三区新线路 | 国产乱对白刺激视频在线观看女王 | 国产一区 在线播放 | 玖玖综合网 | 色婷婷88av视频一二三区 | 99热亚洲精品 | 九九热.com| www.av中文字幕.com | 丁香五月网久久综合 | 天天操夜夜操天天射 | 色天天久久 | 在线精品视频免费播放 | 亚洲精品午夜aaa久久久 | 国产一区二区不卡在线 | 久久综合狠狠综合久久激情 | 在线电影a | 日韩夜夜爽 | 中文字幕日韩无 | 狠狠狠的干 | 亚洲一级免费观看 | 四虎www.| 免费日韩av电影 | www.com黄色 | 色噜噜在线观看视频 | 91免费国产在线观看 | 久久日本视频 | 操操操com| 国产精品乱码一区二区视频 | 丁香电影小说免费视频观看 | 91视频免费网址 | 99久久99久久精品免费 | 黄色成人在线观看 | 欧美午夜视频在线 | 91免费观看 | 免费在线a | 欧美一级视频免费 | 人人爱人人添 | 国内精品久久久久影院男同志 | 97在线精品 | 国产精品成人免费 | 亚洲欧美视频在线播放 | 99色视频在线 | 久99热| 中文字幕有码在线 | 97精品国产手机 | 天天爱天天操天天爽 | 五月天激情综合 | 五月天久久婷 | 久久精品欧美一区 | 在线亚洲人成电影网站色www | 国产午夜一级毛片 | 天天躁日日躁狠狠躁av中文 | 看黄色91 | 国产九九热视频 | 在线黄网站 | 能在线看的av | 97电影在线 | 日本在线精品视频 | 在线观看视频精品 | 午夜精品久久久久99热app | 国产精品免费久久久久影院仙踪林 | 久草视频视频在线播放 | 婷婷成人综合 | 一本色道久久精品 | 天天射成人 | 日韩高清免费在线观看 | 国产99自拍| 国产美女视频免费 | 中文字幕中文字幕在线中文字幕三区 | 免费在线看v | 日韩免费在线网站 | 9草在线 | 97超碰色 | 在线观看久| 精品国产伦一区二区三区免费 | 欧美老人xxxx18 | 亚洲国产午夜精品 | 激情五月在线观看 | 99久久国产免费,99久久国产免费大片 | 亚洲午夜不卡 | 中文字幕91在线 | 五月婷婷六月丁香在线观看 | 天天操天天干天天摸 | 美女福利视频一区二区 | 视频福利在线观看 | 狠狠色狠狠色综合日日92 | 国产精品av免费观看 | 99综合久久 | 中文字幕国产在线 | 在线观看av不卡 | 在线观看亚洲精品视频 | 国产成人精品一区二区三区免费 | 日本夜夜草视频网站 | 日韩一区二区久久 | 一级片免费观看 | 国产精美视频 | 九九激情视频 | 午夜av免费 | 国产精彩视频一区 | 91在线免费看片 | 成人精品久久久 | 中字幕视频在线永久在线观看免费 | 麻豆视频一区二区 | 国产一区二区日本 | 欧美性做爰猛烈叫床潮 | 日本精品一区二区在线观看 | 国产黄色片免费 | 色婷婷视频在线 | 极品美女被弄高潮视频网站 | 最近高清中文字幕在线国语5 | 日本99精品| 久久精品视频中文字幕 | 91片黄在线观看 | 色综合久久久久综合体 | 国产日韩欧美在线观看 | 国产精品一区免费观看 | 91色吧| 色综合久久久久综合 | 日b黄色片 | 99色资源 | 色婷婷av一区 | 一本一本久久aa综合精品 | 在线观看中文字幕一区二区 | 亚洲一区 av | 免费麻豆视频 | 国产va饥渴难耐女保洁员在线观看 | 日韩视频中文字幕在线观看 | 日韩一区二区三区免费视频 | 亚洲天堂在线观看完整版 | 久久国产精品视频 | 日韩深夜在线观看 | 最近高清中文字幕 | 国产在线精品一区二区三区 | 在线观看精品 | 欧美久久久久久久久久久 | 免费情趣视频 | 开心色插 | 日韩午夜在线 | 不卡电影免费在线播放一区 | 天天干天天射天天插 | 国产精品丝袜久久久久久久不卡 | 91视频啪| 成人9ⅰ免费影视网站 | 天天视频亚洲 | 久久成人免费 | 综合色久 | 国产麻豆成人传媒免费观看 | 欧美日韩午夜在线 | 高清av网站 | 国产成人精品在线 | 久久99久久99精品免观看粉嫩 | 国产 视频 高清 免费 | 手机av电影在线观看 | 成年人在线观看网站 | 日本精品一区二区在线观看 | 日韩在线视频线视频免费网站 | 波多野结衣动态图 | 亚洲精品国偷自产在线99热 | 视频二区在线 | 中文一区二区三区在线观看 | 成人91免费视频 | 91在线成人 | 国产视频欧美视频 | 中文字幕av一区二区三区四区 | 国产又粗又猛又黄又爽视频 | 国内外成人在线视频 | 欧洲色综合 | 91污视频在线观看 | 91在线国内视频 | 亚洲黄色激情小说 | 91麻豆精品一区二区三区 | 久久久网址 | 手机av观看 | 日本久久视频 | 999热线在线观看 | 精品 一区 在线 | 国内精品久久久久影院一蜜桃 | 草久在线 | 伊人婷婷综合 | 精品国产一区二区三区久久久久久 | 国产精品视频不卡 | 激情在线网站 | 一区二区理论片 | 日韩欧美视频免费在线观看 | 4438全国亚洲精品观看视频 | 最新影院 | 中文字幕在线播放av | 超碰国产在线 | 成人wwwxxx视频 | 久久夜色精品国产亚洲aⅴ 91chinesexxx | 天堂在线视频免费观看 | 一级淫片在线观看 | 九色91福利 | 玖玖视频 | 99国产精品| 久久人人干| 超碰在线人人爱 | 国产精品一区二区免费在线观看 | 99热这里只有精品国产首页 | 天天操夜操视频 | 国产一级性生活视频 | 色综合激情网 | 91av播放 | 亚洲在线视频观看 | 天天插天天狠天天透 | 日韩91av| 久久久国产一区二区 | 日韩欧美在线视频一区二区 | 99精品久久久 | 国产不卡精品视频 | 婷婷电影在线观看 | 久久不见久久见免费影院 | 久久久精品综合 | 国产偷国产偷亚洲清高 | 91豆花在线观看 | 久久视频网址 | 国产五月天婷婷 | 日本女人逼| 中文字字幕在线 | 天天爱天天操天天干 | 欧美日韩国产mv | 一级成人免费视频 | 成人免费在线网 | 人人擦 | 免费麻豆视频 | 97激情影院 | 中文视频一区二区 | 国产情侣一区 | 精品国产一区二区三区四区在线观看 | 成人超碰在线 | 久久在线精品 | www.人人草 | 精品综合久久 | 夜夜操天天 | 99热在线看 | 色99久久 | 日韩高清在线一区 | 亚州免费视频 | 日韩字幕 | 日本最新高清不卡中文字幕 | 国产91精品一区二区麻豆亚洲 | 一级黄色片在线免费观看 | 日韩免费福利 | av3级在线 | 欧美视屏一区二区 | 久久天堂网站 | 成人h电影在线观看 | 日韩精品一区二区三区不卡 | 777视频在线观看 | 日韩精品一区二区三区外面 | 日日夜夜综合 | 全黄色一级片 | 日日夜夜干 | 免费观看全黄做爰大片国产 | 欧美激情精品久久久久久免费印度 | 极品嫩模被强到高潮呻吟91 | 久久av网| 亚洲国产理论片 | 亚洲综合色av | 最新国产在线视频 | 亚洲国产久 | 成人午夜毛片 | 麻豆国产精品视频 | 日韩在线观看第一页 | 久久国产精品免费一区二区三区 | 日韩精品视频在线观看免费 | 99久久影院 | 国产理论免费 | 91入口在线观看 | 国产成人一区二区三区久久精品 | 久久久久久久久久久综合 | 91香蕉视频在线 | 欧美精品被 | 久久久国产精品一区二区中文 | 五月婷丁香 | 国产在线精品观看 | 精品一区在线 | 亚洲成人午夜在线 | 国产美女在线观看 | 日韩专区在线 | 日韩成人av在线 | aaa毛片视频 | 日韩亚洲国产中文字幕 | 永久免费精品视频网站 | 成人国产在线 | 色综合久久久久综合99 | 99久久精品国产亚洲 | 日日爱网址 | 一级成人免费视频 | 亚洲精品www久久久久久 | 亚洲黄色一级电影 | 国产美女精彩久久 | 色a资源在线 | 91麻豆看国产在线紧急地址 | 91精品国产自产在线观看永久 | 亚洲国产视频a | 欧美日韩国产在线一区 | 国产黄色av网站 | 香蕉久久久久 | 激情丁香综合五月 | www.日日日.com| 免费观看91视频 | 国产欧美在线一区二区三区 | 免费观看一级一片 | 久久精品这里精品 | 亚洲精品女人久久久 | 精品国产免费人成在线观看 | 色夜视频 | 免费看国产曰批40分钟 | 久草网免费 | 色五月色开心色婷婷色丁香 | 免费a级黄色毛片 | 日本一区二区免费在线观看 | 一级片视频免费观看 | 中文字幕中文字幕在线中文字幕三区 | 99久热在线精品视频成人一区 | 国产在线观看你懂的 | 亚洲国产一二三 | 日本黄色免费在线 | 亚洲黄色成人网 | 久久精品视频网 | 99久久精品免费 | 人人看人人艹 | 91天堂影院 | 精品美女在线视频 | 在线观看亚洲免费视频 | 国产三级香港三韩国三级 | 欧美成人理伦片 | 99精品在线视频观看 | 九九热久久久 | 亚洲精品国产精品国 | 成年免费在线视频 | 少妇超碰在线 | 在线免费观看国产视频 | 91视频 - 114av| 精品亚洲男同gayvideo网站 | 九九综合九九 | 亚洲 综合 专区 | av资源在线看 | 成人av资源 | 国产精品9区 | 亚洲精品在线免费观看视频 | 草久久久久久 | 欧美另类视频 | 天天干天天操天天 | 999久久久久久久久久久 | 国产一级电影免费观看 | 日韩激情免费视频 | 中文字幕在线人 | 久久免费视频在线观看6 | 久久久久北条麻妃免费看 | 国产91精品看黄网站在线观看动漫 | 狠狠干夜夜爱 | 青草视频网 | 国产香蕉97碰碰久久人人 | 久久免费大片 | 亚洲精品一区二区三区在线观看 | 日韩理论影院 | 香蕉网在线播放 | 久久免费视频在线 | 欧美一级视频免费 | 99免费观看视频 | www天天干 | av免费成人 | 国产精品热视频 | 91精品国产综合久久福利 | 国产精品永久免费 | 精品久久99 | 在线观看国产区 | 92av视频 | 久久免费观看少妇a级毛片 久久久久成人免费 | 久草在线91 | 精品一区二区在线观看 | 激情网综合 | 九九热有精品 | 少妇bbr搡bbb搡bbb | 亚洲香蕉在线观看 | 亚州中文av| 国产福利91精品一区二区三区 | 婷婷在线视频 | 亚洲综合爱 | 亚洲男人天堂a | 色综合激情久久 | 国产精品手机在线观看 | 欧美粗又大 | 精品国产三级a∨在线欧美 免费一级片在线观看 | 中文字幕免费在线 | 九九热在线播放 | 国产一区二区三区 在线 | 亚洲精品视频在线播放 | 亚洲激情一区二区三区 | 97在线观看视频国产 | 大型av综合网站 | 日韩专区 在线 | www免费看| a视频在线观看 | 日韩乱理 | 99视频免费观看 | 亚洲精品免费在线观看视频 | 国内免费的中文字幕 | 丁香久久综合 | 国产五月婷婷 | 免费看黄色毛片 | 日韩综合一区二区三区 | 亚洲精品在线网站 | 国产精品一二三 | www.夜夜草| 久久久国产精品网站 | 不卡视频在线 | 综合在线观看色 | 国产福利电影网址 | 在线观看91av| 国产破处在线播放 | 波多野结衣在线播放一区 | 久久综合婷婷综合 | 日韩av免费观看网站 | 日韩av一区二区三区四区 | 久久久国产日韩 | 国产一区二区午夜 | 91精品婷婷国产综合久久蝌蚪 | 亚洲第一区在线播放 | 色天堂在线视频 | 伊人激情综合 | av直接看| 国产精品毛片一区二区 | 视频成人 | 日韩黄色av网站 | 天天色天天操天天爽 | 久久精品一区二 | 久久久久国产精品厨房 | 国产精品v a免费视频 | 久久综合桃花 | 香蕉网站在线观看 | 99久久精品国产亚洲 | 狠狠网亚洲精品 | 大荫蒂欧美视频另类xxxx | 97精品国产一二三产区 | 婷婷激情久久 | 午夜影院三级 | 色婷婷亚洲精品 | 91精品国产欧美一区二区 | 激情五月播播久久久精品 | 成人动漫精品一区二区 | 97精产国品一二三产区在线 | 午夜视频在线观看一区二区三区 | 日本不卡一区二区三区在线观看 | 91麻豆高清视频 | 国产免费专区 | 国产精品欧美激情在线观看 | 精品在线观看一区二区三区 | 国产精品中文字幕av | 久久国产精品影视 | 免费观看午夜视频 | www.狠狠 | 国产露脸91国语对白 | 久久99精品热在线观看 | 在线视频日韩一区 | 国产精品久久久久久吹潮天美传媒 | 国产精品久久久影视 | av国产在线观看 | 高清中文字幕 | 亚洲成人黄色在线观看 | 精品嫩模福利一区二区蜜臀 | 久草视频在线免费播放 | 国产区在线视频 | 91精品网站在线观看 | 国产99精品| 国产精品国产毛片 | 美女一区网站 | 黄色免费在线看 | 欧美在线日韩在线 | 欧美精品国产综合久久 | 国产乱对白刺激视频不卡 | 国产一区二区播放 | 国产精品毛片一区 | 亚洲视频1区2区 | 在线日韩中文 | 天天干夜夜爱 | 激情丁香5月 | 日韩三级成人 | 久久久久久久影院 | 开心色插 | www久久99| 久久国产精品免费看 | 亚洲黄色免费在线看 | 中中文字幕av | 91伊人久久大香线蕉蜜芽人口 | 久久69精品久久久久久久电影好 | 96av视频 | 久久久久久久久免费视频 | 成 人 免费 黄 色 视频 | 久 久久影院 | 久久国产精品免费一区二区三区 | 美女免费黄视频网站 | 久久国产色 | 在线观看色网站 | 欧美精品视 | 在线色吧 | 国产精品区二区三区日本 | 夜夜爽www | 99国产成+人+综合+亚洲 欧美 | 午夜国产福利在线 | 91日韩精品 | 亚洲午夜小视频 | 天天激情站 | 在线观看成人毛片 | 久久99久久精品 | 久久久精品国产一区二区三区 | 久久激情视频网 | 国产视频在线观看免费 | 天天爽夜夜爽人人爽曰av | 国产乱对白刺激视频在线观看女王 | www天天干 | 爱干视频| avhd高清在线谜片 | 免费国产一区二区 | 日韩欧美视频一区二区三区 | 99久久婷婷国产精品综合 | 久久久久久中文字幕 | 精品伊人久久久 | 激情综合狠狠 | 欧美网站黄色 | 国产视频欧美视频 | 91视频观看免费 | 最新av电影网站 | 一区二区三区四区五区在线 | av在线永久免费观看 | 91亚洲精品乱码久久久久久蜜桃 | 国产午夜麻豆影院在线观看 | 深夜免费小视频 | 久精品在线 | 黄色三级在线观看 | 天堂av一区二区 | 国产精品一区二区三区在线看 | 国产福利中文字幕 | 91原创在线观看 | 亚洲另类xxxx | 国产久草在线观看 | 国产99久久九九精品 | 人人澡人人添人人爽一区二区 | 日韩专区 在线 | 日韩免费区 | 97成人在线视频 | 精品久久久久国产免费第一页 | 成人一区影院 | 久久久精品视频成人 | 免费看国产曰批40分钟 | 91视频传媒| 精品国产一区二区三区久久久久久 | 精品一区欧美 | 99亚洲国产 | 欧美日比视频 | 91av官网| 天天操月月操 | 久久99精品视频 | 午夜丰满寂寞少妇精品 | 日日夜夜综合网 | 91麻豆产精品久久久久久 | 成人黄色视 | 色综合色综合久久综合频道88 | 91av视频观看 | 国产精品久久久久影院 | 五月婷婷中文网 | 中文字幕a∨在线乱码免费看 | 91女子私密保健养生少妇 | 91中文在线观看 | 成人在线免费看视频 | 午夜视频在线观看一区二区三区 | 在线欧美日韩 | 国内揄拍国产精品 | 日本婷婷色 | 久久免费黄色大片 | 人人爽人人片 | 欧美一区二区三区免费观看 | 亚洲成人av免费 | 国产精品一区免费在线观看 | 97视频在线免费观看 | 极品久久久久久久 | 欧美极品裸体 | 久久无码精品一区二区三区 | 亚洲精品国精品久久99热 | 久久96 | 日本久久中文字幕 | 精品自拍网 | 五月激情久久 | 综合色综合色 | 国产永久网站 | 久久精品96| 97国产精品亚洲精品 | 国产成人福利在线 | 亚洲精品黄色 | 久久理论片 | 亚洲精品久久久蜜桃直播 | 欧美人体xx| av看片网 | 中文永久免费观看 | 97视频免费在线看 | 国内视频1区 | 久久久久夜色 | 久久精品人人做人人综合老师 | 国产日韩精品在线观看 | 久久精选 | 日韩欧美网址 | 91热视频 | 九色91在线视频 | 欧美精品在线观看一区 | 激情五月开心 | 国产精品999久久久 久产久精国产品 | 高清视频一区 | 99se视频在线观看 | 亚洲黄色av网址 | 国产一区二区三区视频在线 | 亚洲精品播放 | 国产欧美久久久精品影院 | 亚洲国产69| 在线日本看片免费人成视久网 | 日本公乱妇视频 | 色狠狠综合 | 公开超碰在线 | 亚洲综合一区二区精品导航 | 婷婷去俺也去六月色 | 午夜精品一区二区三区免费 | 精品91| 在线观影网站 | 四虎影视精品 | 91激情在线视频 | 欧美视频国产视频 | 国产亚洲精品久久久久秋 | 免费国产在线精品 | 亚洲欧洲精品一区 | 中文字幕在线观看视频一区 | 亚洲专区欧美 | 亚洲精品在线观看视频 | 午夜国产一区二区三区四区 | 中文字幕在线免费观看 | 国产视频在线观看一区 | 久久久精品国产免费观看一区二区 | 麻豆91视频 | 亚洲电影图片小说 | 精品一区电影国产 | 欧美日韩在线精品一区二区 | 99久久精品国产一区二区成人 | 日韩三级视频在线看 | 91精品对白一区国产伦 | 久久久久久高潮国产精品视 | 亚洲欧美激情插 | 欧美a级成人淫片免费看 | 婷婷新五月 | 欧美精品久久久久久久免费 | 免费看一及片 | 国产精品久久久久久久婷婷 | 国产精品精 | 国产视频一区二区在线 | 欧美另类69 | 欧美a级在线免费观看 | 日韩免费电影在线观看 | 日韩欧美在线播放 | 日韩精品欧美专区 | 精品国产_亚洲人成在线 | 国产在线中文 | 美女网站视频免费黄 | a√天堂中文在线 | 日韩精品免费专区 | 欧美aⅴ在线观看 | 黄色免费看片网站 | 国产精品黄色 | 久久黄色片子 | 黄网站免费久久 | 在线电影av | 成人在线视频免费看 | 日韩免费不卡av | 国产亚洲精品女人久久久久久 | 91亚洲夫妻 | 丁香电影小说免费视频观看 | 久久综合狠狠综合久久狠狠色综合 | 视频一区二区三区视频 | 色婷婷av一区二 | 日韩aa视频| 欧美在线观看小视频 | 亚洲黄色av网址 | 高清一区二区 | 激情喷水 | 91日韩在线视频 | 国产一级在线播放 | 夜夜操天天干, | 在线观看中文字幕一区二区 | 日女人电影 | 在线亚洲高清视频 | 久插视频| 91在线视频精品 | 久久久久综合视频 | 亚洲精品国产欧美在线观看 | 日韩一级黄色av | 91在线色 | 九草视频在线观看 | 欧美一级视频免费看 | 久久免费精品视频 | 精品美女在线视频 | 中文字幕一区二区三区乱码在线 |