久久福利_99r_国产日韩在线视频_直接看av的网站_中文欧美日韩_久久一

您的位置:首頁技術文章
文章詳情頁

Fluent Mybatis快速入門詳細教程

瀏覽:4日期:2023-10-18 11:55:18

使用fluent mybatis可以不用寫具體的xml文件,通過java api可以構造出比較復雜的業務sql語句,做到代碼邏輯和sql邏輯的合一。 不再需要在Dao中組裝查詢或更新操作,在xml或mapper中再組裝參數。喜歡的朋友可以閱讀這篇文章 http://www.jb51.net/article/218884.htm

對底層數據表關聯關系的處理,我們總是繞不開什么一對一,一對多,多對多這里比較煩人的關系。 業界優秀的ORM框架也都給出了自己的答案,簡單來說就以下幾種方式:

hibernate和JPA對開發基本屏蔽了底層數據的處理,只需要在model層設置數據級聯關系即可。但這種設置也往往是噩夢的開始。mybatis 提供了簡單的@One @Many注解,然后編寫xml映射關系來提供級聯處理。還有一種就是干脆不依賴框架,直接應用自己掌控。因為FluentMybatis是基于mybatis上做封裝和擴展的,所以這里主要聊聊mybatis處理的方式,以及給出FluentMybatis的解放方案。

那么就可以建以下3張表:

數據字典

CREATE TABLE t_member(id bigint(21) unsigned auto_increment primary key COMMENT ‘主鍵id’,user_name varchar(45) DEFAULT NULL COMMENT ‘名字’,is_girl tinyint(1) DEFAULT 0 COMMENT ‘0:男孩; 1:女孩’,age int DEFAULT NULL COMMENT ‘年齡’,school varchar(20) DEFAULT NULL COMMENT ‘學校’,gmt_created datetime DEFAULT NULL COMMENT ‘創建時間’,gmt_modified datetime DEFAULT NULL COMMENT ‘更新時間’,is_deleted tinyint(1) DEFAULT 0 COMMENT ‘是否邏輯刪除’) ENGINE = InnoDBCHARACTER SET = utf8 COMMENT = ‘成員表:女孩或男孩信息’;CREATE TABLE t_member_love(id bigint(21) unsigned auto_increment primary key COMMENT ‘主鍵id’,girl_id bigint(21) NOT NULL COMMENT ‘member表外鍵’,boy_id bigint(21) NOT NULL COMMENT ‘member表外鍵’,status varchar(45) DEFAULT NULL COMMENT ‘狀態’,gmt_created datetime DEFAULT NULL COMMENT ‘創建時間’,gmt_modified datetime DEFAULT NULL COMMENT ‘更新時間’,is_deleted tinyint(2) DEFAULT 0 COMMENT ‘是否邏輯刪除’) ENGINE = InnoDBCHARACTER SET = utf8 COMMENT = ‘成員戀愛關系’;CREATE TABLE t_member_favorite(id bigint(21) unsigned auto_increment primary key COMMENT ‘主鍵id’,member_id bigint(21) NOT NULL COMMENT ‘member表外鍵’,favorite varchar(45) DEFAULT NULL COMMENT ‘愛好: 電影, 爬山, 徒步…’,gmt_created datetime DEFAULT NULL COMMENT ‘創建時間’,gmt_modified datetime DEFAULT NULL COMMENT ‘更新時間’,is_deleted tinyint(2) DEFAULT 0 COMMENT ‘是否邏輯刪除’) ENGINE = InnoDBCHARACTER SET = utf8 COMMENT = ‘成員愛好’;

添加項目Maven依賴具體pom.xml文件

代碼生成

public class AppEntityGenerator {static final String url = “jdbc:mysql://localhost:3306/fluent_mybatis_demo?useSSL=false&useUnicode=true&characterEncoding=utf-8”;/*** 生成代碼的package路徑*/static final String basePackage = “cn.org.fluent.mybatis.many2many.demo”;public static void main(String[] args) { FileGenerator.build(Noting.class);}@Tables( /** 數據庫連接信息 **/ url = url, username = 'root', password = 'password', /** Entity類parent package路徑 **/ basePack = basePackage, /** Entity代碼源目錄 **/ srcDir = 'example/many2many_demo/src/main/java', /** 如果表定義記錄創建,記錄修改,邏輯刪除字段 **/ gmtCreated = 'gmt_create', gmtModified = 'gmt_modified', logicDeleted = 'is_deleted', /** 需要生成文件的表 ( 表名稱:對應的Entity名稱 ) **/ tables = @Table(value = {'t_member', 't_member_love', 't_member_favorite'}, tablePrefix = 't_'))static class Noting {}}

這樣就生成了3個Entity類: MemberEntity, MemberFavoriteEntity, MemberLoveEntity。

關系分析

現在我們來理一理這里面的關系

一對多: 一個成員可以有多個愛好多對多: 一個成員可以有多個男女朋友(前任+現任)一對一: 一個成員只能有一個現任男女朋友mybatis處理手法mybatis提供了@One 和 @Many的注解來處理簡單(只有主鍵和外鍵依賴)的一對一,和一對多的關系 具體到上面的關系,mybatis只能關聯查詢成員的愛好,對帶條件的(不是只通過外鍵)現任男女朋友的一對一也沒有辦法處理。

我這里就不具體展開mybatis的配置語法了,感興趣讀者可以看下下面文章:

Mybatis一對多、多對一處理

Mybatis傳遞多個參數進行SQL查詢的用法

MyBatis注解 & 多對一、一對多

MyBatis系列4:一對一,一對多,多對多查詢及延遲加載(N+1問題)分析

鑒于mybatis只能處理簡單的關聯關系,fluent mybatis就沒有直接封裝mybatis的處理方式,那fluent mybatis是如何處理上述的關聯關系的。 我們先從mybatis也可以處理的一對多的愛好列表入手

一對多的愛好列表處理fluent mybatis要根據MemberEntity自動返回對應的愛好列表,需要下面幾個設置:

MemberEntity繼承RichEntity基類在MemberEntity類里面增加方法 findMyFavorite()給findMyFavorite方法加上注解 @RefMethod在注解中增加關聯關系: “memberId=id”,意思是 MemberFavoriteEntity.memberId等于MemberEntity.id具體代碼片段如下, 所有這些操作都可以通過代碼生成,這里手工添加僅僅是為了講解

public class MemberEntity extends RichEntity implements IEntity {// …/*** 我的愛好列表** @return*/@RefMethod(“memberId=id”)public List findMyFavorite() {return super.loadCache(“findMyFavorite”, MemberEntity.class);}}

好了,我們已經建立好通過Member實例查詢愛好列表的功能了,重新編譯項目 在generated-sources目錄下面,會多出一個文件: Refs

/***Refs:o - 查詢器,更新器工廠類單例引用o - 應用所有Mapper Bean引用o - Entity關聯對象延遲加載查詢實現@author powered by FluentMybatis*/public abstract class Refs extends EntityRefQuery {public List findMyFavoriteOfMemberEntity(MemberEntity entity) {return memberFavoriteMapper.listEntity(new MemberFavoriteQuery().where.memberId().eq(entity.getId()).end());}}

在這個類里面自動生成了一個方法: findMyFavoriteOfMemberEntity, 入參是MemberEntity, 出參是List, 實現里面根據member的id查詢了成員的所有愛好。

增加Spring Bean我們新建一個類: AllRelationQuery (名稱根據你的喜好和業務隨便取), 繼承Refs, 并把AllRelationQuery加入Spring管理即可。

@Servicepublic class AllRelationQuery extends Refs {}

老套路,寫個測試驗證下

@RunWith(SpringRunner.class)@SpringBootTest(classes = Application.class)public class FindMemberFavoriteTest {@Autowiredprivate MemberMapper memberMapper;@Beforepublic void setup() { // 省略數據準備部分}@Testpublic void findMyFavorite() { MemberEntity member = memberMapper.findById(1L); List<MemberFavoriteEntity> favorites = member.findMyFavorite(); System.out.println('愛好項: ' + favorites.size());}}

查看控制臺log輸出

DEBUG - ==> Preparing: SELECT id, …, user_name FROM t_member WHERE id = ?DEBUG - > Parameters: 1(Long)DEBUG - < Total: 1DEBUG - ==> Preparing: SELECT id, …, member_id FROM t_member_favorite WHERE member_id = ?DEBUG - > Parameters: 1(Long)DEBUG - < Total: 2愛好項: 2

如日志所示,Fluent Mybatis按照預期返回了愛好列表。

給一對多關系添點油加點醋做過業務系統的同學都知道,數據庫中業務數據一般會有一個邏輯刪除標識,按照上述邏輯查詢出來的數據,我們會把已經廢棄(邏輯刪除掉)的愛好也一并查詢出來了,那我們如何只查詢出未邏輯刪除(is_deleted=0)的愛好列表呢。

如果采用mybatis的方案,那我們只能聳聳肩,攤開雙手說: “愛莫能助,你自己寫SQL實現吧”, 但fluent mybatis對這類場景的支持的很好,我們只要給@RefMethod注解值加點條件就可以了, MemberFavoriteEntity.memberId=MemberEntity.id并且Favorite的邏輯刪除標識和Member表一樣,具體定義如下:

public class MemberEntity extends RichEntity implements IEntity {@RefMethod(“memberId=id && isDeleted=isDeleted”)public List findMyFavorite() {return super.loadCache(“findMyFavorite”, MemberEntity.class);}}

重新編譯項目,觀察Refs代碼

public abstract class Refs extends EntityRefQuery {public List findMyFavoriteOfMemberEntity(MemberEntity entity) {return memberFavoriteMapper.listEntity(new MemberFavoriteQuery().where.isDeleted().eq(entity.getIsDeleted()).and.memberId().eq(entity.getId()).end());}}

查詢條件上帶上了邏輯刪除條件

跑測試,看log

DEBUG - ==> Preparing: SELECT id, …, user_name FROM t_member WHERE id = ?DEBUG - > Parameters: 1(Long)DEBUG - < Total: 1DEBUG - ==> Preparing: SELECT id, …, member_id FROM t_member_favoriteWHERE is_deleted = ?AND member_id = ?DEBUG - > Parameters: false(Boolean), 1(Long)DEBUG - < Total: 2愛好項: 2

FluentMybatis輕松處理了多條件關聯的一對多關系, 這個在業務中不僅僅限定于邏輯刪除, 還可以推廣到部署環境標識(deploy_env), 租戶關系等條件上,還有只有你業務中才用到的狀態相關的關系上。

Fluent Mybatis對多對多關系處理fluent mybatis可以輕松處理一對一,一對多的簡單和多條件的關聯關系,但對多對多也沒有提供自動化代碼生成的處理手段。 因為多對多,本質上涉及到3張表, A表, B表,AB關聯表。 但fluent mybatis還是提供了半自動手段,對這類場景進行了支持,比如我們需要MemberEntity中返回所有前任戀人列表。

在MemberEntity中定義方法: exFriends()

public class MemberEntity extends RichEntity implements IEntity {/*** 前任男(女)朋友列表** @return*/@RefMethodpublic List findExFriends() {return super.loadCache(“findExFriends”, MemberEntity.class);}}

和上面的自動化的一對多關系有個區別,@RefMethod上沒有設置查詢條件,我們重新編譯項目。 我們觀察Refs類,除了剛才的findMyFavoriteOfMemberEntity方法實現外,還多出一個抽象方法: findExFriendsOfMemberEntity

public abstract class Refs extends EntityRefQuery {/*** 返回前任男(女)朋友列表*/public abstract List findExFriendsOfMemberEntity(MemberEntity entity);}

在動手實現代碼前,我們先分析一下混亂的男女朋友關系在member表上,我們使用了一個性別字段 is_girl來區別是男的還是女的, 在戀愛關系表上,分別有2個外鍵girl_id, boy_id來標識一對戀人關系。 這樣,如果member是女的,要查詢所有前任男朋友,那么sql語句就如下:

select * from t_memberwhere is_deleted=0and id in (select boy_id from t_memeber_lovewhere status = ‘前任’and girl_id = ? – 女孩idand is_deleted = 0)

如果member是男的,要查詢所有前任女朋友,那么sql語句條件就要倒過來:

select * from t_memberwhere is_deleted=0and id in (select girl_id from t_memeber_lovewhere status = ‘前任’and boy_id= ? – 男孩idand is_deleted = 0)

實現查詢前男(女)朋友列表功能一般來說,為了實現上面的分支查詢,在mybatis的xml文件中需要配置 這樣的標簽代碼分支, 或者在java代碼中實現 if(…){}else{}的代碼邏輯分支。 那我們來看看fluent mybatis時如何實現上述查詢的呢?我們就可以在剛才定義的Refs子類上實現findExFriendsOfMemberEntity自己的邏輯。

@Servicepublic class AllRelationQuery extends Refs {@Overridepublic List findExFriendsOfMemberEntity(MemberEntity entity) {MemberQuery query = new MemberQuery().where.isDeleted().isFalse().and.id().in(MemberLoveQuery.class, q -> q.select(entity.getIsGirl() ? boyId.column : girlId.column).where.status().eq(“前任”).and.isDeleted().isFalse().and.girlId().eq(entity.getId(), o -> entity.getIsGirl()).and.boyId().eq(entity.getId(), o -> !entity.getIsGirl()).end()).end();return memberMapper.listEntity(query);}}

寫測試看log

@RunWith(SpringRunner.class)@SpringBootTest(classes = Application.class)public class FindExFriendsTest {@Autowiredprivate MemberMapper memberMapper;@Testpublic void findExBoyFriends() { MemberEntity member = memberMapper.findById(1L); System.out.println('是否女孩:' + member.getIsGirl()); List<MemberEntity> boyFriends = member.findExFriends(); System.out.println(boyFriends);}}

控制臺日志

DEBUG - ==> Preparing: SELECT id, …, user_name FROM t_member WHERE id = ?DEBUG - > Parameters: 1(Long)DEBUG - < Total: 1是否女孩:trueDEBUG - ==> Preparing: SELECT id, …, user_name FROM t_memberWHERE is_deleted = ?AND id IN (SELECT boy_idFROM t_member_loveWHERE status = ?AND is_deleted = ?AND girl_id = ?)DEBUG - > Parameters: false(Boolean), 前任(String), false(Boolean), 1(Long)DEBUG - < Total: 1[MemberEntity(id=2, gmtModified=Sun Nov 08 12:31:57 CST 2020, isDeleted=false, age=null, gmtCreated=null, isGirl=false, school=null, userName=mike)]

如日志所示,在查詢前男友列表是,條件會根據Member的是否是女孩進行分支切換,這也是fluent mybatis動態條件強大的地方。

到此這篇關于FluentMybatis快速入門詳細教程的文章就介紹到這了,更多相關Fluent Mybatis入門內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: Mybatis 數據庫
相關文章:
主站蜘蛛池模板: 久久久久久久99精品免费观看 | 国产成人久久 | 久久亚洲精品中文字幕 | 夜夜骑av | 欧美综合国产精品久久丁香 | av片在线观看 | 毛片网站免费在线观看 | 日韩免费一区 | 日本成人三级 | 日韩一二三区视频 | 亚洲毛片在线观看 | 免费毛片网站 | 久久亚洲国产视频 | 欧美日韩成人在线播放 | 国产色| 久久精品亚洲一区 | 婷婷精品视频 | 久久影视精品 | 在线日韩中文字幕 | 国产一区二区三区久久 | 亚洲精品综合 | 欧美久久视频 | 亚洲高清一区二区三区 | 激情综合色综合久久综合 | 日本不卡一区二区 | 亚洲午夜精品一区二区三区 | 亚洲狠狠爱一区二区三区 | 91在线视频在线 | 日韩一片 | 日韩99| 国内精品一区二区三区 | a在线看| 久久69精品久久久久久久电影好 | av国产精品 | 成人av片在线观看 | 亚洲一区二区在线视频 | 中文视频一区 | 日本一区高清 | 国产日韩欧美一区 | 成人做爰69片免费 | 亚洲tv久久爽久久爽 | 一级a毛片 | 麻豆一区 | 欧美一级日韩 | 国产九九精品视频 | av久久 | 日韩91| 亚洲精品乱码久久久久久久久 | 欧美精品一区二区视频 | 91精品国产91综合久久蜜臀 | 日本黄色片免费看 | 中文字幕亚洲欧美精品一区四区 | 啪啪毛片 | 日韩免费观看视频 | 日本 欧美 国产 | 亚洲成人免费在线 | 亚洲国内精品 | www.欧美| 天天插天天操天天干 | 国产亚洲一区二区三区在线观看 | а天堂中文最新一区二区三区 | 久久密| 激情欧美一区 | 国产成人精品一区二区三区视频 | 欧美一级欧美三级在线观看 | 日韩在线播放视频 | 亚洲aaa | 三级视频网站 | 日本久久艹| 亚洲视频免费在线 | 日韩高清在线 | 婷婷丁香六月天 | 69免费视频 | 国产单男 | 婷婷久久综合 | 成人精品久久久 | 九九热欧美| 久久亚洲天堂 | 日韩福利视频导航 | 久久久精品影院 | 国产一区二区三区精品久久久 | 99久久久国产精品美女 | 99热免费在线| 国产欧美综合一区 | 日韩一区二区成人 | 1000部精品久久久久久久久 | 国产免费一区二区三区四区五区 | 国产成人精品一区二区在线 | 欧美在线视频三区 | 日韩www视频 | 黄久久久| av免费网站在线观看 | 亚洲精品日本 | 国产欧美精品一区二区三区四区 | 亚洲一区二区在线视频 | 婷婷av在线| 日韩激情视频一区二区 | 香蕉久久网 | 天堂免费在线 | 日韩电影专区 | 亚洲精品美女久久 | 久久精品久久久 | 国产精品久久久久久久久久三级 | 九九精品视频在线 | 亚洲黄网在线观看 | 国产精品高清在线观看 | 久久久久久久久久久久久久久久久久久 | 亚洲成av人片一区二区三区 | 一级免费黄色免费片 | 精品久久久久久久久久久久久久 | 日韩一区二区三区在线观看 | 亚洲中午字幕 | 97精品久久 | 久久亚洲一区 | 亚洲h在线观看 | 欧美精品久 | 麻豆专区一区二区三区四区五区 | 天天摸夜夜操 | 黄色国产一级视频 | 国产精品99一区二区三区 | 久久99精品国产99久久6男男 | 久久com | 成人不卡在线 | 日韩在线不卡 | 成人自拍视频 | 亚洲一区在线日韩在线深爱 | 国产在线观看一区二区 | 国产乱a视频在线 | 色婷婷综合久久久中字幕精品久久 | 亚洲精品乱码8久久久久久日本 | 激情伊人 | 国产日韩一区二区三区 | 成人午夜精品一区二区三区 | 久国产精品视频 | 高清国产视频 | 男女羞羞羞视频午夜视频 | 1级毛片 | 91国自产精品中文字幕亚洲 | 嫩草研究院在线观看入口 | 欧美精三区欧美精三区 | 午夜精品影院 | 一级a毛片 | 亚洲网站在线播放 | 午夜三级在线 | 久久久久国产一区二区三区 | 中国大陆高清aⅴ毛片 | 亚洲一区二区三区高清 | 国产精品一二 | 一级毛片免费网站 | 亚洲午夜av | 久久久久91| 久久午夜影院 | 91精品久久久久久久久入口 | 毛片一区二区 | 91极品在线 | 亚洲aⅴ天堂av在线电影软件 | 人人爱夜夜爽日日视频 | 看一级黄色大片 | 最新国产在线 | 国产精品久久久久久久久动漫 | 日韩欧美中文字幕在线视频 | 国产日韩精品一区 | 亚洲视频一区二区三区 | h视频在线免费观看 | 成人在线h| 久草在线青青草 | 综合天天 | 久久亚洲一区二区三区四区 | 在线播放黄色片网站 | 国产一区二区三区四区在线观看 | 怡红院免费在线视频 | 国产精品对白一区二区三区 | 成人精品视频免费 | 免费黄色小视频 | 一级a毛片 | 日本免费一区二区三区 | 久久亚洲一区 | 亚洲一区视频网站 | 国产一区二区视频免费 | 欧美一级欧美三级在线观看 | 91视频精选 | 中文字幕在线观看一区二区三区 | 亚洲国产欧美一区二区三区久久 | 精品国产一区二区三区性色 | 91中文字幕在线 | 欧美视频网站 | 爱爱视频网站 | 日韩欧美在线不卡 | 日韩1区3区4区第一页 | 国产aaa大片| 亚洲电影一区二区 | 久久久久国产一区二区三区四区 | 亚洲视频一区在线 | 国产精品美女久久久久久久久久久 | 色xx综合网| 国产精品一区二区三 | 精品视频在线观看 | 啊啊啊网站 | 特级黄一级播放 | 国产激情精品一区二区三区 | 澳门av | 久久国产亚洲精品 | 91精品在线播放 | 国产区在线 | 欧美xxxx网站 | 美女视频黄色 | 亚洲欧美日韩另类一区二区 | 大黑人交xxx极品hd | 午夜成人免费视频 | 久久大 | 国产精品人人做人人爽 | 中国一级大黄大黄大色毛片 | 久久在线视频 | 欧美成人精品一区二区三区在线看 | 成人性视频在线 | 亚洲综合区 | 亚洲国产视频一区 | 成人欧美一区二区三区在线播放 | www.天天操.com| 黄色片网站在线免费观看 | 亚洲欧美中文日韩在线v日本 | 亚洲一区av | 精品久久国产 | 日韩毛片| 久久国产欧美日韩精品 | a视频在线观看 | 成人亚洲视频 | 午夜大片网 | 亚洲欧美在线综合 | 亚洲免费观看 | 成人福利在线 | 国产在线一二三区 | 最新免费av网站 | 日韩欧美高清dvd碟片 | 嫩草91 | 亚洲精品久久久久久久久久久久久 | 精品一级| 久久久免费av | t66y最新地址一地址二69 | 成人午夜视频在线观看 | 福利在线看| 日本高清视频在线播放 | 日本高清视频一区二区三区 | 美女在线视频一区二区 | 99热最新网站| 黄频免费在线观看 | 欧美性影院 | 欧美大片免费高清观看 | 国产精品亚洲欧美日韩一区在线 | 自拍偷拍精品 | 久久一级| 日韩国伦理久久一区 | 色人人| 免费观看黄色一级大片 | 三级成人片 | 亚洲精品视频在线播放 | 日日爽 | 高清国产午夜精品久久久久久 | 国产精品视频入口 | 一本大道久久a久久精二百 国产精品片aa在线观看 | 欧美日韩一区二区在线观看 | 久久久一区二区 | 日日爱视频 | 伊人网在线视频免费观看 | 国产成人久久精品麻豆二区 | 中文字幕在线视频第一页 | 日本一区二区三区四区 | 一级做a毛片 | 成人免费毛片高清视频 | 日韩av视屏 | 亚洲精久久 | 精品国产乱码久久久久久1区2区 | 一区二区日韩精品 | 狠狠爱综合 | 中文字幕电影在线 | 一区二区三区日本 | 亚洲 欧美 日韩在线 | 欧美成人a∨高清免费观看 在线视频成人 | 国产人妖一区二区 | 国产在线不卡视频 | 国产一区二区成人 | 亚洲国产精品一区二区三区 | 国产成人精品亚洲日本在线观看 | 国产精品久久久久久久久久小说 | 狠狠狠色丁香婷婷综合久久五月 | 久久99精品久久久久久久青青日本 | 免费成人av| 91短视频版在线观看www免费 | 亚洲免费视频网站 | 黄色av网站免费 | 成人精品久久久 | 精品综合久久久 | 91视频网址 | 国产高清精品一区二区三区 | 久久精品欧美一区二区三区不卡 | 欧美色视频在线观看 | 国产精品国产精品国产专区不卡 | 午夜精品久久久久久久久久久久 | 亚洲精品成人久久久 | 国产精品毛片久久久久久久 | 国产成人精品一区二区三区视频 | 狠狠操夜夜操天天操 | 欧美日韩视频 | 综合天天| 国产精品久久国产精品 | 国产美女在线观看 | 久久精品一区二区三区四区毛片 | 欧美综合久久 | 日韩一区二区不卡 | 福利视频网址导航 | 亚洲一区二区三区在线视频 | 欧美日韩成人在线观看 | 欧美精品一区在线观看 | 国产精品成人一区二区三区夜夜夜 | 夜夜操操操 | 成人精品网站在线观看 | 国产成人看片 | а天堂中文最新一区二区三区 | 国产毛片一区二区 | 在线观看91| 一区二区三区小视频 | 久久久久久久久久一区二区 | 九色91视频 | 色婷婷在线视频观看 | www.精品| 97热在线| 婷婷久久综合九色综合绿巨人 | 免费观看毛片 | 91麻豆精品国产91久久久久久久久 | 欧美成人黑人xx视频免费观看 | 成年人网站在线免费看 | 在线亚洲一区 | 国产综合久久久久久鬼色 | 一级在线| 亚洲综合在线播放 | 成人免费在线播放 | 亚洲综合色视频在线观看 | 欧美成人一区二区三区片免费 | 国产精品大全 | 日韩一区二区三区在线视频 | 日韩国产精品视频 | 日韩激情免费 | 天堂精品久久 | 欧洲毛片 | 日韩一区精品视频 | 亚洲精品久久久蜜臀 | 亚洲一区中文字幕 | 9191在线 | 亚洲视频在线一区 | 国产精品一区二区三区在线播放 | 欧美电影一区 | 97久久久| 精品美女在线观看视频在线观看 | 一区二区三区免费 | 国产精品成人3p一区二区三区 | 伊人色综合久久久天天蜜桃 | 久在线视频播放免费视频 | 国产一区中文字幕 | 成人一区二区三区在线 | 暖暖日本在线视频 | 国产精品日韩在线观看 | 免费看国产片在线观看 | 久久国产精品免费一区二区三区 | 国产一区二区三区网站 | 麻豆视频91 | 久久四色 | a国产精品| 欧美成人精品激情在线观看 | 欧美日韩国产一区二区 | 国产麻豆乱码精品一区二区三区 | 国产一区二区免费 | 国产在线不卡 | 一本色道精品久久一区二区三区 | 午夜影院在线 | 日韩一区二区三区在线 | 99精品视频免费 | 午夜久久视频 | 欧美激情一区二区三区四区 | 99视频网站 | 国产一级一级毛片女人精品 | 成人精品在线视频 | 国产二区视频 | 国产高清网站 | 日本精品二区 | 日本精品视频在线观看 | 综合五月网 | 国产一区二区免费 | 天天草综合 | 国产精品久久久久毛片软件 | 日韩欧美国产精品综合嫩v 国产高清av在线一区二区三区 | 日本不卡免费新一二三区 | 成人在线免费 | 国产成人av一区二区三区 | 亚州中文字幕蜜桃视频 | 国产精品一区在线观看你懂的 | 久久99久久99精品免观看粉嫩 | 日本一级中文字幕久久久久久 | 日韩亚洲一区二区 | 亚洲成人福利在线观看 | 国产精品国产a级 | 君岛美绪一区二区三区 | 国产精品视频99 | 亚洲无吗电影 | 久久久精品一区 | 精品日韩一区二区 | 久久伊人成人网 | 91中文字幕一区 | jizz在线播放 | 亚洲精久久 | 三区在线 | 影音先锋成人资源网 | 国产精品久久久久久二区 | 国产老女人精品毛片久久 | 在线看一级片 | 日韩亚洲在线 | 欧美午夜寂寞影院 | 亚洲激情在线观看 | 日韩视频一区二区三区四区 | 日韩一区二区三区在线视频 | 色综合久久久久久久久久久 | 欧美日韩一区二区三区 | 亚洲第一男人天堂 | 亚洲成人在线视频网站 | 精一区二区 | jizz中国zz女人18高潮 | 日韩理伦在线 | 九色在线观看 | 国产视频综合在线 | 精品免费国产一区二区三区四区 | 一区二区三区四区国产 | 黑人巨大精品欧美黑白配亚洲 | 久久综合爱 | 久久精品小视频 | 国产精品福利网站 | 天天看天天操 | 91欧美激情一区二区三区成人 | 成人免费淫片视频观 | 久久99精品久久久噜噜最新章节 | 国产成人精品久久二区二区 | 国产欧美精品一区二区三区 | 中文亚洲欧美 | 国产精品成人一区二区 | 草久在线视频 | 日本精品一区二区三区在线观看视频 | 日本精品免费在线观看 | 亚洲一区二区三区在线 | 日韩一区二区三区在线观看 | 欧美极品一区二区三区 | 中文字幕国产一区 | 久久精品免费一区二区三区 | 久久久国产精品 | 午夜窝窝 | 欧美在线视频一区二区 | 欧美精品一区二区三区在线四季 | 国产精品一区二区三区四区五区 | 亚洲精品国精品久久99热 | 国产精品久久久久久一区二区三区 | 日韩在线免费 | 国产午夜视频 | 免费一级 国产 | 久久精品一 | 综合网av | 成人福利 | 奇米在线777 | 亚洲高清在线观看 | 欧美日韩成人在线观看 | 人人干天天操 | 亚洲高清免费视频 | 日本一区二区在线视频 | 亚洲国产精品第一区二区 | a级性生活 | 欧美一区二区三区精品 | 黄色在线观看网址 | 99热播在线 | 国产精品成人一区二区三区 | 久久999| 成人av片在线观看 | 国产精品久久免费视频 | a在线v| 精品久久久久久久久久久久 | 国产成人免费视频网站高清观看视频 | 在线观看日韩 | 欧美成人精品一区二区三区 | 日韩毛片免费看 | 国产精品久久久久国产a级 91福利网站在线观看 | 日本成人小视频 | 日韩一级免费在线观看 | 亚洲精选一区 | 伊人在线 | 99re在线| 亚洲国产精品福利 | 欧美久久一区二区 | 国产精品久久久久久久久久久久久久 | av免费网站在线观看 | 国产精品久久一区 | 国内精品久久久久 | 久久综合九九 | 欧美日本韩国一区二区 | 91人人澡人人爽 | 亚洲国产福利一区 | 欧美综合一区二区三区 | 国产精品一区二区av | 国产精品免费看 | 久久精视频 | av免费在线观看网站 | 欧美日韩一区二区三区在线观看 | 欧美日韩免费一区二区三区 | 日本一区二区精品 | 国产最新网站 | 成人av片在线观看 | 欧美性猛交一区二区三区精品 | 一区二区三区久久 | 国产真实精品久久二三区 | 国产自在现线2019 | 水卜樱一区二区av | 精品在线一区二区三区 | 午夜精品一区二区三区免费视频 | 欧美日韩综合视频 | 成人毛片在线视频 | 在线视频一二区 | 欧美黑人一区 | 国产成人精品一区二区三区视频 | 欧美日韩国产一区二区三区 | 久久一二三区 | 五月激情天| 国产精品久久久久一区二区三区 | 日韩福利在线观看 | 欧美日韩精品一区二区三区 | 日韩国伦理久久一区 | 91中文字幕在线观看 | 这里有精品视频 | 欧美一区二区久久久 | 日本久久久久 | 色综合久久88色综合天天 | 久久久免费 | 国产成人综合网 | 91社区影院 | 国产高清一区二区 | 欧美精品一区二区三区一线天视频 | 欧美卡一卡二 | 中文字幕亚洲在线 | 国产欧美一区二区视频 | 欧美久久一区二区三区 | 综合在线视频 | 精品国产31久久久久久 | 精品99在线 | 久久一区二区三区四区 | 91精品国产高清一区二区三区 | 91性高湖久久久久久久久网站 | 日韩在线观看视频一区二区 | 91亚色| 精品国产一区二区三区久久影院 | 天堂中文资源在线 | 亚洲第一免费网站 | 国产成人在线免费观看 | 女朋友的闺蜜3韩国三级 | 欧美成人精品在线 | 色综合久久久久 | 男人天堂av网站 | 成人网av | 国产日韩一区二区三免费高清 | 久久99精品国产99久久6男男 | 99re国产精品视频 | 国产日韩精品视频 | 香蕉久久av一区二区三区 | 亚洲高清在线视频 | 欧美亚洲视频在线观看 | 精品二区| 中文字幕 国产精品 | 综合二区 | japanhd熟睡侵犯| 亚洲国产91| 亚洲精品久久 | 永久91嫩草亚洲精品人人 | 综合网在线 | 成人免费在线播放 | 欧美精三区欧美精三区 | 久久国产成人午夜av影院宅 | 精品免费视频 | 狠狠操综合网 | 亚洲精品在线视频观看 | 中文字幕亚洲欧美日韩在线不卡 | 69免费视频 | 三区免费视频 | 狠狠狠干 | 33eee在线视频免费观看 | 久久精品欧美一区二区三区不卡 | 精品久久久久久久久久久久久久 | av网站观看| av在线一区二区三区 | 中文字幕三区 | 国产高清精品一区二区三区 | 中文字幕在线观看 | 国产精品毛片久久久久久久 | 精品久久一区二区 | 色综合99 | 三级av在线 | 久久精品国产99国产精2020新增功能 | 亚洲精品一区二区三区四区高清 | 色噜噜视频在线观看 | 91在线一区二区 | 国产成人一区 | 亚洲精品久久 | 丁香久久 | 波多野结衣三区 | 国产日韩欧美精品 | 在线激情av | 91精品久久久久久久久久久久久久久 | 在线国产一区 | 精品久久网站 | 精品久久久久久久久久久久久久久 | 国产成人啪精品午夜在线观看 | 伊人精品视频 | 99精品国产在热久久 | 日本免费一区二区视频 |