3atv精品不卡视频,97人人超碰国产精品最新,中文字幕av一区二区三区人妻少妇,久久久精品波多野结衣,日韩一区二区三区精品

歡迎訪問(wèn) 生活随笔!

生活随笔

當(dāng)前位置: 首頁(yè) > 编程资源 > 编程问答 >内容正文

编程问答

mybatis plus 使用技巧

發(fā)布時(shí)間:2023/12/20 编程问答 18 豆豆
生活随笔 收集整理的這篇文章主要介紹了 mybatis plus 使用技巧 小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

mybatis plus 看這篇就夠了,一發(fā)入魂

文章目錄

  • mybatis plus 看這篇就夠了,一發(fā)入魂
  • 一、mybatis plus 介紹
  • 二、快速入門
    • 1.創(chuàng)建一個(gè)SpringBoot項(xiàng)目
    • 2.導(dǎo)入依賴
    • 3.配置數(shù)據(jù)庫(kù)
    • 4.創(chuàng)建一個(gè)實(shí)體類
    • 5.創(chuàng)建一個(gè)mapper接口
    • 6.在SpringBoot啟動(dòng)類上配置mapper接口的掃描路徑
    • 7.在數(shù)據(jù)庫(kù)中創(chuàng)建表
    • 8.編寫一個(gè)SpringBoot測(cè)試類
  • 三、核心功能
    • 1.注解
    • 2.CRUD接口
      • Mapper CRUD接口
      • Service CRUD 接口
    • 3.條件構(gòu)造器
      • **使用示例**:
      • Condition
      • 實(shí)體對(duì)象作為條件
      • allEq方法
      • lambda條件構(gòu)造器
    • 4.更新操作
    • 5.刪除操作
    • 6.自定義SQL
      • 分頁(yè)查詢
        • 1.創(chuàng)建mp的分頁(yè)攔截器,注冊(cè)到Spring容器中
        • 2.執(zhí)行分頁(yè)查詢
        • 3.其他
    • 7.AR模式
    • 8.主鍵策略
      • 配置
        • 基本配置
        • 進(jìn)階配置
    • 9.代碼生成器
    • 10.高級(jí)功能
      • 邏輯刪除
      • 自動(dòng)填充
      • 樂(lè)觀鎖插件
      • 性能分析插件
      • 多租戶SQL解析器
      • 動(dòng)態(tài)表名SQL解析器
  • 四、總結(jié)


一、mybatis plus 介紹

????官方網(wǎng)站:baomidou.com
????mybatis-plus是一款Mybatis增強(qiáng)工具,用于簡(jiǎn)化開發(fā),提高效率。下文使用縮寫mp來(lái)簡(jiǎn)化表示mybatis-plus,本文主要介紹mp搭配SpringBoot的使用。

二、快速入門

1.創(chuàng)建一個(gè)SpringBoot項(xiàng)目

2.導(dǎo)入依賴

pom.xml:

<!-- pom.xml --> <?xml version="1.0" encoding="UTF-8"?> <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd"><modelVersion>4.0.0</modelVersion><parent><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-parent</artifactId><version>2.3.4.RELEASE</version><relativePath/> <!-- lookup parent from repository --></parent><groupId>com.example</groupId><artifactId>mybatis-plus</artifactId><version>0.0.1-SNAPSHOT</version><name>mybatis-plus</name><properties><java.version>1.8</java.version></properties><dependencies><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter</artifactId></dependency><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-test</artifactId><scope>test</scope></dependency><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-configuration-processor</artifactId></dependency><dependency><groupId>com.baomidou</groupId><artifactId>mybatis-plus-boot-starter</artifactId><version>3.4.2</version></dependency><dependency><groupId>mysql</groupId><artifactId>mysql-connector-java</artifactId><scope>runtime</scope></dependency><dependency><groupId>org.projectlombok</groupId><artifactId>lombok</artifactId></dependency></dependencies><build><plugins><plugin><groupId>org.springframework.boot</groupId><artifactId>spring-boot-maven-plugin</artifactId></plugin></plugins></build> </project>

3.配置數(shù)據(jù)庫(kù)

application.yml:

# application.yml spring:datasource:driver-class-name: com.mysql.cj.jdbc.Driverurl: jdbc:mysql://localhost:3306/yogurt?serverTimezone=Asia/Shanghai&useUnicode=true&characterEncoding=utf8username: rootpassword: rootmybatis-plus:configuration:log-impl: org.apache.ibatis.logging.stdout.StdOutImpl #開啟SQL語(yǔ)句打印

4.創(chuàng)建一個(gè)實(shí)體類

package com.example.mp.po; import lombok.Data; import java.time.LocalDateTime; @Data public class User {private Long id;private String name;private Integer age;private String email;private Long managerId;private LocalDateTime createTime; }

5.創(chuàng)建一個(gè)mapper接口

package com.example.mp.mappers; import com.baomidou.mybatisplus.core.mapper.BaseMapper; import com.example.mp.po.User; public interface UserMapper extends BaseMapper<User> { }

6.在SpringBoot啟動(dòng)類上配置mapper接口的掃描路徑

package com.example.mp; import org.mybatis.spring.annotation.MapperScan; import org.springframework.boot.SpringApplication; import org.springframework.boot.autoconfigure.SpringBootApplication; @SpringBootApplication @MapperScan("com.example.mp.mappers") public class MybatisPlusApplication {public static void main(String[] args) {SpringApplication.run(MybatisPlusApplication.class, args);} }

7.在數(shù)據(jù)庫(kù)中創(chuàng)建表

DROP TABLE IF EXISTS user; CREATE TABLE user ( id BIGINT(20) PRIMARY KEY NOT NULL COMMENT '主鍵', name VARCHAR(30) DEFAULT NULL COMMENT '姓名', age INT(11) DEFAULT NULL COMMENT '年齡', email VARCHAR(50) DEFAULT NULL COMMENT '郵箱', manager_id BIGINT(20) DEFAULT NULL COMMENT '直屬上級(jí)id', create_time DATETIME DEFAULT NULL COMMENT '創(chuàng)建時(shí)間', CONSTRAINT manager_fk FOREIGN KEY(manager_id) REFERENCES user (id) ) ENGINE=INNODB CHARSET=UTF8;INSERT INTO user (id, name, age ,email, manager_id, create_time) VALUES (1, '大BOSS', 40, 'boss@baomidou.com', NULL, '2021-03-22 09:48:00'), (2, '李經(jīng)理', 40, 'boss@baomidou.com', 1, '2021-01-22 09:48:00'), (3, '黃主管', 40, 'boss@baomidou.com', 2, '2021-01-22 09:48:00'), (4, '吳組長(zhǎng)', 40, 'boss@baomidou.com', 2, '2021-02-22 09:48:00'), (5, '小菜', 40, 'boss@baomidou.com', 2, '2021-02-22 09:48:00')

8.編寫一個(gè)SpringBoot測(cè)試類

package com.example.mp; import com.example.mp.mappers.UserMapper; import com.example.mp.po.User; import org.junit.Test; import org.junit.runner.RunWith; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.boot.test.context.SpringBootTest; import org.springframework.test.context.junit4.SpringRunner; import java.util.List; import static org.junit.Assert.*; @RunWith(SpringRunner.class) @SpringBootTest public class SampleTest {@Autowiredprivate UserMapper mapper;@Testpublic void testSelect() {List<User> list = mapper.selectList(null);assertEquals(5, list.size());list.forEach(System.out::println);} }

項(xiàng)目目錄如下:

運(yùn)行測(cè)試類

????可以看到,針對(duì)單表的基本CRUD操作,只需要?jiǎng)?chuàng)建好實(shí)體類,并創(chuàng)建一個(gè)繼承自BaseMapper的接口即可,可謂非常簡(jiǎn)潔。并且,我們注意到,User類中的managerId,createTime屬性,自動(dòng)和數(shù)據(jù)庫(kù)表中的manager_id,create_time對(duì)應(yīng)了起來(lái),這是因?yàn)閙p自動(dòng)做了數(shù)據(jù)庫(kù)下劃線命名,到Java類的駝峰命名之間的轉(zhuǎn)化。

三、核心功能

1.注解

????mybatis plus 用在Java的實(shí)體類上面的8個(gè)注解:

@TableName
注解在類上,指定類和數(shù)據(jù)庫(kù)表的映射關(guān)系。實(shí)體類的類名(轉(zhuǎn)成小寫后)和數(shù)據(jù)庫(kù)表名相同時(shí),可以不指定該注解。

@TableId
注解在實(shí)體類的某一字段上,表示這個(gè)字段對(duì)應(yīng)數(shù)據(jù)庫(kù)表的主鍵。當(dāng)主鍵名為id時(shí)(表中列名為id,實(shí)體類中字段名為id),無(wú)需使用該注解顯式指定主鍵,mp會(huì)自動(dòng)關(guān)聯(lián)。若類的字段名和表的列名不一致,可用value屬性指定表的列名。另,這個(gè)注解有個(gè)重要的屬性type,用于指定主鍵策略,參見主鍵策略小節(jié)

@TableField
注解在某一字段上,指定Java實(shí)體類的字段和數(shù)據(jù)庫(kù)表的列的映射關(guān)系。這個(gè)注解有如下幾個(gè)應(yīng)用場(chǎng)景。

  • 排除非表字段

????若Java實(shí)體類中某個(gè)字段,不對(duì)應(yīng)表中的任何列,它只是用于保存一些額外的,或組裝后的數(shù)據(jù),則可以設(shè)置exist屬性為false,這樣在對(duì)實(shí)體對(duì)象進(jìn)行插入時(shí),會(huì)忽略這個(gè)字段。

  • 字段驗(yàn)證策略

????通過(guò)insertStrategy,updateStrategy,whereStrategy屬性進(jìn)行配置,可以控制在實(shí)體對(duì)象進(jìn)行插入,更新,或作為WHERE條件時(shí),對(duì)象中的字段要如何組裝到SQL語(yǔ)句中。

  • 字段填充策略

????通過(guò)fill屬性指定,字段為空時(shí)會(huì)進(jìn)行自動(dòng)填充。

@Version
樂(lè)觀鎖注解。

@EnumValue
注解在枚舉字段上。

@TableLogic
邏輯刪除。

@KeySequence
序列主鍵策略(oracle)。

@InterceptorIgnore
插件過(guò)濾規(guī)則。

2.CRUD接口

????mp封裝了一些最基礎(chǔ)的CRUD方法,只需要直接繼承mp提供的接口,無(wú)需編寫任何SQL,即可食用。mp提供了兩套接口,分別是Mapper CRUD接口和Service CRUD接口。并且mp還提供了條件構(gòu)造器Wrapper,可以方便地組裝SQL語(yǔ)句中的WHERE條件。

Mapper CRUD接口

????只需定義好實(shí)體類,然后創(chuàng)建一個(gè)接口,繼承mp提供的BaseMapper,即可食用。mp會(huì)在mybatis啟動(dòng)時(shí),自動(dòng)解析實(shí)體類和表的映射關(guān)系,并注入帶有通用CRUD方法的mapper。BaseMapper里提供的方法,部分列舉如下:

insert(T entity) 插入一條記錄。
deleteById(Serializable id) 根據(jù)主鍵id刪除一條記錄。
delete(Wrapper wrapper) 根據(jù)條件構(gòu)造器wrapper進(jìn)行刪除。
selectById(Serializable id) 根據(jù)主鍵id進(jìn)行查找。
selectBatchIds(Collection idList) 根據(jù)主鍵id進(jìn)行批量查找。
selectByMap(Map<String,Object> map) 根據(jù)map中指定的列名和列值進(jìn)行等值匹配查找。
selectMaps(Wrapper wrapper) 根據(jù) wrapper 條件,查詢記錄,將查詢結(jié)果封裝為一個(gè)Map,Map的key為結(jié)果的列,value為值。
selectList(Wrapper wrapper) 根據(jù)條件構(gòu)造器wrapper進(jìn)行查詢。
update(T entity, Wrapper wrapper) 根據(jù)條件構(gòu)造器wrapper進(jìn)行更新。
updateById(T entity)

????簡(jiǎn)單的使用示例如前文快速入門小節(jié),下面講解幾個(gè)比較特別的方法:

  • selectMaps

????BaseMapper接口還提供了一個(gè)selectMaps方法,這個(gè)方法會(huì)將查詢結(jié)果封裝為一個(gè)Map,Map的key為結(jié)果的列,value為值。
該方法的使用場(chǎng)景如下:

只查部分列
當(dāng)某個(gè)表的列特別多,而SELECT的時(shí)候只需要選取個(gè)別列,查詢出的結(jié)果也沒(méi)必要封裝成Java實(shí)體類對(duì)象時(shí)(只查部分列時(shí),封裝成實(shí)體后,實(shí)體對(duì)象中的很多屬性會(huì)是null),則可以用selectMaps,獲取到指定的列后,再自行進(jìn)行處理即可。

@Testpublic void test3() {QueryWrapper<User> wrapper = new QueryWrapper<>();wrapper.select("id","name","email").likeRight("name","黃");List<Map<String, Object>> maps = userMapper.selectMaps(wrapper);maps.forEach(System.out::println);}

  • 進(jìn)行數(shù)據(jù)統(tǒng)計(jì)
// 按照直屬上級(jí)進(jìn)行分組,查詢每組的平均年齡,最大年齡,最小年齡 /** select avg(age) avg_age ,min(age) min_age, max(age) max_age from user group by manager_id having sum(age) < 500; **/@Test public void test3() {QueryWrapper<User> wrapper = new QueryWrapper<>();wrapper.select("manager_id", "avg(age) avg_age", "min(age) min_age", "max(age) max_age").groupBy("manager_id").having("sum(age) < {0}", 500);List<Map<String, Object>> maps = userMapper.selectMaps(wrapper);maps.forEach(System.out::println); }

  • selectObjs

只會(huì)返回第一個(gè)字段(第一列)的值,其他字段會(huì)被舍棄

@Test public void test3() {QueryWrapper<User> wrapper = new QueryWrapper<>();wrapper.select("id", "name").like("name", "黃");List<Object> objects = userMapper.selectObjs(wrapper);objects.forEach(System.out::println); }

  • selectCount
    查詢滿足條件的總數(shù),注意,使用這個(gè)方法,不能調(diào)用QueryWrapper的select方法設(shè)置要查詢的列了。這個(gè)方法會(huì)自動(dòng)添加select count(1)
@Test public void test3() {QueryWrapper<User> wrapper = new QueryWrapper<>();wrapper.like("name", "黃");Integer count = userMapper.selectCount(wrapper);System.out.println(count); }

Service CRUD 接口

????另外一套CRUD是Service層的,只需要編寫一個(gè)接口,繼承IService,并創(chuàng)建一個(gè)接口實(shí)現(xiàn)類,即可食用。(這個(gè)接口提供的CRUD方法,和Mapper接口提供的功能大同小異,比較明顯的區(qū)別在于IService支持了更多的批量化操作,如saveBatch,saveOrUpdateBatch等方法。

  • 首先,新建一個(gè)接口,繼承IService
  • package com.example.mp.service;import com.baomidou.mybatisplus.extension.service.IService; import com.example.mp.po.User;public interface UserService extends IService<User> { }
  • 創(chuàng)建這個(gè)接口的實(shí)現(xiàn)類,并繼承ServiceImpl,最后打上@Service注解,注冊(cè)到Spring容器中,即可使用
  • package com.example.mp.service.impl;import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; import com.example.mp.mappers.UserMapper; import com.example.mp.po.User; import com.example.mp.service.UserService; import org.springframework.stereotype.Service;@Service public class UserServiceImpl extends ServiceImpl<UserMapper, User> implements UserService { }
  • 測(cè)試代碼
  • package com.example.mp;import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; import com.baomidou.mybatisplus.core.toolkit.Wrappers; import com.example.mp.po.User; import com.example.mp.service.UserService; import org.junit.Test; import org.junit.runner.RunWith; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.boot.test.context.SpringBootTest; import org.springframework.test.context.junit4.SpringRunner; @RunWith(SpringRunner.class) @SpringBootTest public class ServiceTest {@Autowiredprivate UserService userService;@Testpublic void testGetOne() {LambdaQueryWrapper<User> wrapper = Wrappers.<User>lambdaQuery();wrapper.gt(User::getAge, 28);User one = userService.getOne(wrapper, false); // 第二參數(shù)指定為false,使得在查到了多行記錄時(shí),不拋出異常,而返回第一條記錄System.out.println(one);} }


    另,IService也支持鏈?zhǔn)秸{(diào)用,代碼寫起來(lái)非常簡(jiǎn)潔,查詢示例如下

    @Test public void testChain() {List<User> list = userService.lambdaQuery().gt(User::getAge, 39).likeRight(User::getName, "王").list();list.forEach(System.out::println); }

    更新語(yǔ)句:

    @Test public void testChain() {userService.lambdaUpdate().gt(User::getAge, 39).likeRight(User::getName, "王").set(User::getEmail, "w39@baomidou.com").update(); }

    刪除語(yǔ)句:

    @Test public void testChain() {userService.lambdaUpdate().like(User::getName, "青蛙").remove(); }

    3.條件構(gòu)造器

    ????mp讓我覺得極其方便的一點(diǎn)在于其提供了強(qiáng)大的條件構(gòu)造器Wrapper,可以非常方便的構(gòu)造WHERE條件。條件構(gòu)造器主要涉及到3個(gè)類,AbstractWrapper。QueryWrapper,UpdateWrapper,它們的類關(guān)系如下:

    ????mp在AbstractWrapper中提供了非常多的方法用于構(gòu)建WHERE條件,而QueryWrapper針對(duì)SELECT語(yǔ)句,提供了select()方法,可自定義需要查詢的列,而UpdateWrapper針對(duì)UPDATE語(yǔ)句,提供了set()方法,用于構(gòu)造set語(yǔ)句。條件構(gòu)造器也支持lambda表達(dá)式,寫起來(lái)非常舒爽。
    下面對(duì)AbstractWrapper中用于構(gòu)建SQL語(yǔ)句中的WHERE條件的方法進(jìn)行部分列舉:

    • eq:equals,等于
    • allEq:all equals,全等于
    • ne:not equals,不等于
    • gt:greater than ,大于 >
    • ge:greater than or equals,大于等于≥
    • lt:less than,小于<
    • le:less than or equals,小于等于≤
    • between:相當(dāng)于SQL中的BETWEEN
    • notBetween
    • like:模糊匹配。like(“name”,“黃”),相當(dāng)于SQL的name like ‘%黃%’
    • likeRight:模糊匹配右半邊。likeRight(“name”,“黃”),相當(dāng)于SQL的name like ‘黃%’
    • likeLeft:模糊匹配左半邊。likeLeft(“name”,“黃”),相當(dāng)于SQL的name like ‘%黃’
    • notLike:notLike(“name”,“黃”),相當(dāng)于SQL的name not like ‘%黃%’
    • isNull
    • isNotNull
    • in
    • and:SQL連接符AND
    • or:SQL連接符OR
    • apply:用于拼接SQL,該方法可用于數(shù)據(jù)庫(kù)函數(shù),并可以動(dòng)態(tài)傳參

    使用示例

    // 案例先展示需要完成的SQL語(yǔ)句,后展示W(wǎng)rapper的寫法// 1. 名字中包含佳,且年齡小于25 // SELECT * FROM user WHERE name like '%佳%' AND age < 25 QueryWrapper<User> wrapper = new QueryWrapper<>(); wrapper.like("name", "佳").lt("age", 25); List<User> users = userMapper.selectList(wrapper); // 下面展示SQL時(shí),僅展示W(wǎng)HERE條件;展示代碼時(shí), 僅展示W(wǎng)rapper構(gòu)建部分// 2. 姓名為黃姓,且年齡大于等于20,小于等于40,且email字段不為空 // name like '黃%' AND age BETWEEN 20 AND 40 AND email is not null wrapper.likeRight("name","黃").between("age", 20, 40).isNotNull("email");// 3. 姓名為黃姓,或者年齡大于等于40,按照年齡降序排列,年齡相同則按照id升序排列 // name like '黃%' OR age >= 40 order by age desc, id asc wrapper.likeRight("name","黃").or().ge("age",40).orderByDesc("age").orderByAsc("id");// 4.創(chuàng)建日期為2021年3月22日,并且直屬上級(jí)的名字為李姓 // date_format(create_time,'%Y-%m-%d') = '2021-03-22' AND manager_id IN (SELECT id FROM user WHERE name like '李%') wrapper.apply("date_format(create_time, '%Y-%m-%d') = {0}", "2021-03-22") // 建議采用{index}這種方式動(dòng)態(tài)傳參, 可防止SQL注入.inSql("manager_id", "SELECT id FROM user WHERE name like '李%'"); // 上面的apply, 也可以直接使用下面這種方式做字符串拼接,但當(dāng)這個(gè)日期是一個(gè)外部參數(shù)時(shí),這種方式有SQL注入的風(fēng)險(xiǎn) wrapper.apply("date_format(create_time, '%Y-%m-%d') = '2021-03-22'");// 5. 名字為王姓,并且(年齡小于40,或者郵箱不為空) // name like '王%' AND (age < 40 OR email is not null) wrapper.likeRight("name", "王").and(q -> q.lt("age", 40).or().isNotNull("email"));// 6. 名字為王姓,或者(年齡小于40并且年齡大于20并且郵箱不為空) // name like '王%' OR (age < 40 AND age > 20 AND email is not null) wrapper.likeRight("name", "王").or(q -> q.lt("age",40).gt("age",20).isNotNull("email"));// 7. (年齡小于40或者郵箱不為空) 并且名字為王姓 // (age < 40 OR email is not null) AND name like '王%' wrapper.nested(q -> q.lt("age", 40).or().isNotNull("email")).likeRight("name", "王");// 8. 年齡為30,31,34,35 // age IN (30,31,34,35) wrapper.in("age", Arrays.asList(30,31,34,35)); // 或 wrapper.inSql("age","30,31,34,35");// 9. 年齡為30,31,34,35, 返回滿足條件的第一條記錄 // age IN (30,31,34,35) LIMIT 1 wrapper.in("age", Arrays.asList(30,31,34,35)).last("LIMIT 1");// 10. 只選出id, name 列 (QueryWrapper 特有) // SELECT id, name FROM user; wrapper.select("id", "name");// 11. 選出id, name, age, email, 等同于排除 manager_id 和 create_time // 當(dāng)列特別多, 而只需要排除個(gè)別列時(shí), 采用上面的方式可能需要寫很多個(gè)列, 可以采用重載的select方法,指定需要排除的列 wrapper.select(User.class, info -> {String columnName = info.getColumn();return !"create_time".equals(columnName) && !"manager_id".equals(columnName);});

    Condition

    ????條件構(gòu)造器的諸多方法中,均可以指定一個(gè)boolean類型的參數(shù)condition,用來(lái)決定該條件是否加入最后生成的WHERE語(yǔ)句中,比如:

    String name = "黃"; // 假設(shè)name變量是一個(gè)外部傳入的參數(shù) QueryWrapper<User> wrapper = new QueryWrapper<>(); wrapper.like(StringUtils.hasText(name), "name", name); // 僅當(dāng) StringUtils.hasText(name) 為 true 時(shí), 會(huì)拼接這個(gè)like語(yǔ)句到WHERE中 // 其實(shí)就是對(duì)下面代碼的簡(jiǎn)化 if (StringUtils.hasText(name)) {wrapper.like("name", name); }

    實(shí)體對(duì)象作為條件

    ????調(diào)用構(gòu)造函數(shù)創(chuàng)建一個(gè)Wrapper對(duì)象時(shí),可以傳入一個(gè)實(shí)體對(duì)象。后續(xù)使用這個(gè)Wrapper時(shí),會(huì)以實(shí)體對(duì)象中的非空屬性,構(gòu)建WHERE條件(默認(rèn)構(gòu)建等值匹配的WHERE條件,這個(gè)行為可以通過(guò)實(shí)體類里各個(gè)字段上的@TableField注解中的condition屬性進(jìn)行改變)。

    @Test public void test3() {User user = new User();user.setName("黃主管");user.setAge(28);QueryWrapper<User> wrapper = new QueryWrapper<>(user);List<User> users = userMapper.selectList(wrapper);users.forEach(System.out::println); }

    執(zhí)行結(jié)果如下。可以看到,是根據(jù)實(shí)體對(duì)象中的非空屬性,進(jìn)行了等值匹配查詢。

    若希望針對(duì)某些屬性,改變等值匹配的行為,則可以在實(shí)體類中用@TableField注解進(jìn)行配置,示例如下:

    package com.example.mp.po; import com.baomidou.mybatisplus.annotation.SqlCondition; import com.baomidou.mybatisplus.annotation.TableField; import lombok.Data; import java.time.LocalDateTime; @Data public class User {private Long id;@TableField(condition = SqlCondition.LIKE) // 配置該字段使用like進(jìn)行拼接private String name;private Integer age;private String email;private Long managerId;private LocalDateTime createTime; } @Test public void test3() {User user = new User();user.setName("黃");QueryWrapper<User> wrapper = new QueryWrapper<>(user);List<User> users = userMapper.selectList(wrapper);users.forEach(System.out::println); }

    從下圖得到的結(jié)果來(lái)看,對(duì)于實(shí)體對(duì)象中的name字段,采用了like進(jìn)行拼接

    @TableField中配置的condition屬性實(shí)則是一個(gè)字符串,SqlCondition類中預(yù)定義了一些字符串以供選擇

    package com.baomidou.mybatisplus.annotation;public class SqlCondition {//下面的字符串中, %s 是占位符, 第一個(gè) %s 是列名, 第二個(gè) %s 是列的值public static final String EQUAL = "%s=#{%s}";public static final String NOT_EQUAL = "%s&lt;&gt;#{%s}";public static final String LIKE = "%s LIKE CONCAT('%%',#{%s},'%%')";public static final String LIKE_LEFT = "%s LIKE CONCAT('%%',#{%s})";public static final String LIKE_RIGHT = "%s LIKE CONCAT(#{%s},'%%')"; }

    SqlCondition中提供的配置比較有限,當(dāng)我們需要<或>等拼接方式,則需要自己定義。比如:

    package com.example.mp.po; import com.baomidou.mybatisplus.annotation.SqlCondition; import com.baomidou.mybatisplus.annotation.TableField; import lombok.Data; import java.time.LocalDateTime; @Data public class User {private Long id;@TableField(condition = SqlCondition.LIKE)private String name;@TableField(condition = "%s &gt; #{%s}") // 這里相當(dāng)于大于, 其中 &gt; 是字符實(shí)體private Integer age;private String email;private Long managerId;private LocalDateTime createTime; }

    測(cè)試:

    @Test public void test3() {User user = new User();user.setName("黃");user.setAge(30);QueryWrapper<User> wrapper = new QueryWrapper<>(user);List<User> users = userMapper.selectList(wrapper);users.forEach(System.out::println); }

    從下圖得到的結(jié)果,可以看出,name屬性是用like拼接的,而age屬性是用>拼接的

    allEq方法

    allEq方法傳入一個(gè)map,用來(lái)做等值匹配

    @Test public void test3() {QueryWrapper<User> wrapper = new QueryWrapper<>();Map<String, Object> param = new HashMap<>();param.put("age", 40);param.put("name", "黃飛飛");wrapper.allEq(param);List<User> users = userMapper.selectList(wrapper);users.forEach(System.out::println); }


    當(dāng)allEq方法傳入的Map中有value為null的元素時(shí),默認(rèn)會(huì)設(shè)置為is null

    @Test public void test3() {QueryWrapper<User> wrapper = new QueryWrapper<>();Map<String, Object> param = new HashMap<>();param.put("age", 40);param.put("name", null);wrapper.allEq(param);List<User> users = userMapper.selectList(wrapper);users.forEach(System.out::println); }


    若想忽略map中value為null的元素,可以在調(diào)用allEq時(shí),設(shè)置參數(shù)boolean null2IsNull為false

    @Test public void test3() {QueryWrapper<User> wrapper = new QueryWrapper<>();Map<String, Object> param = new HashMap<>();param.put("age", 40);param.put("name", null);wrapper.allEq(param, false);List<User> users = userMapper.selectList(wrapper);users.forEach(System.out::println); }


    若想要在執(zhí)行allEq時(shí),過(guò)濾掉Map中的某些元素,可以調(diào)用allEq的重載方法allEq(BiPredicate<R, V> filter, Map<R, V> params)

    @Test public void test3() {QueryWrapper<User> wrapper = new QueryWrapper<>();Map<String, Object> param = new HashMap<>();param.put("age", 40);param.put("name", "黃飛飛");wrapper.allEq((k,v) -> !"name".equals(k), param); // 過(guò)濾掉map中key為name的元素List<User> users = userMapper.selectList(wrapper);users.forEach(System.out::println); }

    lambda條件構(gòu)造器

    ????lambda條件構(gòu)造器,支持lambda表達(dá)式,可以不必像普通條件構(gòu)造器一樣,以字符串形式指定列名,它可以直接以實(shí)體類的方法引用來(lái)指定列。示例如下:

    @Test public void testLambda() {LambdaQueryWrapper<User> wrapper = new LambdaQueryWrapper<>();wrapper.like(User::getName, "黃").lt(User::getAge, 30);List<User> users = userMapper.selectList(wrapper);users.forEach(System.out::println); }


    像普通的條件構(gòu)造器,列名是用字符串的形式指定,無(wú)法在編譯期進(jìn)行列名合法性的檢查,這就不如lambda條件構(gòu)造器來(lái)的優(yōu)雅。

    另外,還有個(gè)鏈?zhǔn)絣ambda條件構(gòu)造器,使用示例如下:

    @Test public void testLambda() {LambdaQueryChainWrapper<User> chainWrapper = new LambdaQueryChainWrapper<>(userMapper);List<User> users = chainWrapper.like(User::getName, "黃").gt(User::getAge, 30).list();users.forEach(System.out::println); }

    4.更新操作

    上面介紹的都是查詢操作,現(xiàn)在來(lái)講更新和刪除操作。
    BaseMapper中提供了2個(gè)更新方法

    • updateById(T entity)
      根據(jù)入?yún)ntity的id(主鍵)進(jìn)行更新,對(duì)于entity中非空的屬性,會(huì)出現(xiàn)在UPDATE語(yǔ)句的SET后面,即entity中非空的屬性,會(huì)被更新到數(shù)據(jù)庫(kù),示例如下:
    @RunWith(SpringRunner.class) @SpringBootTest public class UpdateTest {@Autowiredprivate UserMapper userMapper;@Testpublic void testUpdate() {User user = new User();user.setId(2L);user.setAge(18);userMapper.updateById(user);} }

    • update(T entity, Wrapper wrapper)
      根據(jù)實(shí)體entity和條件構(gòu)造器wrapper進(jìn)行更新,示例如下:
    @Test public void testUpdate2() {User user = new User();user.setName("王三蛋");LambdaUpdateWrapper<User> wrapper = new LambdaUpdateWrapper<>();wrapper.between(User::getAge, 26,31).likeRight(User::getName,"吳");userMapper.update(user, wrapper);}


    額外演示一下,把實(shí)體對(duì)象傳入Wrapper,即用實(shí)體對(duì)象構(gòu)造WHERE條件的案例:

    @Test public void testUpdate3() {User whereUser = new User();whereUser.setAge(40);whereUser.setName("王");LambdaUpdateWrapper<User> wrapper = new LambdaUpdateWrapper<>(whereUser);User user = new User();user.setEmail("share@baomidou.com");user.setManagerId(10L);userMapper.update(user, wrapper); }

    注意到我們的User類中,對(duì)name屬性和age屬性進(jìn)行了如下的設(shè)置

    @Data public class User {private Long id;@TableField(condition = SqlCondition.LIKE)private String name;@TableField(condition = "%s &gt; #{%s}")private Integer age;private String email;private Long managerId;private LocalDateTime createTime; }


    再額外演示一下,鏈?zhǔn)絣ambda條件構(gòu)造器的使用

    @Test public void testUpdate5() {LambdaUpdateChainWrapper<User> wrapper = new LambdaUpdateChainWrapper<>(userMapper);wrapper.likeRight(User::getEmail, "share").like(User::getName, "飛飛").set(User::getEmail, "ff@baomidou.com").update(); }

    反思
    ????由于BaseMapper提供的2個(gè)更新方法都是傳入一個(gè)實(shí)體對(duì)象去執(zhí)行更新,這在需要更新的列比較多時(shí)還好,若想要更新的只有那么一列,或者兩列,則創(chuàng)建一個(gè)實(shí)體對(duì)象就顯得有點(diǎn)麻煩。針對(duì)這種情況,UpdateWrapper提供有set方法,可以手動(dòng)拼接SQL中的SET語(yǔ)句,此時(shí)可以不必傳入實(shí)體對(duì)象,示例如下:

    @Test public void testUpdate4() {LambdaUpdateWrapper<User> wrapper = new LambdaUpdateWrapper<>();wrapper.likeRight(User::getEmail, "share").set(User::getManagerId, 9L);userMapper.update(null, wrapper); }

    5.刪除操作

    BaseMapper一共提供了如下幾個(gè)用于刪除的方法

    • deleteById 根據(jù)主鍵id進(jìn)行刪除
    • deleteBatchIds 根據(jù)主鍵id進(jìn)行批量刪除
    • deleteByMap 根據(jù)Map進(jìn)行刪除(Map中的key為列名,value為值,根據(jù)列和值進(jìn)行等值匹配)
    • delete(Wrapper wrapper) 根據(jù)條件構(gòu)造器Wrapper進(jìn)行刪除

    6.自定義SQL

    當(dāng)mp提供的方法還不能滿足需求時(shí),可以使用mp提供的Wrapper條件構(gòu)造器,來(lái)自定義SQL。

    • 注解方式
    package com.example.mp.mappers; import com.baomidou.mybatisplus.core.conditions.Wrapper; import com.baomidou.mybatisplus.core.mapper.BaseMapper; import com.baomidou.mybatisplus.core.toolkit.Constants; import com.example.mp.po.User; import org.apache.ibatis.annotations.Param; import org.apache.ibatis.annotations.Select; import java.util.List;public interface UserMapper extends BaseMapper<User> {// SQL中不寫WHERE關(guān)鍵字,且固定使用${ew.customSqlSegment}@Select("select * from user ${ew.customSqlSegment}")List<User> findAll(@Param(Constants.WRAPPER)Wrapper<User> wrapper); }
    • xml方式
    package com.example.mp.mappers; import com.baomidou.mybatisplus.core.conditions.Wrapper; import com.baomidou.mybatisplus.core.mapper.BaseMapper; import com.example.mp.po.User; import java.util.List;public interface UserMapper extends BaseMapper<User> {List<User> findAll(Wrapper<User> wrapper); } <!-- UserMapper.xml --> <?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd"> <mapper namespace="com.example.mp.mappers.UserMapper"><select id="findAll" resultType="com.example.mp.po.User">SELECT * FROM user ${ew.customSqlSegment}</select> </mapper>

    分頁(yè)查詢

    BaseMapper中提供了2個(gè)方法進(jìn)行分頁(yè)查詢,分別是selectPage和selectMapsPage,前者會(huì)將查詢的結(jié)果封裝成Java實(shí)體對(duì)象,后者會(huì)封裝成Map<String,Object>。分頁(yè)查詢的使用示例如下:

    1.創(chuàng)建mp的分頁(yè)攔截器,注冊(cè)到Spring容器中

    package com.example.mp.config; import com.baomidou.mybatisplus.annotation.DbType; import com.baomidou.mybatisplus.extension.plugins.MybatisPlusInterceptor; import com.baomidou.mybatisplus.extension.plugins.inner.PaginationInnerInterceptor; import org.springframework.context.annotation.Bean; import org.springframework.context.annotation.Configuration;@Configuration public class MybatisPlusConfig {/** 新版mp **/@Beanpublic MybatisPlusInterceptor mybatisPlusInterceptor() {MybatisPlusInterceptor interceptor = new MybatisPlusInterceptor();interceptor.addInnerInterceptor(new PaginationInnerInterceptor(DbType.MYSQL));return interceptor;}/** 舊版mp 用 PaginationInterceptor **/ }

    2.執(zhí)行分頁(yè)查詢

    @Test public void testPage() {LambdaQueryWrapper<User> wrapper = new LambdaQueryWrapper<>();wrapper.ge(User::getAge, 28);// 設(shè)置分頁(yè)信息, 查第3頁(yè), 每頁(yè)2條數(shù)據(jù)Page<User> page = new Page<>(3, 2);// 執(zhí)行分頁(yè)查詢Page<User> userPage = userMapper.selectPage(page, wrapper);System.out.println("總記錄數(shù) = " + userPage.getTotal());System.out.println("總頁(yè)數(shù) = " + userPage.getPages());System.out.println("當(dāng)前頁(yè)碼 = " + userPage.getCurrent());// 獲取分頁(yè)查詢結(jié)果List<User> records = userPage.getRecords();records.forEach(System.out::println); }

    3.其他

    ????注意到,分頁(yè)查詢總共發(fā)出了2次SQL,一次查總記錄數(shù),一次查具體數(shù)據(jù)。若希望不查總記錄數(shù),僅查分頁(yè)結(jié)果。可以通過(guò)Page的重載構(gòu)造函數(shù),指定isSearchCount為false即可

    public Page(long current, long size, boolean isSearchCount)

    ????在實(shí)際開發(fā)中,可能遇到多表聯(lián)查的場(chǎng)景,此時(shí)BaseMapper中提供的單表分頁(yè)查詢的方法無(wú)法滿足需求,需要自定義SQL,示例如下(使用單表查詢的SQL進(jìn)行演示,實(shí)際進(jìn)行多表聯(lián)查時(shí),修改SQL語(yǔ)句即可)

    • 在mapper接口中定義一個(gè)函數(shù),接收一個(gè)Page對(duì)象為參數(shù),并編寫自定義SQL
    // 這里采用純注解方式。當(dāng)然,若SQL比較復(fù)雜,建議還是采用XML的方式 @Select("SELECT * FROM user ${ew.customSqlSegment}") Page<User> selectUserPage(Page<User> page, @Param(Constants.WRAPPER) Wrapper<User> wrapper); @Test public void testPage2() {LambdaQueryWrapper<User> wrapper = new LambdaQueryWrapper<>();wrapper.ge(User::getAge, 28).likeRight(User::getName, "王");Page<User> page = new Page<>(3,2);Page<User> userPage = userMapper.selectUserPage(page, wrapper);System.out.println("總記錄數(shù) = " + userPage.getTotal());System.out.println("總頁(yè)數(shù) = " + userPage.getPages());userPage.getRecords().forEach(System.out::println); }

    7.AR模式

    ActiveRecord模式,通過(guò)操作實(shí)體對(duì)象,直接操作數(shù)據(jù)庫(kù)表。與ORM有點(diǎn)類似。

    • 讓實(shí)體類User繼承自Model
    package com.example.mp.po;import com.baomidou.mybatisplus.annotation.SqlCondition; import com.baomidou.mybatisplus.annotation.TableField; import com.baomidou.mybatisplus.extension.activerecord.Model; import lombok.Data; import lombok.EqualsAndHashCode; import java.time.LocalDateTime;@EqualsAndHashCode(callSuper = false) @Data public class User extends Model<User> {private Long id;@TableField(condition = SqlCondition.LIKE)private String name;@TableField(condition = "%s &gt; #{%s}")private Integer age;private String email;private Long managerId;private LocalDateTime createTime; }
    • 直接調(diào)用實(shí)體對(duì)象上的方法
    @Test public void insertAr() {User user = new User();user.setId(15L);user.setName("我是AR豬");user.setAge(1);user.setEmail("ar@baomidou.com");user.setManagerId(1L);boolean success = user.insert(); // 插入System.out.println(success); }

    8.主鍵策略

    ????在定義實(shí)體類時(shí),用@TableId指定主鍵,而其type屬性,可以指定主鍵策略。

    ????mp支持多種主鍵策略,默認(rèn)的策略是基于雪花算法的自增id。全部主鍵策略定義在了枚舉類IdType中,IdType有如下的取值。

    • AUTO
      數(shù)據(jù)庫(kù)ID自增,依賴于數(shù)據(jù)庫(kù)。在插入操作生成SQL語(yǔ)句時(shí),不會(huì)插入主鍵這一列

    • NONE
      未設(shè)置主鍵類型。若在代碼中沒(méi)有手動(dòng)設(shè)置主鍵,則會(huì)根據(jù)主鍵的全局策略自動(dòng)生成(默認(rèn)的主鍵全局策略是基于雪花算法的自增ID)

    • INPUT
      需要手動(dòng)設(shè)置主鍵,若不設(shè)置。插入操作生成SQL語(yǔ)句時(shí),主鍵這一列的值會(huì)是null。oracle的序列主鍵需要使用這種方式

    • ASSIGN_ID
      當(dāng)沒(méi)有手動(dòng)設(shè)置主鍵,即實(shí)體類中的主鍵屬性為空時(shí),才會(huì)自動(dòng)填充,使用雪花算法

    • ASSIGN_UUID
      當(dāng)實(shí)體類的主鍵屬性為空時(shí),才會(huì)自動(dòng)填充,使用UUID

    ????可以針對(duì)每個(gè)實(shí)體類,使用@TableId注解指定該實(shí)體類的主鍵策略,這可以理解為局部策略。若希望對(duì)所有的實(shí)體類,都采用同一種主鍵策略,挨個(gè)在每個(gè)實(shí)體類上進(jìn)行配置,則太麻煩了,此時(shí)可以用主鍵的全局策略。只需要在application.yml進(jìn)行配置即可。比如,配置了全局采用自增主鍵策略。

    # application.yml mybatis-plus:global-config:db-config:id-type: auto

    下面對(duì)不同主鍵策略的行為進(jìn)行演示:

    • AUTO
      在User上對(duì)id屬性加上注解,然后將MYSQL的user表修改其主鍵為自增。
    @EqualsAndHashCode(callSuper = false) @Data public class User extends Model<User> {@TableId(type = IdType.AUTO)private Long id;@TableField(condition = SqlCondition.LIKE)private String name;@TableField(condition = "%s &gt; #{%s}")private Integer age;private String email;private Long managerId;private LocalDateTime createTime; }
    • NONE
      在MYSQL的user表中,去掉主鍵自增。然后修改User類(若不配置@TableId注解,默認(rèn)主鍵策略也是NONE)
    @TableId(type = IdType.NONE) private Long id;

    插入時(shí),若實(shí)體類的主鍵ID有值,則使用之;若主鍵ID為空,則使用主鍵全局策略,來(lái)生成一個(gè)ID。

    小結(jié)
    ????AUTO依賴于數(shù)據(jù)庫(kù)的自增主鍵,插入時(shí),實(shí)體對(duì)象無(wú)需設(shè)置主鍵,插入成功后,主鍵會(huì)被寫回實(shí)體對(duì)象。
    ????INPUT完全依賴于用戶輸入。實(shí)體對(duì)象中主鍵ID是什么,插入到數(shù)據(jù)庫(kù)時(shí)就設(shè)置什么。若有值便設(shè)置值,若為null則設(shè)置null。
    ????其余的幾個(gè)策略,都是在實(shí)體對(duì)象中主鍵ID為空時(shí),才會(huì)自動(dòng)生成。
    ????NONE會(huì)跟隨全局策略,ASSIGN_ID采用雪花算法,ASSIGN_UUID采用UUID。
    ????全局配置,在application.yml中進(jìn)行即可;針對(duì)單個(gè)實(shí)體類的局部配置,使用**@TableId**即可。對(duì)于某個(gè)實(shí)體類,若它有局部主鍵策略,則采用之,否則,跟隨全局策略。

    配置

    mybatis plus有許多可配置項(xiàng),可在application.yml中進(jìn)行配置,如上面的全局主鍵策略。下面列舉部分配置項(xiàng)。

    基本配置

    • configLocation:若有單獨(dú)的mybatis配置,用這個(gè)注解指定mybatis的配置文件(mybatis的全局配置文件)
    • mapperLocations:mybatis mapper所對(duì)應(yīng)的xml文件的位置
    • typeAliasesPackage:mybatis的別名包掃描路徑

    進(jìn)階配置

    • mapUnderscoreToCamelCase:是否開啟自動(dòng)駝峰命名規(guī)則映射。(默認(rèn)開啟)
    • dbTpe:數(shù)據(jù)庫(kù)類型。一般不用配,會(huì)根據(jù)數(shù)據(jù)庫(kù)連接url自動(dòng)識(shí)別
    • fieldStrategy:(已過(guò)時(shí))字段驗(yàn)證策略。該配置項(xiàng)在最新版的mp文檔中已經(jīng)找不到了,被細(xì)分成了insertStrategy,updateStrategy,selectStrategy。默認(rèn)值是NOT_NULL,即對(duì)于實(shí)體對(duì)象中非空的字段,才會(huì)組裝到最終的SQL語(yǔ)句中。

    有如下幾種可選配置

    • IGNORED:忽略校驗(yàn)。即,不做校驗(yàn)。實(shí)體對(duì)象中的全部字段,無(wú)論值是什么,都如實(shí)地被組裝到SQL語(yǔ)句中(為NULL的字段在SQL語(yǔ)句中就組裝為NULL)
    • NOT_NULL:非NULL校驗(yàn)。只會(huì)將非NULL的字段組裝到SQL語(yǔ)句中
    • NOT_EMPTY:非空校驗(yàn)。當(dāng)有字段是字符串類型時(shí),只組裝非空字符串;對(duì)其他類型的字段,等同于NOT_NULL
    • NEVER:不加入SQL。所有字段不加入到SQL語(yǔ)句

    ????這個(gè)配置項(xiàng),可在application.yml中進(jìn)行全局配置,也可以在某一實(shí)體類中,對(duì)某一字段用@TableField注解進(jìn)行局部配置。

    ????這個(gè)字段驗(yàn)證策略有什么用呢?在UPDATE操作中能夠體現(xiàn)出來(lái),若用一個(gè)User對(duì)象執(zhí)行UPDATE操作,我們希望只對(duì)User對(duì)象中非空的屬性,更新到數(shù)據(jù)庫(kù)中,其他屬性不做更新,則NOT_NULL可以滿足需求。而若updateStrategy配置為IGNORED,則不會(huì)進(jìn)行非空判斷,會(huì)將實(shí)體對(duì)象中的全部屬性如實(shí)組裝到SQL中,這樣,執(zhí)行UPDATE時(shí),可能就將一些不想更新的字段,設(shè)置為了NULL。

    • tablePrefix:添加表名前綴
      比如
    mybatis-plus:global-config:db-config:table-prefix: xx_

    然后將MYSQL中的表做一下修改。但Java實(shí)體類保持不變(仍然為User)。

    @Test public void test3() {QueryWrapper<User> wrapper = new QueryWrapper<>();wrapper.like("name", "黃");Integer count = userMapper.selectCount(wrapper);System.out.println(count); }

    可以看到拼接出來(lái)的SQL,在表名前面添加了前綴

    9.代碼生成器

    mp提供一個(gè)生成器,可快速生成Entity實(shí)體類,Mapper接口,Service,Controller等全套代碼。

    示例如下:

    public class GeneratorTest {@Testpublic void generate() {AutoGenerator generator = new AutoGenerator();// 全局配置GlobalConfig config = new GlobalConfig();String projectPath = System.getProperty("user.dir");// 設(shè)置輸出到的目錄config.setOutputDir(projectPath + "/src/main/java");config.setAuthor("yogurt");// 生成結(jié)束后是否打開文件夾config.setOpen(false);// 全局配置添加到 generator 上generator.setGlobalConfig(config);// 數(shù)據(jù)源配置DataSourceConfig dataSourceConfig = new DataSourceConfig();dataSourceConfig.setUrl("jdbc:mysql://localhost:3306/yogurt?serverTimezone=Asia/Shanghai");dataSourceConfig.setDriverName("com.mysql.cj.jdbc.Driver");dataSourceConfig.setUsername("root");dataSourceConfig.setPassword("root");// 數(shù)據(jù)源配置添加到 generatorgenerator.setDataSource(dataSourceConfig);// 包配置, 生成的代碼放在哪個(gè)包下PackageConfig packageConfig = new PackageConfig();packageConfig.setParent("com.example.mp.generator");// 包配置添加到 generatorgenerator.setPackageInfo(packageConfig);// 策略配置StrategyConfig strategyConfig = new StrategyConfig();// 下劃線駝峰命名轉(zhuǎn)換strategyConfig.setNaming(NamingStrategy.underline_to_camel);strategyConfig.setColumnNaming(NamingStrategy.underline_to_camel);// 開啟lombokstrategyConfig.setEntityLombokModel(true);// 開啟RestControllerstrategyConfig.setRestControllerStyle(true);generator.setStrategy(strategyConfig);generator.setTemplateEngine(new FreemarkerTemplateEngine());// 開始生成generator.execute();} }

    10.高級(jí)功能

    邏輯刪除

    ????首先,為什么要有邏輯刪除呢?直接刪掉不行嗎?當(dāng)然可以,但日后若想要恢復(fù),或者需要查看這些數(shù)據(jù),就做不到了。邏輯刪除是為了方便數(shù)據(jù)恢復(fù),和保護(hù)數(shù)據(jù)本身價(jià)值的一種方案。
    ????日常中,我們?cè)陔娔X中刪除一個(gè)文件后,也僅僅是把該文件放入了回收站,日后若有需要還能進(jìn)行查看或恢復(fù)。當(dāng)我們確定不再需要某個(gè)文件,可以將其從回收站中徹底刪除。這也是類似的道理。
    ????mp提供的邏輯刪除實(shí)現(xiàn)起來(lái)非常簡(jiǎn)單,只需要在application.yml中進(jìn)行邏輯刪除的相關(guān)配置即可。

    mybatis-plus:global-config:db-config:logic-delete-field: deleted # 全局邏輯刪除的實(shí)體字段名logic-delete-value: 1 # 邏輯已刪除值(默認(rèn)為1)logic-not-delete-value: 0 # 邏輯未刪除值(默認(rèn)為0)# 若邏輯已刪除和未刪除的值和默認(rèn)值一樣,則可以不配置這2項(xiàng)

    測(cè)試:

    package com.example.mp; import com.example.mp.mappers.User2Mapper; import com.example.mp.po.User2; import org.junit.Test; import org.junit.runner.RunWith; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.boot.test.context.SpringBootTest; import org.springframework.test.context.junit4.SpringRunner; import java.util.List; @RunWith(SpringRunner.class) @SpringBootTest public class LogicDeleteTest {@Autowiredprivate User2Mapper mapper;@Testpublic void testLogicDel() {int i = mapper.deleteById(6);System.out.println("rowAffected = " + i);} }

    結(jié)果:

    可以看到,發(fā)出的SQL不再是DELETE,而是UPDATE。

    若想要SELECT的列,不包括邏輯刪除的那一列,則可以在實(shí)體類中通過(guò)@TableField進(jìn)行配置

    @TableField(select = false) private Integer deleted;

    可以看到下圖的執(zhí)行結(jié)果中,SELECT中已經(jīng)不包含deleted這一列了

    前面在application.yml中做的配置,是全局的。通常來(lái)說(shuō),對(duì)于多個(gè)表,我們也會(huì)統(tǒng)一邏輯刪除字段的名稱,統(tǒng)一邏輯已刪除和未刪除的值,所以全局配置即可。當(dāng)然,若要對(duì)某些表進(jìn)行單獨(dú)配置,在實(shí)體類的對(duì)應(yīng)字段上使用@TableLogic即可

    @TableLogic(value = "0", delval = "1") private Integer deleted;

    小結(jié)
    開啟mp的邏輯刪除后,會(huì)對(duì)SQL產(chǎn)生如下的影響

    • INSERT語(yǔ)句:沒(méi)有影響
    • SELECT語(yǔ)句:追加WHERE條件,過(guò)濾掉已刪除的數(shù)據(jù)
    • UPDATE語(yǔ)句:追加WHERE條件,防止更新到已刪除的數(shù)據(jù)
    • DELETE語(yǔ)句:轉(zhuǎn)變?yōu)閁PDATE語(yǔ)句

    注意,上述的影響,只針對(duì)mp自動(dòng)注入的SQL生效,如果是自己手動(dòng)添加的自定義SQL,則不會(huì)生效。比如

    public interface User2Mapper extends BaseMapper<User2> {@Select("select * from user2")List<User2> selectRaw(); }

    調(diào)用這個(gè)selectRaw,則mp的邏輯刪除不會(huì)生效。

    另,邏輯刪除可在application.yml中進(jìn)行全局配置,也可在實(shí)體類中用@TableLogic進(jìn)行局部配置。

    自動(dòng)填充

    ????表中常常會(huì)有“新增時(shí)間”,“修改時(shí)間”,“操作人” 等字段。比較原始的方式,是每次插入或更新時(shí),手動(dòng)進(jìn)行設(shè)置。mp可以通過(guò)配置,對(duì)某些字段進(jìn)行自動(dòng)填充,示例如下

  • 在實(shí)體類中的某些字段上,通過(guò)@TableField設(shè)置自動(dòng)填充
  • public class User2 {private Long id;private String name;private Integer age;private String email;private Long managerId;@TableField(fill = FieldFill.INSERT) // 插入時(shí)自動(dòng)填充private LocalDateTime createTime;@TableField(fill = FieldFill.UPDATE) // 更新時(shí)自動(dòng)填充private LocalDateTime updateTime;private Integer version;private Integer deleted; }
  • 實(shí)現(xiàn)自動(dòng)填充處理器
  • package com.example.mp.component; import com.baomidou.mybatisplus.core.handlers.MetaObjectHandler; import org.apache.ibatis.reflection.MetaObject; import org.springframework.stereotype.Component; import java.time.LocalDateTime;@Component //需要注冊(cè)到Spring容器中 public class MyMetaObjectHandler implements MetaObjectHandler {@Overridepublic void insertFill(MetaObject metaObject) {// 插入時(shí)自動(dòng)填充// 注意第二個(gè)參數(shù)要填寫實(shí)體類中的字段名稱,而不是表的列名稱strictFillStrategy(metaObject, "createTime", LocalDateTime::now);}@Overridepublic void updateFill(MetaObject metaObject) {// 更新時(shí)自動(dòng)填充strictFillStrategy(metaObject, "updateTime", LocalDateTime::now);} }

    測(cè)試:

    @Test public void test() {User2 user = new User2();user.setId(8L);user.setName("王一蛋");user.setAge(29);user.setEmail("yd@baomidou.com");user.setManagerId(2L);mapper.insert(user); }

    根據(jù)下圖結(jié)果,可以看到對(duì)createTime進(jìn)行了自動(dòng)填充

    注意,自動(dòng)填充僅在該字段為空時(shí)會(huì)生效,若該字段不為空,則直接使用已有的值。如下

    @Test public void test() {User2 user = new User2();user.setId(8L);user.setName("王一蛋");user.setAge(29);user.setEmail("yd@baomidou.com");user.setManagerId(2L);user.setCreateTime(LocalDateTime.of(2000,1,1,8,0,0));mapper.insert(user); }


    更新時(shí)的自動(dòng)填充,測(cè)試如下:

    @Test public void test() {User2 user = new User2();user.setId(8L);user.setName("王一蛋");user.setAge(99);mapper.updateById(user); }

    樂(lè)觀鎖插件

    ????當(dāng)出現(xiàn)并發(fā)操作時(shí),需要確保各個(gè)用戶對(duì)數(shù)據(jù)的操作不產(chǎn)生沖突,此時(shí)需要一種并發(fā)控制手段。悲觀鎖的方法是,在對(duì)數(shù)據(jù)庫(kù)的一條記錄進(jìn)行修改時(shí),先直接加鎖(數(shù)據(jù)庫(kù)的鎖機(jī)制),鎖定這條數(shù)據(jù),然后再進(jìn)行操作;而樂(lè)觀鎖,正如其名,它先假設(shè)不存在沖突情況,而在實(shí)際進(jìn)行數(shù)據(jù)操作時(shí),再檢查是否沖突。樂(lè)觀鎖的一種通常實(shí)現(xiàn)是版本號(hào),在MySQL中也有名為MVCC的基于版本號(hào)的并發(fā)事務(wù)控制。
    ????在讀多寫少的場(chǎng)景下,樂(lè)觀鎖比較適用,能夠減少加鎖操作導(dǎo)致的性能開銷,提高系統(tǒng)吞吐量。
    ????在寫多讀少的場(chǎng)景下,悲觀鎖比較使用,否則會(huì)因?yàn)闃?lè)觀鎖不斷失敗重試,反而導(dǎo)致性能下降。

    樂(lè)觀鎖的實(shí)現(xiàn)如下:

  • 取出記錄時(shí),獲取當(dāng)前version
  • 更新時(shí),帶上這個(gè)version
  • 執(zhí)行更新時(shí), set version = newVersion where version = oldVersion
  • 如果oldVersion與數(shù)據(jù)庫(kù)中的version不一致,就更新失敗
  • 這種思想和CAS(Compare And Swap)非常相似。

    樂(lè)觀鎖的實(shí)現(xiàn)步驟如下:

  • 配置樂(lè)觀鎖插件
  • package com.example.mp.config;import com.baomidou.mybatisplus.extension.plugins.inner.OptimisticLockerInnerInterceptor; import org.springframework.context.annotation.Bean; import org.springframework.context.annotation.Configuration;@Configuration public class MybatisPlusConfig {/** 3.4.0以后的mp版本,推薦用如下的配置方式 **/@Beanpublic MybatisPlusInterceptor mybatisPlusInterceptor() {MybatisPlusInterceptor interceptor = new MybatisPlusInterceptor();interceptor.addInnerInterceptor(new OptimisticLockerInnerInterceptor());return interceptor;}/** 舊版mp可以采用如下方式。注意新舊版本中,新版的類,名稱帶有Inner, 舊版的不帶, 不要配錯(cuò)了 **//*@Beanpublic OptimisticLockerInterceptor opLocker() {return new OptimisticLockerInterceptor();}*/ }
  • 在實(shí)體類中表示版本的字段上添加注解@Version
  • @Data public class User2 {private Long id;private String name;private Integer age;private String email;private Long managerId;private LocalDateTime createTime;private LocalDateTime updateTime;@Versionprivate Integer version;private Integer deleted; }

    測(cè)試代碼

    @Test public void testOpLocker() {int version = 1; // 假設(shè)這個(gè)version是先前查詢時(shí)獲得的User2 user = new User2();user.setId(8L);user.setEmail("version@baomidou.com");user.setVersion(version);int i = mapper.updateById(user); }

    執(zhí)行之前先看一下數(shù)據(jù)庫(kù)的情況

    根據(jù)下圖執(zhí)行結(jié)果,可以看到SQL語(yǔ)句中添加了version相關(guān)的操作

    當(dāng)UPDATE返回了1,表示影響行數(shù)為1,則更新成功。反之,由于WHERE后面的version與數(shù)據(jù)庫(kù)中的不一致,匹配不到任何記錄,則影響行數(shù)為0,表示更新失敗。更新成功后,新的version會(huì)被封裝回實(shí)體對(duì)象中。

    實(shí)體類中version字段,類型只支持int,long,Date,Timestamp,LocalDateTime

    注意,樂(lè)觀鎖插件僅支持updateById(id)與update(entity, wrapper)方法

    注意:如果使用wrapper,則wrapper不能復(fù)用!

    錯(cuò)誤示例

    @Test public void testOpLocker() {User2 user = new User2();user.setId(8L);user.setVersion(1);user.setAge(2);// 第一次使用LambdaQueryWrapper<User2> wrapper = new LambdaQueryWrapper<>();wrapper.eq(User2::getName, "王一蛋");mapper.update(user, wrapper);// 第二次復(fù)用user.setAge(3);mapper.update(user, wrapper); }


    可以看到在第二次復(fù)用wrapper時(shí),拼接出的SQL中,后面WHERE語(yǔ)句中出現(xiàn)了2次version,是有問(wèn)題的。

    性能分析插件

    該插件會(huì)輸出SQL語(yǔ)句的執(zhí)行時(shí)間,以便做SQL語(yǔ)句的性能分析和調(diào)優(yōu)。
    使用步驟:

  • 引入maven依賴
  • <dependency><groupId>p6spy</groupId><artifactId>p6spy</artifactId><version>3.9.1</version> </dependency>
  • 修改application.yml
  • spring:datasource:driver-class-name: com.p6spy.engine.spy.P6SpyDriver #換成p6spy的驅(qū)動(dòng)url: jdbc:p6spy:mysql://localhost:3306/yogurt?serverTimezone=Asia/Shanghai #url修改username: rootpassword: root
  • 在src/main/resources資源目錄下添加spy.properties
  • #spy.properties #3.2.1以上使用 modulelist=com.baomidou.mybatisplus.extension.p6spy.MybatisPlusLogFactory,com.p6spy.engine.outage.P6OutageFactory # 真實(shí)JDBC driver , 多個(gè)以逗號(hào)分割,默認(rèn)為空。由于上面設(shè)置了modulelist, 這里可以不用設(shè)置driverlist #driverlist=com.mysql.cj.jdbc.Driver # 自定義日志打印 logMessageFormat=com.baomidou.mybatisplus.extension.p6spy.P6SpyLogger #日志輸出到控制臺(tái) appender=com.baomidou.mybatisplus.extension.p6spy.StdoutLogger #若要日志輸出到文件, 把上面的appnder注釋掉, 或者采用下面的appender, 再添加logfile配置 #不配置appender時(shí), 默認(rèn)是往文件進(jìn)行輸出的 #appender=com.p6spy.engine.spy.appender.FileLogger #logfile=log.log # 設(shè)置 p6spy driver 代理 deregisterdrivers=true # 取消JDBC URL前綴 useprefix=true # 配置記錄 Log 例外,可去掉的結(jié)果集有error,info,batch,debug,statement,commit,rollback,result,resultset. excludecategories=info,debug,result,commit,resultset # 日期格式 dateformat=yyyy-MM-dd HH:mm:ss # 是否開啟慢SQL記錄 outagedetection=true # 慢SQL記錄標(biāo)準(zhǔn) 2 秒 outagedetectioninterval=2 # 執(zhí)行時(shí)間設(shè)置, 只有超過(guò)這個(gè)執(zhí)行時(shí)間的才進(jìn)行記錄, 默認(rèn)值0, 單位毫秒 executionThreshold=10

    隨便運(yùn)行一個(gè)測(cè)試用例,可以看到該SQL的執(zhí)行時(shí)長(zhǎng)被記錄了下來(lái)

    多租戶SQL解析器

    多租戶的概念:多個(gè)用戶共用一套系統(tǒng),但他們的數(shù)據(jù)有需要相對(duì)的獨(dú)立,保持一定的隔離性。
    多租戶的數(shù)據(jù)隔離一般有如下的方式:

    • 不同租戶使用不同的數(shù)據(jù)庫(kù)服務(wù)器
      優(yōu)點(diǎn):不同租戶有不同的獨(dú)立數(shù)據(jù)庫(kù),有助于擴(kuò)展,以及對(duì)不同租戶提供更好的個(gè)性化,出現(xiàn)故障時(shí)恢復(fù)數(shù)據(jù)較為簡(jiǎn)單。
      缺點(diǎn):增加了數(shù)據(jù)庫(kù)數(shù)量,購(gòu)置成本,維護(hù)成本更高。
    • 不同租戶使用相同的數(shù)據(jù)庫(kù)服務(wù)器,但使用不同的數(shù)據(jù)庫(kù)(不同的schema)
      優(yōu)點(diǎn):購(gòu)置和維護(hù)成本低了一些,缺點(diǎn)是數(shù)據(jù)恢復(fù)較為困難,因?yàn)椴煌鈶舻臄?shù)據(jù)都放在了一起。
    • 不同租戶使用相同的數(shù)據(jù)庫(kù)服務(wù)器,使用相同的數(shù)據(jù)庫(kù),共享數(shù)據(jù)表,在表中增加租戶id來(lái)做區(qū)分
      優(yōu)點(diǎn):購(gòu)置和維護(hù)成本最低,支持用戶最多,缺點(diǎn)是隔離性最低,安全性最低。

    示例如下:
    添加多租戶攔截器配置。添加配置后,在執(zhí)行CRUD的時(shí)候,會(huì)自動(dòng)在SQL語(yǔ)句最后拼接租戶id的條件。

    package com.example.mp.config;import com.baomidou.mybatisplus.extension.plugins.MybatisPlusInterceptor; import com.baomidou.mybatisplus.extension.plugins.handler.TenantLineHandler; import com.baomidou.mybatisplus.extension.plugins.inner.TenantLineInnerInterceptor; import net.sf.jsqlparser.expression.Expression; import net.sf.jsqlparser.expression.LongValue; import org.springframework.context.annotation.Bean; import org.springframework.context.annotation.Configuration;@Configuration public class MybatisPlusConfig {@Beanpublic MybatisPlusInterceptor mybatisPlusInterceptor() {MybatisPlusInterceptor interceptor = new MybatisPlusInterceptor();interceptor.addInnerInterceptor(new TenantLineInnerInterceptor(new TenantLineHandler() {@Overridepublic Expression getTenantId() {// 返回租戶id的值, 這里固定寫死為1// 一般是從當(dāng)前上下文中取出一個(gè) 租戶idreturn new LongValue(1);}/**** 通常會(huì)將表示租戶id的列名,需要排除租戶id的表等信息,封裝到一個(gè)配置類中(如TenantConfig)**/@Overridepublic String getTenantIdColumn() {// 返回表中的表示租戶id的列名return "manager_id";}@Overridepublic boolean ignoreTable(String tableName) {// 表名不為 user2 的表, 不拼接多租戶條件return !"user2".equals(tableName);}}));// 如果用了分頁(yè)插件注意先 add TenantLineInnerInterceptor 再 add PaginationInnerInterceptor// 用了分頁(yè)插件必須設(shè)置 MybatisConfiguration#useDeprecatedExecutor = falsereturn interceptor;}}

    測(cè)試

    @Test public void testTenant() {LambdaQueryWrapper<User2> wrapper = new LambdaQueryWrapper<>();wrapper.likeRight(User2::getName, "王").select(User2::getName, User2::getAge, User2::getEmail, User2::getManagerId);user2Mapper.selectList(wrapper); }

    動(dòng)態(tài)表名SQL解析器

    ????當(dāng)數(shù)據(jù)量特別大的時(shí)候,我們通常會(huì)采用分庫(kù)分表。這時(shí),可能就會(huì)有多張表,其表結(jié)構(gòu)相同,但表名不同。例如order_1,order_2,order_3,查詢時(shí),我們可能需要?jiǎng)討B(tài)設(shè)置要查的表名。mp提供了動(dòng)態(tài)表名SQL解析器,示例如下:

    配置動(dòng)態(tài)表名攔截器

    package com.example.mp.config;import com.baomidou.mybatisplus.extension.plugins.MybatisPlusInterceptor; import com.baomidou.mybatisplus.extension.plugins.handler.TableNameHandler; import com.baomidou.mybatisplus.extension.plugins.inner.DynamicTableNameInnerInterceptor; import org.springframework.context.annotation.Bean; import org.springframework.context.annotation.Configuration; import java.util.HashMap; import java.util.Random;@Configuration public class MybatisPlusConfig {@Beanpublic MybatisPlusInterceptor mybatisPlusInterceptor() {MybatisPlusInterceptor interceptor = new MybatisPlusInterceptor();DynamicTableNameInnerInterceptor dynamicTableNameInnerInterceptor = new DynamicTableNameInnerInterceptor();HashMap<String, TableNameHandler> map = new HashMap<>();// 對(duì)于user2表,進(jìn)行動(dòng)態(tài)表名設(shè)置map.put("user2", (sql, tableName) -> {String _ = "_";int random = new Random().nextInt(2) + 1;return tableName + _ + random; // 若返回null, 則不會(huì)進(jìn)行動(dòng)態(tài)表名替換, 還是會(huì)使用user2});dynamicTableNameInnerInterceptor.setTableNameHandlerMap(map);interceptor.addInnerInterceptor(dynamicTableNameInnerInterceptor);return interceptor;}}

    測(cè)試

    @Test public void testDynamicTable() {user2Mapper.selectList(null); }

    結(jié)果

    四、總結(jié)

    • 條件構(gòu)造器AbstractWrapper中提供了多個(gè)方法用于構(gòu)造SQL語(yǔ)句中的WHERE條件,而其子類QueryWrapper額外提供了select方法,可以只選取特定的列,子類UpdateWrapper額外提供了set方法,用于設(shè)置SQL中的SET語(yǔ)句。除了普通的Wrapper,還有基于lambda表達(dá)式的Wrapper,如LambdaQueryWrapperLambdaUpdateWrapper,它們?cè)跇?gòu)造WHERE條件時(shí),直接以方法引用來(lái)指定WHERE條件中的列,比普通Wrapper通過(guò)字符串來(lái)指定要更加優(yōu)雅。另,還有鏈?zhǔn)絎rapper,如LambdaQueryChainWrapper,它封裝了BaseMapper,可以更方便地獲取結(jié)果。
    • 條件構(gòu)造器采用鏈?zhǔn)秸{(diào)用來(lái)拼接多個(gè)條件,條件之間默認(rèn)以AND連接。
    • 當(dāng)ANDOR后面的條件需要被括號(hào)包裹時(shí),將括號(hào)中的條件以lambda表達(dá)式形式,作為參數(shù)傳入and()或or()
      特別的,當(dāng)()需要放在WHERE語(yǔ)句的最開頭時(shí),可以使用**nested()**方法。
    • 條件表達(dá)式時(shí)當(dāng)需要傳入自定義的SQL語(yǔ)句,或者需要調(diào)用數(shù)據(jù)庫(kù)函數(shù)時(shí),可用apply()方法進(jìn)行SQL拼接。
    • 條件構(gòu)造器中的各個(gè)方法可以通過(guò)一個(gè)boolean類型的變量condition,來(lái)根據(jù)需要靈活拼接WHERE條件(僅當(dāng)condition為true時(shí)會(huì)拼接SQL語(yǔ)句)。
    • 使用lambda條件構(gòu)造器,可以通過(guò)lambda表達(dá)式,直接使用實(shí)體類中的屬性進(jìn)行條件構(gòu)造,比普通的條件構(gòu)造器更加優(yōu)雅。
    • 若mp提供的方法不夠用,可以通過(guò)自定義SQL(原生mybatis)的形式進(jìn)行擴(kuò)展開發(fā)。
    • 使用mp進(jìn)行分頁(yè)查詢時(shí),需要?jiǎng)?chuàng)建一個(gè)分頁(yè)攔截器(Interceptor),注冊(cè)到Spring容器中,隨后查詢時(shí),通過(guò)傳入一個(gè)分頁(yè)對(duì)象(Page對(duì)象)進(jìn)行查詢即可。單表查詢時(shí),可以使用BaseMapper提供的selectPageselectMapsPage方法。復(fù)雜場(chǎng)景下(如多表聯(lián)查),使用自定義SQL。
    • AR模式可以直接通過(guò)操作實(shí)體類來(lái)操作數(shù)據(jù)庫(kù)。讓實(shí)體類繼承自Model即可。

    總結(jié)

    以上是生活随笔為你收集整理的mybatis plus 使用技巧的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。

    如果覺得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。

    99久久精品无码一区二区毛片 | 女人和拘做爰正片视频 | 青青青爽视频在线观看 | 久久精品国产大片免费观看 | 九九久久精品国产免费看小说 | 搡女人真爽免费视频大全 | √天堂资源地址中文在线 | 国产一区二区三区精品视频 | 亚洲成av人在线观看网址 | 久久综合久久自在自线精品自 | 亚洲熟妇色xxxxx欧美老妇 | 亚洲成av人片在线观看无码不卡 | 日日天日日夜日日摸 | 四虎4hu永久免费 | 大乳丰满人妻中文字幕日本 | 成人片黄网站色大片免费观看 | 久久97精品久久久久久久不卡 | 国产偷国产偷精品高清尤物 | 偷窥日本少妇撒尿chinese | 亚洲区小说区激情区图片区 | 精品欧美一区二区三区久久久 | 天天做天天爱天天爽综合网 | 午夜福利电影 | 无码乱肉视频免费大全合集 | 国产午夜精品一区二区三区嫩草 | aa片在线观看视频在线播放 | av无码电影一区二区三区 | 中文字幕色婷婷在线视频 | 日韩av无码一区二区三区不卡 | 国产成人久久精品流白浆 | 熟妇人妻中文av无码 | 国内揄拍国内精品少妇国语 | 伊人久久大香线蕉亚洲 | 欧洲极品少妇 | 任你躁在线精品免费 | aⅴ在线视频男人的天堂 | 无码福利日韩神码福利片 | 色一情一乱一伦一视频免费看 | 亚洲精品成人av在线 | 日韩欧美成人免费观看 | 国产极品美女高潮无套在线观看 | 日本高清一区免费中文视频 | 国产网红无码精品视频 | 99er热精品视频 | 久久精品人人做人人综合试看 | 在教室伦流澡到高潮hnp视频 | 三上悠亚人妻中文字幕在线 | 天海翼激烈高潮到腰振不止 | 一个人看的www免费视频在线观看 | 综合激情五月综合激情五月激情1 | 国产成人精品视频ⅴa片软件竹菊 | 青青草原综合久久大伊人精品 | 国产va免费精品观看 | 成人精品视频一区二区三区尤物 | 亚洲啪av永久无码精品放毛片 | 久久综合网欧美色妞网 | 三上悠亚人妻中文字幕在线 | 中文字幕 亚洲精品 第1页 | 老子影院午夜伦不卡 | 亚洲中文无码av永久不收费 | 色综合久久久无码网中文 | 国产在线一区二区三区四区五区 | √8天堂资源地址中文在线 | 亚洲精品午夜国产va久久成人 | 亚洲小说图区综合在线 | 亚洲国产精品久久久久久 | 国产午夜亚洲精品不卡 | 国产成人精品视频ⅴa片软件竹菊 | 亚洲码国产精品高潮在线 | 综合网日日天干夜夜久久 | 国产成人综合美国十次 | 国产在线无码精品电影网 | 高潮毛片无遮挡高清免费 | 亚洲乱码日产精品bd | 99国产精品白浆在线观看免费 | 亚洲の无码国产の无码影院 | 无码乱肉视频免费大全合集 | 中文字幕无码人妻少妇免费 | 日韩少妇白浆无码系列 | 久久久精品456亚洲影院 | 亚洲乱码中文字幕在线 | 美女黄网站人色视频免费国产 | 成人亚洲精品久久久久 | 亚洲自偷自偷在线制服 | 成人欧美一区二区三区黑人免费 | 色诱久久久久综合网ywww | 大地资源网第二页免费观看 | 欧美性生交xxxxx久久久 | 久久久精品国产sm最大网站 | 久久久av男人的天堂 | 国产亚洲精品久久久久久久久动漫 | 大地资源网第二页免费观看 | 日日躁夜夜躁狠狠躁 | 天天摸天天透天天添 | 国产农村乱对白刺激视频 | 欧美午夜特黄aaaaaa片 | 狠狠躁日日躁夜夜躁2020 | 爽爽影院免费观看 | 国产特级毛片aaaaaa高潮流水 | 成人无码影片精品久久久 | 日韩av激情在线观看 | 国产精品亚洲一区二区三区喷水 | 无码国产乱人伦偷精品视频 | 18无码粉嫩小泬无套在线观看 | 欧洲欧美人成视频在线 | 黑人玩弄人妻中文在线 | 一本无码人妻在中文字幕免费 | 99久久精品国产一区二区蜜芽 | 亚洲综合伊人久久大杳蕉 | 亚洲精品一区三区三区在线观看 | 人妻夜夜爽天天爽三区 | 人人妻在人人 | 亚洲精品鲁一鲁一区二区三区 | 国产精品无码永久免费888 | 精品无码一区二区三区爱欲 | 日本精品高清一区二区 | 一个人看的www免费视频在线观看 | 思思久久99热只有频精品66 | 丰满人妻一区二区三区免费视频 | 熟女俱乐部五十路六十路av | 荫蒂被男人添的好舒服爽免费视频 | 丰满人妻一区二区三区免费视频 | 又湿又紧又大又爽a视频国产 | 天天摸天天透天天添 | 性色欲网站人妻丰满中文久久不卡 | 国产精品自产拍在线观看 | 国产精品久久久一区二区三区 | 色偷偷人人澡人人爽人人模 | 未满小14洗澡无码视频网站 | 亚洲 另类 在线 欧美 制服 | 免费乱码人妻系列无码专区 | 日韩精品无码一本二本三本色 | 人人妻人人澡人人爽人人精品 | 国产亚洲欧美在线专区 | 久久久www成人免费毛片 | 大肉大捧一进一出好爽视频 | 国产午夜亚洲精品不卡 | 大地资源网第二页免费观看 | 图片区 小说区 区 亚洲五月 | 免费无码av一区二区 | 免费男性肉肉影院 | 亚洲成在人网站无码天堂 | 日韩精品成人一区二区三区 | 中文字幕无码免费久久9一区9 | 亚洲gv猛男gv无码男同 | 精品国产国产综合精品 | 色婷婷av一区二区三区之红樱桃 | 亚洲精品午夜国产va久久成人 | 永久黄网站色视频免费直播 | 色综合久久中文娱乐网 | 日产精品高潮呻吟av久久 | 国产在线精品一区二区高清不卡 | 欧美国产亚洲日韩在线二区 | 55夜色66夜色国产精品视频 | 欧美一区二区三区 | 中文无码精品a∨在线观看不卡 | 久久视频在线观看精品 | 我要看www免费看插插视频 | 激情人妻另类人妻伦 | 蜜桃视频插满18在线观看 | 中文字幕无码日韩欧毛 | 日本一区二区三区免费播放 | 久久综合九色综合97网 | 成人精品天堂一区二区三区 | 女人高潮内射99精品 | 青青青爽视频在线观看 | 天天拍夜夜添久久精品大 | 欧美日韩综合一区二区三区 | 中文精品无码中文字幕无码专区 | 99久久精品午夜一区二区 | 人人妻人人澡人人爽欧美一区九九 | 亚洲国产av美女网站 | 内射巨臀欧美在线视频 | 草草网站影院白丝内射 | 免费看男女做好爽好硬视频 | 中文字幕日韩精品一区二区三区 | 无码av岛国片在线播放 | 中文字幕乱妇无码av在线 | 成人女人看片免费视频放人 | 好爽又高潮了毛片免费下载 | 免费人成网站视频在线观看 | 国语自产偷拍精品视频偷 | 少妇性荡欲午夜性开放视频剧场 | 色综合视频一区二区三区 | 欧美精品在线观看 | 日本护士毛茸茸高潮 | 国产乱人伦app精品久久 国产在线无码精品电影网 国产国产精品人在线视 | 亚洲国产欧美国产综合一区 | 国产av人人夜夜澡人人爽麻豆 | 中文字幕乱码亚洲无线三区 | 久久久精品人妻久久影视 | 无码乱肉视频免费大全合集 | 欧美野外疯狂做受xxxx高潮 | 天天拍夜夜添久久精品 | 国内精品久久毛片一区二区 | 国产人妻精品午夜福利免费 | 无码人妻精品一区二区三区下载 | 大乳丰满人妻中文字幕日本 | 无码人妻久久一区二区三区不卡 | 纯爱无遮挡h肉动漫在线播放 | 亚洲理论电影在线观看 | 亚洲中文字幕无码一久久区 | 国产亚洲人成在线播放 | 无码乱肉视频免费大全合集 | 欧美日本精品一区二区三区 | 亚洲中文字幕在线无码一区二区 | 美女扒开屁股让男人桶 | 欧美freesex黑人又粗又大 | 久久精品国产日本波多野结衣 | 欧美日本免费一区二区三区 | 无码精品人妻一区二区三区av | 久久这里只有精品视频9 | 国产美女精品一区二区三区 | 日本高清一区免费中文视频 | 日韩 欧美 动漫 国产 制服 | 5858s亚洲色大成网站www | 小泽玛莉亚一区二区视频在线 | 无码av最新清无码专区吞精 | 亚洲熟妇色xxxxx欧美老妇y | 亚洲日韩av片在线观看 | 福利一区二区三区视频在线观看 | 亚洲国产欧美日韩精品一区二区三区 | 国产女主播喷水视频在线观看 | 国内精品人妻无码久久久影院 | 欧美 亚洲 国产 另类 | 亚洲日韩av一区二区三区四区 | 国产电影无码午夜在线播放 | √8天堂资源地址中文在线 | 日日摸天天摸爽爽狠狠97 | 一区二区三区高清视频一 | 欧美大屁股xxxxhd黑色 | 少妇邻居内射在线 | 高潮毛片无遮挡高清免费视频 | 女人被男人躁得好爽免费视频 | 国产精品无码一区二区桃花视频 | 大胆欧美熟妇xx | 又大又紧又粉嫩18p少妇 | 狂野欧美性猛xxxx乱大交 | 无码国产色欲xxxxx视频 | 国产精品久久久久久无码 | 成人亚洲精品久久久久 | 国产色xx群视频射精 | 欧美熟妇另类久久久久久不卡 | 动漫av网站免费观看 | 精品国产乱码久久久久乱码 | 国产精品免费大片 | 日韩精品成人一区二区三区 | 丰腴饱满的极品熟妇 | 5858s亚洲色大成网站www | 成人一区二区免费视频 | 成熟妇人a片免费看网站 | 无遮无挡爽爽免费视频 | 动漫av网站免费观看 | 亚洲中文字幕无码中字 | 欧美日本免费一区二区三区 | 亚洲精品久久久久久一区二区 | 老熟女重囗味hdxx69 | 国产亚洲精品久久久久久 | 超碰97人人做人人爱少妇 | 欧美 日韩 亚洲 在线 | 97色伦图片97综合影院 | 荫蒂添的好舒服视频囗交 | 一区二区三区高清视频一 | 无码国产色欲xxxxx视频 | 无码福利日韩神码福利片 | 成人免费视频在线观看 | 亚洲日韩av片在线观看 | 欧美日韩一区二区综合 | 亚洲国产欧美日韩精品一区二区三区 | 成人欧美一区二区三区黑人免费 | 一个人看的视频www在线 | 亚洲成a人片在线观看无码3d | 亚洲人亚洲人成电影网站色 | 亚洲毛片av日韩av无码 | 国精产品一品二品国精品69xx | 国产精品久久久久影院嫩草 | 精品一区二区三区波多野结衣 | 男人和女人高潮免费网站 | 久久精品无码一区二区三区 | 亚洲中文字幕av在天堂 | 亚洲精品久久久久久一区二区 | 成人试看120秒体验区 | 国产午夜亚洲精品不卡下载 | 国产尤物精品视频 | 久久综合给合久久狠狠狠97色 | 狠狠色欧美亚洲狠狠色www | 大肉大捧一进一出视频出来呀 | 久久精品国产一区二区三区 | 国产亚洲精品久久久久久久久动漫 | 一本无码人妻在中文字幕免费 | 亚洲阿v天堂在线 | 国产精品高潮呻吟av久久4虎 | 成人动漫在线观看 | 成人欧美一区二区三区黑人 | 亚洲 激情 小说 另类 欧美 | 精品久久久久香蕉网 | 国产成人精品久久亚洲高清不卡 | 成人精品视频一区二区三区尤物 | 无码午夜成人1000部免费视频 | 国产精品亚洲lv粉色 | 久激情内射婷内射蜜桃人妖 | 国产亚av手机在线观看 | 国内少妇偷人精品视频 | 久久久无码中文字幕久... | 国产精品无码成人午夜电影 | 国产精品久久久久久久影院 | 亚洲狠狠色丁香婷婷综合 | 欧美日韩视频无码一区二区三 | 中文字幕人成乱码熟女app | 国产精品无套呻吟在线 | 人人澡人摸人人添 | 亚洲欧洲日本无在线码 | 黑人巨大精品欧美黑寡妇 | 亚洲精品久久久久avwww潮水 | 国产高清不卡无码视频 | 国产后入清纯学生妹 | 久在线观看福利视频 | 久久久久成人精品免费播放动漫 | 丝袜足控一区二区三区 | 四虎国产精品免费久久 | 久久亚洲日韩精品一区二区三区 | 久久精品99久久香蕉国产色戒 | 内射爽无广熟女亚洲 | 亚洲综合伊人久久大杳蕉 | 亚洲中文字幕在线观看 | 久久99精品久久久久久 | 撕开奶罩揉吮奶头视频 | 无码人妻少妇伦在线电影 | 欧美乱妇无乱码大黄a片 | 亚洲中文字幕无码中字 | 国产亚洲日韩欧美另类第八页 | 日本爽爽爽爽爽爽在线观看免 | 奇米综合四色77777久久 东京无码熟妇人妻av在线网址 | 亚洲国产成人a精品不卡在线 | 国产精品亚洲а∨无码播放麻豆 | 中文字幕无码人妻少妇免费 | 亚洲精品久久久久久久久久久 | 日韩av无码中文无码电影 | 无码成人精品区在线观看 | 呦交小u女精品视频 | 国产亚洲欧美在线专区 | 成在人线av无码免费 | 狠狠cao日日穞夜夜穞av | 久久久久久久女国产乱让韩 | 国产真人无遮挡作爱免费视频 | 亚洲日本一区二区三区在线 | 国产人妻精品一区二区三区 | 东京无码熟妇人妻av在线网址 | 久久久久久久久蜜桃 | 啦啦啦www在线观看免费视频 | 日本大香伊一区二区三区 | 精品无码av一区二区三区 | 亚洲日本va中文字幕 | 蜜桃臀无码内射一区二区三区 | 婷婷丁香六月激情综合啪 | 国产一区二区三区日韩精品 | 伊人久久大香线焦av综合影院 | 国产精品二区一区二区aⅴ污介绍 | 日韩成人一区二区三区在线观看 | 国产口爆吞精在线视频 | 亚洲精品鲁一鲁一区二区三区 | 97色伦图片97综合影院 | 狠狠色丁香久久婷婷综合五月 | 亚洲中文字幕va福利 | 久热国产vs视频在线观看 | 亚洲娇小与黑人巨大交 | 国产乱码精品一品二品 | 国产精品理论片在线观看 | 日本爽爽爽爽爽爽在线观看免 | 中文字幕久久久久人妻 | 精品国产一区二区三区四区在线看 | 在线观看免费人成视频 | 丁香啪啪综合成人亚洲 | 久久综合狠狠综合久久综合88 | 久久亚洲a片com人成 | 伊在人天堂亚洲香蕉精品区 | 宝宝好涨水快流出来免费视频 | 熟妇激情内射com | 正在播放东北夫妻内射 | 亚洲aⅴ无码成人网站国产app | 亚洲精品无码人妻无码 | 俺去俺来也www色官网 | 欧美人与善在线com | 最近免费中文字幕中文高清百度 | 99久久无码一区人妻 | 又紧又大又爽精品一区二区 | 亚洲精品成人av在线 | 日本精品高清一区二区 | 永久免费精品精品永久-夜色 | 亚洲男人av天堂午夜在 | 人妻少妇精品无码专区动漫 | 精品无码成人片一区二区98 | 国产明星裸体无码xxxx视频 | 一本加勒比波多野结衣 | 亚洲国产精品久久人人爱 | 在线а√天堂中文官网 | 国产无套粉嫩白浆在线 | 极品尤物被啪到呻吟喷水 | 欧美成人午夜精品久久久 | 日韩精品一区二区av在线 | 日本成熟视频免费视频 | 99国产精品白浆在线观看免费 | 精品人妻人人做人人爽 | 国产明星裸体无码xxxx视频 | 精品人妻中文字幕有码在线 | 亚洲国产午夜精品理论片 | 又黄又爽又色的视频 | 精品一区二区三区无码免费视频 | 亚洲一区av无码专区在线观看 | 亚洲成av人综合在线观看 | 国产成人精品久久亚洲高清不卡 | 国产精品久久久久久久9999 | 日韩少妇内射免费播放 | 无码国产激情在线观看 | 国产免费久久久久久无码 | 国产又爽又猛又粗的视频a片 | 国产偷自视频区视频 | 成人无码视频在线观看网站 | 性欧美熟妇videofreesex | 人人妻人人澡人人爽欧美一区 | 亚洲精品一区二区三区在线 | 婷婷六月久久综合丁香 | 亚洲一区二区三区 | 极品嫩模高潮叫床 | 东京热男人av天堂 | 国产成人一区二区三区在线观看 | 欧美freesex黑人又粗又大 | 久久久久久国产精品无码下载 | 久久久av男人的天堂 | 麻豆md0077饥渴少妇 | 婷婷综合久久中文字幕蜜桃三电影 | 人人妻人人澡人人爽人人精品浪潮 | 久久熟妇人妻午夜寂寞影院 | 久久精品女人的天堂av | 波多野结衣高清一区二区三区 | 给我免费的视频在线观看 | 国产精品无码一区二区三区不卡 | 中文亚洲成a人片在线观看 | 日韩无套无码精品 | 国产精品久久久久久亚洲影视内衣 | 强开小婷嫩苞又嫩又紧视频 | 在线观看免费人成视频 | 女人被爽到呻吟gif动态图视看 | 欧美放荡的少妇 | 亚洲日韩av一区二区三区中文 | 久久午夜无码鲁丝片午夜精品 | 99精品国产综合久久久久五月天 | 国产成人精品视频ⅴa片软件竹菊 | 国产特级毛片aaaaaa高潮流水 | 老司机亚洲精品影院无码 | 欧洲欧美人成视频在线 | 国产疯狂伦交大片 | 高清国产亚洲精品自在久久 | 中文字幕av日韩精品一区二区 | 日韩欧美群交p片內射中文 | 97精品人妻一区二区三区香蕉 | 成人综合网亚洲伊人 | 天天躁夜夜躁狠狠是什么心态 | 狠狠综合久久久久综合网 | 一二三四在线观看免费视频 | 国精产品一区二区三区 | 丁香花在线影院观看在线播放 | 小sao货水好多真紧h无码视频 | 我要看www免费看插插视频 | 大地资源网第二页免费观看 | 性生交片免费无码看人 | 国内精品九九久久久精品 | 亚洲の无码国产の无码影院 | 精品国偷自产在线 | 亚洲日本va午夜在线电影 | 色综合久久中文娱乐网 | 成在人线av无码免观看麻豆 | 精品久久久久久亚洲精品 | 精品夜夜澡人妻无码av蜜桃 | 四虎永久在线精品免费网址 | 亚洲综合无码一区二区三区 | 99久久无码一区人妻 | 成人欧美一区二区三区 | 欧美人与善在线com | 精品久久综合1区2区3区激情 | 精品夜夜澡人妻无码av蜜桃 | 国内精品人妻无码久久久影院 | 成年美女黄网站色大免费视频 | 国产无套粉嫩白浆在线 | 亚洲最大成人网站 | 国产成人无码区免费内射一片色欲 | 三上悠亚人妻中文字幕在线 | 亚洲欧洲中文日韩av乱码 | 精品国产一区二区三区四区 | 久久亚洲精品中文字幕无男同 | 久久久久99精品成人片 | 色婷婷综合激情综在线播放 | a国产一区二区免费入口 | 内射老妇bbwx0c0ck | 丰满人妻一区二区三区免费视频 | 麻豆人妻少妇精品无码专区 | 亚洲色大成网站www国产 | 动漫av网站免费观看 | 国产成人精品一区二区在线小狼 | 午夜精品久久久内射近拍高清 | 丰满少妇高潮惨叫视频 | 亚洲精品成人福利网站 | 无码人中文字幕 | 久久精品无码一区二区三区 | 99国产精品白浆在线观看免费 | 色一情一乱一伦一区二区三欧美 | 精品国产一区二区三区四区在线看 | 国产情侣作爱视频免费观看 | 啦啦啦www在线观看免费视频 | 中文字幕 人妻熟女 | 国产激情艳情在线看视频 | 久久国产自偷自偷免费一区调 | 无码人妻精品一区二区三区不卡 | 中文字幕av日韩精品一区二区 | 日本免费一区二区三区最新 | 色综合久久久久综合一本到桃花网 | 亚洲国产成人av在线观看 | 久久精品成人欧美大片 | 精品欧美一区二区三区久久久 | 少妇被粗大的猛进出69影院 | 亚洲精品国产a久久久久久 | 日韩人妻系列无码专区 | 国产手机在线αⅴ片无码观看 | 日本丰满熟妇videos | 中文字幕人妻无码一夲道 | 色五月丁香五月综合五月 | 国产欧美精品一区二区三区 | 天天躁日日躁狠狠躁免费麻豆 | 99久久人妻精品免费一区 | 日本熟妇大屁股人妻 | 精品午夜福利在线观看 | 在线观看国产午夜福利片 | 97人妻精品一区二区三区 | 中文字幕无码日韩欧毛 | 夜先锋av资源网站 | 无码成人精品区在线观看 | 欧美黑人巨大xxxxx | 一本色道久久综合亚洲精品不卡 | 成人一在线视频日韩国产 | 国产97在线 | 亚洲 | 精品无人区无码乱码毛片国产 | 欧美激情一区二区三区成人 | 日本一区二区三区免费高清 | 国产人妻精品午夜福利免费 | 久久精品人妻少妇一区二区三区 | 在线精品亚洲一区二区 | 久久亚洲中文字幕精品一区 | 亚洲aⅴ无码成人网站国产app | 在线成人www免费观看视频 | 牲欲强的熟妇农村老妇女视频 | 在线播放免费人成毛片乱码 | 国内少妇偷人精品视频 | 蜜臀av在线播放 久久综合激激的五月天 | 久久久久人妻一区精品色欧美 | 久久精品国产99久久6动漫 | 99久久久无码国产aaa精品 | 国产情侣作爱视频免费观看 | 少妇性荡欲午夜性开放视频剧场 | 色噜噜亚洲男人的天堂 | 在线а√天堂中文官网 | 日产精品99久久久久久 | 亚洲熟妇色xxxxx欧美老妇 | 亚洲区欧美区综合区自拍区 | 成年美女黄网站色大免费视频 | 成人无码视频在线观看网站 | 亚洲综合另类小说色区 | 亚洲精品中文字幕久久久久 | 中文字幕 人妻熟女 | 狂野欧美激情性xxxx | 中文无码伦av中文字幕 | 亚洲人成网站色7799 | 丝袜足控一区二区三区 | 久久99久久99精品中文字幕 | 国产精品亚洲а∨无码播放麻豆 | 精品无码成人片一区二区98 | aⅴ亚洲 日韩 色 图网站 播放 | 久久人人爽人人爽人人片av高清 | 特大黑人娇小亚洲女 | 女人和拘做爰正片视频 | 精品国产国产综合精品 | 久久综合色之久久综合 | 日本一卡二卡不卡视频查询 | 国产无av码在线观看 | 性色av无码免费一区二区三区 | 久久国产精品精品国产色婷婷 | 精品国产一区二区三区四区在线看 | 狠狠躁日日躁夜夜躁2020 | 激情综合激情五月俺也去 | 性欧美大战久久久久久久 | 国产性猛交╳xxx乱大交 国产精品久久久久久无码 欧洲欧美人成视频在线 | 人妻aⅴ无码一区二区三区 | 久久97精品久久久久久久不卡 | 亚洲综合色区中文字幕 | 久久综合给久久狠狠97色 | 又色又爽又黄的美女裸体网站 | 99麻豆久久久国产精品免费 | 一本色道久久综合狠狠躁 | 精品久久久无码人妻字幂 | 娇妻被黑人粗大高潮白浆 | 天天躁夜夜躁狠狠是什么心态 | 性开放的女人aaa片 | 天堂а√在线地址中文在线 | a在线亚洲男人的天堂 | 亚洲日本va中文字幕 | 中文精品久久久久人妻不卡 | 国产人成高清在线视频99最全资源 | 99re在线播放 | 午夜嘿嘿嘿影院 | 亚洲欧美日韩成人高清在线一区 | 性欧美大战久久久久久久 | 国语精品一区二区三区 | 狂野欧美性猛xxxx乱大交 | 日日橹狠狠爱欧美视频 | 免费乱码人妻系列无码专区 | 久久精品无码一区二区三区 | 无码一区二区三区在线 | 久久五月精品中文字幕 | 久久精品人妻少妇一区二区三区 | 又大又硬又黄的免费视频 | 国产免费观看黄av片 | 国产亚洲tv在线观看 | 亚洲阿v天堂在线 | 俺去俺来也在线www色官网 | 97se亚洲精品一区 | 粉嫩少妇内射浓精videos | 综合激情五月综合激情五月激情1 | 亚洲日韩av一区二区三区四区 | 少妇无码一区二区二三区 | 国产精品手机免费 | 久久久精品欧美一区二区免费 | 一区二区三区乱码在线 | 欧洲 | 精品人妻人人做人人爽夜夜爽 | 东京热一精品无码av | 天天摸天天碰天天添 | 麻豆精品国产精华精华液好用吗 | 亚洲国产精品毛片av不卡在线 | 无码精品国产va在线观看dvd | 在线播放免费人成毛片乱码 | 亚洲娇小与黑人巨大交 | 国产综合色产在线精品 | 九九综合va免费看 | 中国女人内谢69xxxxxa片 | 亚洲欧美日韩国产精品一区二区 | 激情爆乳一区二区三区 | 红桃av一区二区三区在线无码av | 最近的中文字幕在线看视频 | 亚洲春色在线视频 | 色一情一乱一伦一视频免费看 | 午夜理论片yy44880影院 | 76少妇精品导航 | 人妻人人添人妻人人爱 | 日韩精品乱码av一区二区 | 波多野结衣aⅴ在线 | 亚洲一区二区观看播放 | 欧美成人高清在线播放 | 欧美国产日韩亚洲中文 | 国产无遮挡又黄又爽又色 | 亚洲精品成人福利网站 | 精品一二三区久久aaa片 | 精品国产一区二区三区四区在线看 | 久久国产精品偷任你爽任你 | 亚洲成a人片在线观看日本 | 99久久亚洲精品无码毛片 | 一本久久伊人热热精品中文字幕 | 国産精品久久久久久久 | 天堂在线观看www | 日日橹狠狠爱欧美视频 | 欧美性生交活xxxxxdddd | 亚洲人交乣女bbw | 激情内射日本一区二区三区 | 特黄特色大片免费播放器图片 | 亚洲精品一区二区三区在线 | 国产精品亚洲综合色区韩国 | 强辱丰满人妻hd中文字幕 | 伊人久久婷婷五月综合97色 | 亚洲乱码日产精品bd | 国产国产精品人在线视 | 久久熟妇人妻午夜寂寞影院 | 人人妻在人人 | ass日本丰满熟妇pics | 成人无码影片精品久久久 | 人妻夜夜爽天天爽三区 | 综合人妻久久一区二区精品 | 色噜噜亚洲男人的天堂 | 亚洲中文字幕va福利 | 国产熟女一区二区三区四区五区 | 77777熟女视频在线观看 а天堂中文在线官网 | 久久久久国色av免费观看性色 | 少妇激情av一区二区 | 国产午夜无码精品免费看 | 精品人人妻人人澡人人爽人人 | 国产亚洲精品久久久久久国模美 | 中文字幕人妻丝袜二区 | 亚洲熟悉妇女xxx妇女av | 性色av无码免费一区二区三区 | 牲欲强的熟妇农村老妇女 | 97久久超碰中文字幕 | 男人和女人高潮免费网站 | 成人欧美一区二区三区黑人 | 日本欧美一区二区三区乱码 | 久久久久se色偷偷亚洲精品av | 亚洲精品鲁一鲁一区二区三区 | 久久这里只有精品视频9 | 国产亚洲精品久久久久久国模美 | 澳门永久av免费网站 | 国产又爽又黄又刺激的视频 | 精品国产一区二区三区四区在线看 | 精品无码成人片一区二区98 | 一本一道久久综合久久 | 久久久久国色av免费观看性色 | 久久精品成人欧美大片 | 亚洲精品一区二区三区四区五区 | 国产乱人无码伦av在线a | 亚洲欧美日韩成人高清在线一区 | 久久午夜无码鲁丝片秋霞 | 久久精品女人天堂av免费观看 | 国精品人妻无码一区二区三区蜜柚 | 青草视频在线播放 | 久久久精品456亚洲影院 | 久久精品丝袜高跟鞋 | 国产偷抇久久精品a片69 | 亚洲日韩中文字幕在线播放 | 亚洲色无码一区二区三区 | 色综合久久88色综合天天 | 亚洲a无码综合a国产av中文 | 日本www一道久久久免费榴莲 | 又紧又大又爽精品一区二区 | 久久国产精品精品国产色婷婷 | 国产网红无码精品视频 | 久久久亚洲欧洲日产国码αv | 小sao货水好多真紧h无码视频 | 伊人久久大香线蕉午夜 | 亚洲第一无码av无码专区 | 免费人成在线观看网站 | 午夜精品一区二区三区的区别 | 大地资源中文第3页 | 亚洲阿v天堂在线 | 久久无码专区国产精品s | 初尝人妻少妇中文字幕 | 在线视频网站www色 | 日本大乳高潮视频在线观看 | 亚洲中文字幕在线无码一区二区 | 久久无码专区国产精品s | 四虎国产精品免费久久 | 日本一卡二卡不卡视频查询 | 亚洲日韩乱码中文无码蜜桃臀网站 | 久久人妻内射无码一区三区 | 色噜噜亚洲男人的天堂 | 亚洲欧洲日本综合aⅴ在线 | 精品一区二区三区无码免费视频 | 精品国产aⅴ无码一区二区 | 99精品视频在线观看免费 | 人妻中文无码久热丝袜 | 牲欲强的熟妇农村老妇女 | 色综合久久久无码网中文 | 久久精品99久久香蕉国产色戒 | 国产av一区二区精品久久凹凸 | 欧美野外疯狂做受xxxx高潮 | 大肉大捧一进一出好爽视频 | 狠狠躁日日躁夜夜躁2020 | 狠狠色色综合网站 | 天堂无码人妻精品一区二区三区 | 国内丰满熟女出轨videos | 免费无码一区二区三区蜜桃大 | 国产手机在线αⅴ片无码观看 | 四虎4hu永久免费 | 99久久亚洲精品无码毛片 | 国产 浪潮av性色四虎 | 国产精品18久久久久久麻辣 | 99久久精品日本一区二区免费 | 国产另类ts人妖一区二区 | 人妻人人添人妻人人爱 | 国产女主播喷水视频在线观看 | 亚洲色偷偷男人的天堂 | 欧美激情一区二区三区成人 | 免费无码一区二区三区蜜桃大 | 少妇无套内谢久久久久 | 特黄特色大片免费播放器图片 | 波多野42部无码喷潮在线 | 亚洲成av人影院在线观看 | 日日麻批免费40分钟无码 | 日本一卡2卡3卡四卡精品网站 | 久久国产精品偷任你爽任你 | 精品无码一区二区三区的天堂 | 国产色xx群视频射精 | 日韩av无码中文无码电影 | 无码午夜成人1000部免费视频 | 日韩在线不卡免费视频一区 | 国产成人无码专区 | 国产精品久久久一区二区三区 | 国内综合精品午夜久久资源 | 日韩少妇内射免费播放 | 欧美变态另类xxxx | 一本久道久久综合狠狠爱 | 欧美老妇与禽交 | 国产av剧情md精品麻豆 | 少妇激情av一区二区 | 影音先锋中文字幕无码 | 亚洲熟悉妇女xxx妇女av | 97色伦图片97综合影院 | 麻花豆传媒剧国产免费mv在线 | 性开放的女人aaa片 | 国产精品理论片在线观看 | 久久综合网欧美色妞网 | 亚洲日韩精品欧美一区二区 | 国内揄拍国内精品人妻 | 欧美人与禽zoz0性伦交 | 国产麻豆精品一区二区三区v视界 | 成人无码影片精品久久久 | 国产明星裸体无码xxxx视频 | 久久国语露脸国产精品电影 | 国产麻豆精品一区二区三区v视界 | 欧美大屁股xxxxhd黑色 | 亚洲精品久久久久avwww潮水 | 亚洲综合精品香蕉久久网 | 狂野欧美性猛交免费视频 | 在线亚洲高清揄拍自拍一品区 | 人妻少妇精品视频专区 | 牲欲强的熟妇农村老妇女 | 国产成人人人97超碰超爽8 | 天堂无码人妻精品一区二区三区 | 国产精品福利视频导航 | 高中生自慰www网站 | 色欲人妻aaaaaaa无码 | 国产精品无套呻吟在线 | 国产sm调教视频在线观看 | 国产成人一区二区三区在线观看 | 亚洲乱码日产精品bd | 伊人久久大香线蕉av一区二区 | 久久国内精品自在自线 | 久久无码人妻影院 | 久久精品中文字幕大胸 | 国产综合色产在线精品 | 国产av人人夜夜澡人人爽麻豆 | 久久久久久九九精品久 | 国产精品高潮呻吟av久久 | 国产97色在线 | 免 | 欧洲极品少妇 | 丝袜足控一区二区三区 | 5858s亚洲色大成网站www | 亚洲一区二区三区香蕉 | 亚洲人成影院在线观看 | 熟女少妇人妻中文字幕 | 国产网红无码精品视频 | 自拍偷自拍亚洲精品10p | 久久精品国产一区二区三区 | 日本一卡2卡3卡4卡无卡免费网站 国产一区二区三区影院 | 国产舌乚八伦偷品w中 | 7777奇米四色成人眼影 | 亚洲乱亚洲乱妇50p | 丰满人妻精品国产99aⅴ | 丁香啪啪综合成人亚洲 | 国产午夜福利亚洲第一 | 亚洲一区二区三区四区 | 日日鲁鲁鲁夜夜爽爽狠狠 | 激情爆乳一区二区三区 | 精品乱码久久久久久久 | av无码不卡在线观看免费 | 日日碰狠狠躁久久躁蜜桃 | 亚洲精品一区国产 | 特级做a爰片毛片免费69 | 欧美日韩精品 | 色五月五月丁香亚洲综合网 | 欧美熟妇另类久久久久久多毛 | 亚洲精品国产品国语在线观看 | 亚洲一区二区三区在线观看网站 | 成人毛片一区二区 | 国产精品欧美成人 | 正在播放东北夫妻内射 | 久久国产自偷自偷免费一区调 | 亚洲精品午夜国产va久久成人 | 一本大道久久东京热无码av | 无码国产乱人伦偷精品视频 | 国产精品亚洲а∨无码播放麻豆 | 99久久精品国产一区二区蜜芽 | 亲嘴扒胸摸屁股激烈网站 | 久久久中文久久久无码 | 天干天干啦夜天干天2017 | 女人被男人爽到呻吟的视频 | 国产黄在线观看免费观看不卡 | 欧美 丝袜 自拍 制服 另类 | 亚洲七七久久桃花影院 | 国内老熟妇对白xxxxhd | 成年美女黄网站色大免费视频 | 人妻少妇被猛烈进入中文字幕 | 亚洲色欲久久久综合网东京热 | www国产精品内射老师 | 在线精品亚洲一区二区 | 无码午夜成人1000部免费视频 | 成年女人永久免费看片 | 色综合久久久无码网中文 | 精品国产aⅴ无码一区二区 | 亚洲国产精品一区二区美利坚 | 一本久道久久综合婷婷五月 | 日日噜噜噜噜夜夜爽亚洲精品 | 久久国产精品精品国产色婷婷 | 久久久久久久久888 | 中文字幕日产无线码一区 | 特黄特色大片免费播放器图片 | 丰满少妇女裸体bbw | 2020久久超碰国产精品最新 | 天堂а√在线地址中文在线 | 国产亚洲精品久久久久久国模美 | 久久99精品国产.久久久久 | 伊人久久大香线蕉av一区二区 | 最近中文2019字幕第二页 | 国产激情无码一区二区 | 日韩精品无码一本二本三本色 | 国产精品99爱免费视频 | 好男人www社区 | 久久久久99精品成人片 | 国产手机在线αⅴ片无码观看 | 欧美喷潮久久久xxxxx | 小sao货水好多真紧h无码视频 | 国产精品第一国产精品 | 国产精品亚洲lv粉色 | 国产精品免费大片 | 亚洲一区二区三区国产精华液 | 国产在线一区二区三区四区五区 | 色综合久久久久综合一本到桃花网 | 久久精品国产日本波多野结衣 | 色综合视频一区二区三区 | 欧美xxxx黑人又粗又长 | 日本精品高清一区二区 | 日韩欧美成人免费观看 | 亚洲精品久久久久avwww潮水 | 人人爽人人澡人人人妻 | 日本精品人妻无码77777 天堂一区人妻无码 | 伊人色综合久久天天小片 | 人妻与老人中文字幕 | 精品乱码久久久久久久 | 99久久久无码国产精品免费 | 午夜福利试看120秒体验区 | 天天爽夜夜爽夜夜爽 | 亚洲中文字幕乱码av波多ji | 性生交片免费无码看人 | 正在播放老肥熟妇露脸 | 亚洲欧美中文字幕5发布 | 伊人久久大香线蕉午夜 | 蜜桃av抽搐高潮一区二区 | 国产精品美女久久久网av | 色一情一乱一伦 | 国产精品99爱免费视频 | 亚洲精品欧美二区三区中文字幕 | 婷婷五月综合缴情在线视频 | 亚洲人交乣女bbw | 亚洲欧美色中文字幕在线 | 亚洲熟妇色xxxxx欧美老妇y | 天堂久久天堂av色综合 | aⅴ亚洲 日韩 色 图网站 播放 | 又紧又大又爽精品一区二区 | 国产人成高清在线视频99最全资源 | 丰满少妇人妻久久久久久 | 高潮毛片无遮挡高清免费视频 | 国产办公室秘书无码精品99 | 欧美乱妇无乱码大黄a片 | 久久zyz资源站无码中文动漫 | 青草青草久热国产精品 | 中文字幕人妻无码一区二区三区 | 国产精品毛多多水多 | 国产精品第一国产精品 | 少妇被黑人到高潮喷出白浆 | 国产精品18久久久久久麻辣 | 日韩成人一区二区三区在线观看 | 国产口爆吞精在线视频 | 国产成人无码午夜视频在线观看 | 鲁鲁鲁爽爽爽在线视频观看 | 99在线 | 亚洲 | 国产黑色丝袜在线播放 | 国产97色在线 | 免 | 欧洲vodafone精品性 | 国产人妻精品午夜福利免费 | 久久久久久亚洲精品a片成人 | 婷婷丁香五月天综合东京热 | 人妻与老人中文字幕 | 国产偷抇久久精品a片69 | 国产精品无码成人午夜电影 | 未满成年国产在线观看 | 午夜无码区在线观看 | 美女毛片一区二区三区四区 | 久久人妻内射无码一区三区 | 久久综合香蕉国产蜜臀av | 乱人伦人妻中文字幕无码久久网 | 国精品人妻无码一区二区三区蜜柚 | 久久无码中文字幕免费影院蜜桃 | 精品一区二区三区波多野结衣 | 国产乱码精品一品二品 | 国内精品人妻无码久久久影院 | 国产成人无码午夜视频在线观看 | 欧美老熟妇乱xxxxx | 午夜时刻免费入口 | 精品欧洲av无码一区二区三区 | 亚洲乱亚洲乱妇50p | 亚洲成a人一区二区三区 | 国产口爆吞精在线视频 | 精品无人区无码乱码毛片国产 | 极品嫩模高潮叫床 | 亚洲男女内射在线播放 | 亚洲精品国产第一综合99久久 | 帮老师解开蕾丝奶罩吸乳网站 | 久久精品女人天堂av免费观看 | 亚洲乱码国产乱码精品精 | 国产一区二区三区精品视频 | 国产热a欧美热a在线视频 | 亚洲国产av美女网站 | 四虎永久在线精品免费网址 | 国精品人妻无码一区二区三区蜜柚 | 亚洲午夜福利在线观看 | 日韩精品无码一区二区中文字幕 | 麻花豆传媒剧国产免费mv在线 | 六月丁香婷婷色狠狠久久 | 久久亚洲日韩精品一区二区三区 | 亚洲精品一区二区三区大桥未久 | 久久久中文久久久无码 | 免费看男女做好爽好硬视频 | 中文无码精品a∨在线观看不卡 | 成人免费视频视频在线观看 免费 | 国产精品亚洲а∨无码播放麻豆 | 国产无遮挡又黄又爽又色 | 奇米影视7777久久精品 | 亚洲成熟女人毛毛耸耸多 | 55夜色66夜色国产精品视频 | 亚洲色在线无码国产精品不卡 | 国内精品一区二区三区不卡 | 欧美丰满少妇xxxx性 | 装睡被陌生人摸出水好爽 | 国产精品嫩草久久久久 | 国产香蕉97碰碰久久人人 | 国产成人精品一区二区在线小狼 | 国产内射老熟女aaaa | 久久久精品人妻久久影视 | 国产成人无码a区在线观看视频app | 永久免费观看美女裸体的网站 | 国产精品毛多多水多 | 樱花草在线社区www | 国产综合久久久久鬼色 | 精品人妻人人做人人爽 | 国产va免费精品观看 | 影音先锋中文字幕无码 | 日韩在线不卡免费视频一区 | 亚洲精品中文字幕 | 97精品人妻一区二区三区香蕉 | 又色又爽又黄的美女裸体网站 | 亚洲中文字幕成人无码 | 成人女人看片免费视频放人 | 亚洲另类伦春色综合小说 | 久久人人97超碰a片精品 | 国产办公室秘书无码精品99 | 青青青手机频在线观看 | 成人精品视频一区二区 | 奇米影视7777久久精品 | 色五月丁香五月综合五月 | 扒开双腿吃奶呻吟做受视频 | 人妻有码中文字幕在线 | 久久精品国产大片免费观看 | 久久精品视频在线看15 | 色综合视频一区二区三区 | 男女猛烈xx00免费视频试看 | 激情五月综合色婷婷一区二区 | 日韩欧美成人免费观看 | 国产乱码精品一品二品 | 东京无码熟妇人妻av在线网址 | 无遮挡国产高潮视频免费观看 | 久久人人爽人人爽人人片av高清 | 人妻中文无码久热丝袜 | 天堂无码人妻精品一区二区三区 | 丰满少妇熟乱xxxxx视频 | 色欲综合久久中文字幕网 | 四虎影视成人永久免费观看视频 | 中文字幕乱码人妻二区三区 | 欧洲精品码一区二区三区免费看 | 女人被男人爽到呻吟的视频 | 人妻aⅴ无码一区二区三区 | 午夜免费福利小电影 | 亚洲成a人一区二区三区 | 九九久久精品国产免费看小说 | 亚洲欧洲日本综合aⅴ在线 | 美女极度色诱视频国产 | 欧美性猛交xxxx富婆 | 久久成人a毛片免费观看网站 | 日本一区二区更新不卡 | www国产精品内射老师 | 玩弄人妻少妇500系列视频 | 玩弄少妇高潮ⅹxxxyw | 国内综合精品午夜久久资源 | 中文字幕av无码一区二区三区电影 | 午夜无码区在线观看 | 台湾无码一区二区 | 精品国偷自产在线视频 | 国产人成高清在线视频99最全资源 | 亚洲成色在线综合网站 | 国产精品毛片一区二区 | 国产成人精品三级麻豆 | 18精品久久久无码午夜福利 | 久久久成人毛片无码 | 成人亚洲精品久久久久 | 久久久久成人精品免费播放动漫 | 2020最新国产自产精品 | 日日碰狠狠丁香久燥 | 久久99精品国产麻豆蜜芽 | 一区二区三区高清视频一 | 又湿又紧又大又爽a视频国产 | 亚洲日韩av一区二区三区四区 | 中文字幕 人妻熟女 | 野外少妇愉情中文字幕 | 扒开双腿疯狂进出爽爽爽视频 | 精品国产一区av天美传媒 | 2020久久超碰国产精品最新 | 亚洲国产欧美日韩精品一区二区三区 | 亚洲成av人片在线观看无码不卡 | 色噜噜亚洲男人的天堂 | 国产精品人人妻人人爽 | 精品亚洲韩国一区二区三区 | 好男人社区资源 | 国产成人无码一二三区视频 | 国产精品无码一区二区三区不卡 | 无码一区二区三区在线 | 国产激情艳情在线看视频 | 亚洲第一无码av无码专区 | 国产精品亚洲专区无码不卡 | 国内少妇偷人精品视频 | 丁香花在线影院观看在线播放 | 精品人妻人人做人人爽 | 国产后入清纯学生妹 | 97人妻精品一区二区三区 | 午夜精品一区二区三区的区别 | 大屁股大乳丰满人妻 | 少妇厨房愉情理9仑片视频 | 欧美人与善在线com | 中文字幕色婷婷在线视频 | 国产精品无码成人午夜电影 | 国产精品久久久久无码av色戒 | 纯爱无遮挡h肉动漫在线播放 | 国内揄拍国内精品少妇国语 | 久久99精品久久久久久动态图 | 2020最新国产自产精品 | 国产凸凹视频一区二区 | 小sao货水好多真紧h无码视频 | 熟妇女人妻丰满少妇中文字幕 | 国产成人久久精品流白浆 | 西西人体www44rt大胆高清 | 久久国产自偷自偷免费一区调 | 成人欧美一区二区三区黑人 | 久久99国产综合精品 | 午夜福利一区二区三区在线观看 | 麻豆精品国产精华精华液好用吗 | 亚洲欧美综合区丁香五月小说 | 草草网站影院白丝内射 | 亚洲人成影院在线无码按摩店 | 久久久久99精品国产片 | 成人无码精品1区2区3区免费看 | 青青久在线视频免费观看 | 中文字幕乱码人妻无码久久 | 久久精品女人天堂av免费观看 | 美女扒开屁股让男人桶 | 欧美性猛交xxxx富婆 | 精品成在人线av无码免费看 | 亚洲第一无码av无码专区 | 大地资源中文第3页 | 亚洲人亚洲人成电影网站色 | 成人免费无码大片a毛片 | 久久这里只有精品视频9 | 亚洲综合另类小说色区 | 欧美国产亚洲日韩在线二区 | 国产精品高潮呻吟av久久 | 国产精品久免费的黄网站 | 人人妻人人澡人人爽精品欧美 | 亚洲男女内射在线播放 | 天海翼激烈高潮到腰振不止 | 99久久无码一区人妻 | 欧美成人午夜精品久久久 | 精品一区二区三区无码免费视频 | 老熟妇乱子伦牲交视频 | 国产热a欧美热a在线视频 | 内射后入在线观看一区 | 樱花草在线社区www | 久久久久亚洲精品男人的天堂 | 亚洲国产精品无码一区二区三区 | 蜜臀av在线观看 在线欧美精品一区二区三区 | 97夜夜澡人人双人人人喊 | 日韩无套无码精品 | 婷婷丁香六月激情综合啪 | 亚洲中文字幕成人无码 | 亚洲va中文字幕无码久久不卡 | 欧美黑人性暴力猛交喷水 | 中文字幕无码日韩专区 | 在线看片无码永久免费视频 | 国产做国产爱免费视频 | 国产精品嫩草久久久久 | 免费观看又污又黄的网站 | 国内揄拍国内精品少妇国语 | 亚洲中文字幕无码一久久区 | 沈阳熟女露脸对白视频 | 熟妇人妻无码xxx视频 | √8天堂资源地址中文在线 | 国产97在线 | 亚洲 | 日韩av激情在线观看 | 亚洲а∨天堂久久精品2021 | 国产色在线 | 国产 | 色综合久久久久综合一本到桃花网 | 久久精品人人做人人综合 | 狠狠色噜噜狠狠狠狠7777米奇 | 日本乱人伦片中文三区 | 日本丰满护士爆乳xxxx | 在线播放无码字幕亚洲 | 丝袜人妻一区二区三区 | 国产av无码专区亚洲awww | 内射爽无广熟女亚洲 | 亚洲精品www久久久 | 日本xxxx色视频在线观看免费 | 荫蒂添的好舒服视频囗交 | 久久综合久久自在自线精品自 | 99久久精品日本一区二区免费 | 日本丰满熟妇videos | 99精品无人区乱码1区2区3区 | 嫩b人妻精品一区二区三区 | 欧美一区二区三区视频在线观看 | 欧美xxxx黑人又粗又长 | 女人被爽到呻吟gif动态图视看 | 荡女精品导航 | 狠狠色噜噜狠狠狠狠7777米奇 | 国产国语老龄妇女a片 | 精品国产成人一区二区三区 | 亚洲人成影院在线观看 | 又湿又紧又大又爽a视频国产 | 国产成人无码av在线影院 | 日韩精品无码免费一区二区三区 | 国产三级精品三级男人的天堂 | 免费视频欧美无人区码 | 久久国产精品_国产精品 | 无码人妻精品一区二区三区不卡 | 亚洲色欲色欲天天天www | 亚洲 激情 小说 另类 欧美 | 日产国产精品亚洲系列 | 激情人妻另类人妻伦 | 久久久国产一区二区三区 | 漂亮人妻洗澡被公强 日日躁 | 夜精品a片一区二区三区无码白浆 | 国产乱子伦视频在线播放 | 成人亚洲精品久久久久软件 | 国产精品无码久久av | 永久免费观看国产裸体美女 | 麻豆国产97在线 | 欧洲 | 99久久精品日本一区二区免费 | 亚洲s码欧洲m码国产av | 日韩视频 中文字幕 视频一区 | 亚洲人成网站免费播放 | 在线欧美精品一区二区三区 | 一区二区三区乱码在线 | 欧洲 | 日韩精品无码免费一区二区三区 | 精品久久久无码中文字幕 | 日本高清一区免费中文视频 | 亚洲日韩一区二区 | 一本久道久久综合婷婷五月 | 免费国产成人高清在线观看网站 | 亚洲综合无码一区二区三区 | 日韩精品无码一本二本三本色 | 最近中文2019字幕第二页 | 久久久久久a亚洲欧洲av冫 | 国产美女极度色诱视频www | 最新国产麻豆aⅴ精品无码 | 亚洲人成网站色7799 | 未满成年国产在线观看 | 影音先锋中文字幕无码 | 久久久成人毛片无码 | 国产人成高清在线视频99最全资源 | 国产精品亚洲专区无码不卡 | 国产精品igao视频网 | 久久99精品国产麻豆蜜芽 | 最近中文2019字幕第二页 | 亚洲精品午夜无码电影网 | 久久99精品国产麻豆蜜芽 | 99久久99久久免费精品蜜桃 | 亚洲色欲久久久综合网东京热 | 亚洲精品国产精品乱码视色 | 乱人伦中文视频在线观看 | 久久熟妇人妻午夜寂寞影院 | 亚洲中文无码av永久不收费 | 大色综合色综合网站 | 国产无套粉嫩白浆在线 | 最近免费中文字幕中文高清百度 | 狠狠cao日日穞夜夜穞av | 亚洲中文字幕av在天堂 | 55夜色66夜色国产精品视频 | 久久综合给合久久狠狠狠97色 | 日韩精品a片一区二区三区妖精 | 中文字幕+乱码+中文字幕一区 | 欧美自拍另类欧美综合图片区 | 国产人妻人伦精品1国产丝袜 | 少妇无码一区二区二三区 | 欧美 日韩 人妻 高清 中文 | 激情五月综合色婷婷一区二区 | 日本va欧美va欧美va精品 | 男女超爽视频免费播放 | 大胆欧美熟妇xx | 大地资源中文第3页 | 久久97精品久久久久久久不卡 | 色偷偷av老熟女 久久精品人妻少妇一区二区三区 | 国产精品va在线观看无码 | 亚洲中文字幕在线无码一区二区 | 思思久久99热只有频精品66 | 成年美女黄网站色大免费全看 | 国产乱人伦av在线无码 | 宝宝好涨水快流出来免费视频 | 国产精品高潮呻吟av久久 | 精品亚洲成av人在线观看 | 2020最新国产自产精品 | 未满成年国产在线观看 | 欧美freesex黑人又粗又大 | 熟妇人妻无乱码中文字幕 | 亚洲精品国产精品乱码视色 | 日日夜夜撸啊撸 | 国产无套内射久久久国产 | 国产成人精品三级麻豆 | 国内老熟妇对白xxxxhd | 久久久久久久久888 | 久久国语露脸国产精品电影 | www国产精品内射老师 | 内射巨臀欧美在线视频 | 免费看男女做好爽好硬视频 | 色欲av亚洲一区无码少妇 | 天天躁日日躁狠狠躁免费麻豆 | 麻豆国产丝袜白领秘书在线观看 | 99久久精品日本一区二区免费 | 国模大胆一区二区三区 | 精品人妻av区 | 久久久久久亚洲精品a片成人 | 免费人成在线观看网站 | 成人精品天堂一区二区三区 | 亚洲欧美日韩综合久久久 | 丰满妇女强制高潮18xxxx | 久久综合香蕉国产蜜臀av | 男女性色大片免费网站 | 日本又色又爽又黄的a片18禁 | 黑人玩弄人妻中文在线 | 国产午夜无码视频在线观看 | 国产麻豆精品一区二区三区v视界 | 99久久精品国产一区二区蜜芽 | 国产成人精品必看 | 无码任你躁久久久久久久 | 国产精品久久久久无码av色戒 | 久久综合狠狠综合久久综合88 | 精品国精品国产自在久国产87 | 麻豆蜜桃av蜜臀av色欲av | 久久五月精品中文字幕 | 亚洲理论电影在线观看 | 蜜臀av无码人妻精品 | 在线观看欧美一区二区三区 | 日韩视频 中文字幕 视频一区 | 国产极品美女高潮无套在线观看 | 国产绳艺sm调教室论坛 | 久久精品女人天堂av免费观看 | 久久精品成人欧美大片 | 在线a亚洲视频播放在线观看 | 国产乱人伦av在线无码 | 中文字幕av无码一区二区三区电影 | 丝袜人妻一区二区三区 | 亚洲色在线无码国产精品不卡 | 欧美性生交xxxxx久久久 | 亚洲国产欧美国产综合一区 | 国产成人精品三级麻豆 | 日韩视频 中文字幕 视频一区 | 亚洲色大成网站www国产 | 国产成人无码a区在线观看视频app | 国产绳艺sm调教室论坛 | 纯爱无遮挡h肉动漫在线播放 | 熟妇人妻中文av无码 | 超碰97人人做人人爱少妇 | 亚洲第一无码av无码专区 | 18黄暴禁片在线观看 | 日韩欧美中文字幕在线三区 | 国产精品嫩草久久久久 | 18无码粉嫩小泬无套在线观看 | 国产美女精品一区二区三区 | 又大又紧又粉嫩18p少妇 | 国产在热线精品视频 | 成年美女黄网站色大免费视频 | 在线播放无码字幕亚洲 | 国产无遮挡吃胸膜奶免费看 | 精品国产av色一区二区深夜久久 | 国产成人人人97超碰超爽8 | 国产精品亚洲一区二区三区喷水 | 无码中文字幕色专区 | 77777熟女视频在线观看 а天堂中文在线官网 | 国产真实伦对白全集 | 国产精品久久国产三级国 | 青青草原综合久久大伊人精品 | 狠狠色噜噜狠狠狠7777奇米 | 少妇激情av一区二区 | 亚洲呦女专区 | 欧美日韩视频无码一区二区三 | 天天摸天天碰天天添 | 欧美人与禽zoz0性伦交 | 天干天干啦夜天干天2017 | 亚洲精品午夜国产va久久成人 | 装睡被陌生人摸出水好爽 | 少妇性l交大片 | а√资源新版在线天堂 | 亚洲第一无码av无码专区 | 99久久精品午夜一区二区 | 日韩亚洲欧美中文高清在线 | 99久久亚洲精品无码毛片 | 亚洲国产午夜精品理论片 | 欧美真人作爱免费视频 | 亚洲爆乳精品无码一区二区三区 | 国产成人无码av片在线观看不卡 | 亚洲色大成网站www国产 | 一二三四社区在线中文视频 | 亚洲国产精华液网站w | 久久国产劲爆∧v内射 | 欧美熟妇另类久久久久久不卡 | 国产精品福利视频导航 | 性欧美熟妇videofreesex | 国产后入清纯学生妹 | 一个人免费观看的www视频 | 无遮无挡爽爽免费视频 | 色综合久久88色综合天天 | 国产乱人伦偷精品视频 | 午夜精品久久久久久久 | 午夜精品久久久久久久久 | 又大又黄又粗又爽的免费视频 | 久久伊人色av天堂九九小黄鸭 | 99久久婷婷国产综合精品青草免费 | 色婷婷综合中文久久一本 | 国产精品成人av在线观看 | 青青久在线视频免费观看 | 少妇性荡欲午夜性开放视频剧场 | 少妇人妻大乳在线视频 | 色欲人妻aaaaaaa无码 | 国内综合精品午夜久久资源 | 欧美日韩精品 | 亚洲热妇无码av在线播放 | 国产国语老龄妇女a片 | 亚洲国产av精品一区二区蜜芽 | 国产69精品久久久久app下载 | 蜜臀aⅴ国产精品久久久国产老师 | 久久久久久久久蜜桃 | 国产午夜亚洲精品不卡 | 人妻少妇精品视频专区 | 国产农村乱对白刺激视频 | 无码av免费一区二区三区试看 | 久久久国产一区二区三区 | 国内精品九九久久久精品 | 天天做天天爱天天爽综合网 | 国产午夜精品一区二区三区嫩草 | 亚洲一区二区三区含羞草 | 国精品人妻无码一区二区三区蜜柚 | 牲欲强的熟妇农村老妇女 | 亚欧洲精品在线视频免费观看 | 日本乱人伦片中文三区 | 四虎永久在线精品免费网址 | 国产欧美熟妇另类久久久 | 丝袜美腿亚洲一区二区 | 久久精品国产大片免费观看 | 国产成人无码a区在线观看视频app | 色五月五月丁香亚洲综合网 | 又大又硬又黄的免费视频 | 亚洲日本va午夜在线电影 | 激情五月综合色婷婷一区二区 | 中文精品无码中文字幕无码专区 | 国产精品人人爽人人做我的可爱 | 欧美日韩色另类综合 | 天堂一区人妻无码 | 午夜福利电影 | 日韩亚洲欧美精品综合 | 内射老妇bbwx0c0ck | 日韩少妇内射免费播放 | 国产成人精品无码播放 | 欧美亚洲国产一区二区三区 | 精品国产青草久久久久福利 | 国产午夜精品一区二区三区嫩草 | 国产av人人夜夜澡人人爽麻豆 | 娇妻被黑人粗大高潮白浆 | 男人扒开女人内裤强吻桶进去 | 东京热一精品无码av | 真人与拘做受免费视频一 | 国内精品久久毛片一区二区 | 国产精品久久久午夜夜伦鲁鲁 | 婷婷五月综合缴情在线视频 | 国产欧美熟妇另类久久久 | 永久免费观看美女裸体的网站 | 日日麻批免费40分钟无码 | 国产97在线 | 亚洲 | 超碰97人人做人人爱少妇 | 亚洲一区二区三区播放 | 亚洲国产午夜精品理论片 | 国产人成高清在线视频99最全资源 | 国产欧美精品一区二区三区 | 国产真实伦对白全集 | 亚洲欧洲无卡二区视頻 | 成人试看120秒体验区 | 欧美性黑人极品hd | 免费男性肉肉影院 | 成人av无码一区二区三区 | 色 综合 欧美 亚洲 国产 | 亚洲一区二区三区含羞草 | 丰满人妻精品国产99aⅴ | 欧美老妇交乱视频在线观看 | 乱码av麻豆丝袜熟女系列 | 全球成人中文在线 | 女人被男人爽到呻吟的视频 | 国产无套粉嫩白浆在线 | 97夜夜澡人人爽人人喊中国片 | 98国产精品综合一区二区三区 | 久久无码人妻影院 | 国产精品鲁鲁鲁 | 国产精品无码永久免费888 | 六十路熟妇乱子伦 | 色情久久久av熟女人妻网站 | 国产疯狂伦交大片 | 在线精品亚洲一区二区 | 日韩精品无码免费一区二区三区 | 亚洲午夜久久久影院 | 成人性做爰aaa片免费看不忠 | 久久99精品久久久久久动态图 | 日韩精品无码一本二本三本色 | 天天拍夜夜添久久精品大 | 亚洲a无码综合a国产av中文 | 欧美人与禽猛交狂配 | 国产片av国语在线观看 | 色婷婷香蕉在线一区二区 | 97人妻精品一区二区三区 | 狠狠色欧美亚洲狠狠色www | 国产精品国产三级国产专播 | 小sao货水好多真紧h无码视频 | 婷婷六月久久综合丁香 | 狠狠噜狠狠狠狠丁香五月 | 日本精品少妇一区二区三区 | 欧美亚洲日韩国产人成在线播放 | 亚洲欧美日韩成人高清在线一区 | 精品国产成人一区二区三区 | 国产成人一区二区三区别 | 少妇无套内谢久久久久 | 国产女主播喷水视频在线观看 | 搡女人真爽免费视频大全 | 亚洲日本va中文字幕 | 澳门永久av免费网站 | 少妇无码av无码专区在线观看 | 日韩精品一区二区av在线 | 日本精品高清一区二区 | 久久国产精品_国产精品 | 成人性做爰aaa片免费看不忠 | 亚洲人交乣女bbw | 精品人妻人人做人人爽 | 久久久久久a亚洲欧洲av冫 | 老头边吃奶边弄进去呻吟 | 久9re热视频这里只有精品 | 国产成人午夜福利在线播放 | 国产成人无码a区在线观看视频app | 国产特级毛片aaaaaaa高清 | 亚洲精品综合一区二区三区在线 | 欧美国产亚洲日韩在线二区 | 久久久www成人免费毛片 | 国产福利视频一区二区 | 亚洲精品一区二区三区四区五区 | 玩弄人妻少妇500系列视频 | 少妇性l交大片欧洲热妇乱xxx | 亚洲成a人片在线观看日本 | 亚洲自偷精品视频自拍 | 日本丰满熟妇videos | 亚洲中文字幕久久无码 | 青青青手机频在线观看 | 无码播放一区二区三区 | 人妻人人添人妻人人爱 | 欧美丰满老熟妇xxxxx性 | 精品厕所偷拍各类美女tp嘘嘘 | 国产特级毛片aaaaaaa高清 | 午夜精品久久久久久久 | 精品无人国产偷自产在线 | 亚洲色偷偷偷综合网 | 日韩欧美成人免费观看 | 天堂а√在线中文在线 | 日日躁夜夜躁狠狠躁 | 国产成人无码午夜视频在线观看 | 午夜精品一区二区三区的区别 | 人妻无码久久精品人妻 | 丁香花在线影院观看在线播放 | 人人爽人人爽人人片av亚洲 | 国产美女精品一区二区三区 | 女人高潮内射99精品 | 少妇无码一区二区二三区 | 99riav国产精品视频 | 国产成人av免费观看 | 少妇高潮一区二区三区99 | 亚洲人成网站色7799 | 国产色视频一区二区三区 | 在线观看国产午夜福利片 | 久久亚洲日韩精品一区二区三区 | 国产办公室秘书无码精品99 | 欧美性猛交xxxx富婆 | 欧美xxxx黑人又粗又长 | 久久久国产一区二区三区 | 国产综合在线观看 | 日本一区二区三区免费高清 | 自拍偷自拍亚洲精品被多人伦好爽 | 99riav国产精品视频 | 大肉大捧一进一出好爽视频 | 日产国产精品亚洲系列 | 精品国产青草久久久久福利 | 日本乱人伦片中文三区 | 国产尤物精品视频 | 99国产精品白浆在线观看免费 | 国产亚洲tv在线观看 | 日日躁夜夜躁狠狠躁 | 丰腴饱满的极品熟妇 | 熟女少妇人妻中文字幕 | 亚洲中文字幕成人无码 | 欧美日韩一区二区三区自拍 | 蜜桃av抽搐高潮一区二区 | 夫妻免费无码v看片 | 中文字幕乱码亚洲无线三区 | 中文字幕乱码人妻二区三区 | 美女黄网站人色视频免费国产 | 亚洲国产成人av在线观看 | 精品乱子伦一区二区三区 | 亚洲国产欧美在线成人 | 国产精品无套呻吟在线 | 少妇无码吹潮 | 亚洲 激情 小说 另类 欧美 | 两性色午夜视频免费播放 | 国产亚洲精品久久久久久久 | 永久免费精品精品永久-夜色 | 一本无码人妻在中文字幕免费 | 欧美成人高清在线播放 | 一二三四社区在线中文视频 | 久久久精品人妻久久影视 | 中文字幕乱码人妻无码久久 | 国内精品久久久久久中文字幕 | 精品国精品国产自在久国产87 | 人人妻人人澡人人爽欧美一区 | 国产绳艺sm调教室论坛 | 99精品久久毛片a片 | 精品人妻中文字幕有码在线 | 国产激情综合五月久久 | 成人免费无码大片a毛片 | 一二三四在线观看免费视频 | 国产在线无码精品电影网 | 国产极品视觉盛宴 | 无码免费一区二区三区 | 青青草原综合久久大伊人精品 | 熟妇人妻无乱码中文字幕 | 国产真人无遮挡作爱免费视频 | 国产精品美女久久久网av | 99久久久国产精品无码免费 | 亚洲春色在线视频 | 男女爱爱好爽视频免费看 | 欧美丰满老熟妇xxxxx性 | 久久久精品欧美一区二区免费 | 欧美人与禽猛交狂配 | 黑人粗大猛烈进出高潮视频 | 精品国产一区二区三区四区在线看 | 国产成人精品久久亚洲高清不卡 | 中文字幕中文有码在线 | 玩弄中年熟妇正在播放 | 久久久中文久久久无码 | 中文字幕乱码亚洲无线三区 | 国产成人无码区免费内射一片色欲 | 日本爽爽爽爽爽爽在线观看免 | 亚洲国产av精品一区二区蜜芽 | 久久亚洲中文字幕无码 | 国产人妻大战黑人第1集 | 国精产品一品二品国精品69xx | 日日天日日夜日日摸 | 窝窝午夜理论片影院 | 国产精品视频免费播放 | 国产成人无码av在线影院 | 亚洲男女内射在线播放 | 亚洲精品久久久久中文第一幕 | 亚洲一区二区三区香蕉 | 狠狠色丁香久久婷婷综合五月 | 色一情一乱一伦一视频免费看 | 99久久99久久免费精品蜜桃 | 午夜精品一区二区三区在线观看 | 六十路熟妇乱子伦 | 午夜精品一区二区三区的区别 | 久久熟妇人妻午夜寂寞影院 |