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

10萬條數據批量插入,到底怎么做才快?

開發 前端
雖然是一條一條的插入,但是我們要開啟批處理模式(BATCH),這樣前前后后就只用這一個 SqlSession,如果不采用批處理模式,反反復復的獲取 Connection 以及釋放 Connection 會耗費大量時間,效率奇低,這種效率奇低的方式松哥就不給大家測試了。

[[432840]]

上周松哥轉載了一個數據批量插入的文章,里邊和大家聊了一下數據批量插入的問題,批量插入到底怎么做才快。

有個小伙伴看了文章后提出了不同的意見:

松哥認真和 BUG 同學聊了下,基本上明白了這個小伙伴的意思,于是我自己也寫了個測試案例,重新整理了今天這篇文章,希望和小伙伴們一起探討這個問題,也歡迎小伙伴們提出更好的方案。

1. 思路分析

批量插入這個問題,我們用 JDBC 操作,其實就是兩種思路吧:

  • 用一個 for 循環,把數據一條一條的插入(這種需要開啟批處理)。
  • 生成一條插入 sql,類似這種 insert into user(username,address) values('aa','bb'),('cc','dd')...。

到底哪種快呢?

我們從兩方面來考慮這個問題:

  • 插入 SQL 本身執行的效率。
  • 網絡 I/O。

先說第一種方案,就是用 for 循環循環插入:

  • 這種方案的優勢在于,JDBC 中的 PreparedStatement 有預編譯功能,預編譯之后會緩存起來,后面的 SQL 執行會比較快并且 JDBC 可以開啟批處理,這個批處理執行非常給力。
  • 劣勢在于,很多時候我們的 SQL 服務器和應用服務器可能并不是同一臺,所以必須要考慮網絡 IO,如果網絡 IO 比較費時間的話,那么可能會拖慢 SQL 執行的速度。

再來說第二種方案,就是生成一條 SQL 插入:

  • 這種方案的優勢在于只有一次網絡 IO,即使分片處理也只是數次網絡 IO,所以這種方案不會在網絡 IO 上花費太多時間。
  • 當然這種方案有好幾個劣勢,一是 SQL 太長了,甚至可能需要分片后批量處理;二是無法充分發揮 PreparedStatement 預編譯的優勢,SQL 要重新解析且無法復用;三是最終生成的 SQL 太長了,數據庫管理器解析這么長的 SQL 也需要時間。

所以我們最終要考慮的就是我們在網絡 IO 上花費的時間,是否超過了 SQL 插入的時間?這是我們要考慮的核心問題。

2. 數據測試

接下來我們來做一個簡單的測試,批量插入 5 萬條數據看下。

首先準備一個簡單的測試表:

  1. CREATE TABLE `user` ( 
  2.   `id` int(11) unsigned NOT NULL AUTO_INCREMENT, 
  3.   `username` varchar(255) DEFAULT NULL
  4.   `address` varchar(255) DEFAULT NULL
  5.   `passwordvarchar(255) DEFAULT NULL
  6.   PRIMARY KEY (`id`) 
  7. ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4; 

接下來創建一個 Spring Boot 工程,引入 MyBatis 依賴和 MySQL 驅動,然后 application.properties 中配置一下數據庫連接信息:

  1. spring.datasource.username=root 
  2. spring.datasource.password=123 
  3. spring.datasource.url=jdbc:mysql:///batch_insert?serverTimezone=Asia/Shanghai&rewriteBatchedStatements=true 

大家需要注意,這個數據庫連接 URL 地址中多了一個參數 rewriteBatchedStatements,這是核心。

MySQL JDBC 驅動在默認情況下會無視 executeBatch() 語句,把我們期望批量執行的一組 sql 語句拆散,一條一條地發給 MySQL 數據庫,批量插入實際上是單條插入,直接造成較低的性能。將 rewriteBatchedStatements 參數置為 true, 數據庫驅動才會幫我們批量執行 SQL。

OK,這樣準備工作就做好了。

2.1 方案一測試

首先我們來看方案一的測試,即一條一條的插入(實際上是批處理)。

首先創建相應的 mapper,如下:

  1. @Mapper 
  2. public interface UserMapper { 
  3.     Integer addUserOneByOne(User user); 

對應的 XML 文件如下:

  1. <insert id="addUserOneByOne"
  2.     insert into user (username,address,passwordvalues (#{username},#{address},#{password}) 
  3. </insert

service 如下:

  1. @Service 
  2. public class UserService extends ServiceImpl<UserMapper, User> implements IUserService { 
  3.     private static final Logger logger = LoggerFactory.getLogger(UserService.class); 
  4.     @Autowired 
  5.     UserMapper userMapper; 
  6.     @Autowired 
  7.     SqlSessionFactory sqlSessionFactory; 
  8.  
  9.     @Transactional(rollbackFor = Exception.class) 
  10.     public void addUserOneByOne(List<User> users) { 
  11.         SqlSession session = sqlSessionFactory.openSession(ExecutorType.BATCH); 
  12.         UserMapper um = session.getMapper(UserMapper.class); 
  13.         long startTime = System.currentTimeMillis(); 
  14.         for (User user : users) { 
  15.             um.addUserOneByOne(user); 
  16.         } 
  17.         session.commit(); 
  18.         long endTime = System.currentTimeMillis(); 
  19.         logger.info("一條條插入 SQL 耗費時間 {}", (endTime - startTime)); 
  20.     } 

這里我要說一下:

雖然是一條一條的插入,但是我們要開啟批處理模式(BATCH),這樣前前后后就只用這一個 SqlSession,如果不采用批處理模式,反反復復的獲取 Connection 以及釋放 Connection 會耗費大量時間,效率奇低,這種效率奇低的方式松哥就不給大家測試了。

接下來寫一個簡單的測試接口看下:

  1. @RestController 
  2. public class HelloController { 
  3.     private static final Logger logger = getLogger(HelloController.class); 
  4.     @Autowired 
  5.     UserService userService; 
  6.     /** 
  7.      * 一條一條插入 
  8.      */ 
  9.     @GetMapping("/user2"
  10.     public void user2() { 
  11.         List<User> users = new ArrayList<>(); 
  12.         for (int i = 0; i < 50000; i++) { 
  13.             User u = new User(); 
  14.             u.setAddress("廣州:" + i); 
  15.             u.setUsername("張三:" + i); 
  16.             u.setPassword("123:" + i); 
  17.             users.add(u); 
  18.         } 
  19.         userService.addUserOneByOne(users); 
  20.     } 

寫個簡單的單元測試:

  1. /** 
  2.  *  
  3.  * 單元測試加事務的目的是為了插入之后自動回滾,避免影響下一次測試結果 
  4.  * 一條一條插入 
  5.  */ 
  6. @Test 
  7. @Transactional 
  8. void addUserOneByOne() { 
  9.     List<User> users = new ArrayList<>(); 
  10.     for (int i = 0; i < 50000; i++) { 
  11.         User u = new User(); 
  12.         u.setAddress("廣州:" + i); 
  13.         u.setUsername("張三:" + i); 
  14.         u.setPassword("123:" + i); 
  15.         users.add(u); 
  16.     } 
  17.     userService.addUserOneByOne(users); 

可以看到,耗時 901 毫秒,5w 條數據插入不到 1 秒。

2.2 方案二測試

方案二是生成一條 SQL,然后插入。

mapper 如下:

  1. @Mapper 
  2. public interface UserMapper { 
  3.     void addByOneSQL(@Param("users") List<User> users); 

對應的 SQL 如下:

  1. <insert id="addByOneSQL"
  2.     insert into user (username,address,passwordvalues 
  3.     <foreach collection="users" item="user" separator=","
  4.         (#{user.username},#{user.address},#{user.password}) 
  5.     </foreach> 
  6. </insert

service 如下:

  1. @Service 
  2. public class UserService extends ServiceImpl<UserMapper, User> implements IUserService { 
  3.     private static final Logger logger = LoggerFactory.getLogger(UserService.class); 
  4.     @Autowired 
  5.     UserMapper userMapper; 
  6.     @Autowired 
  7.     SqlSessionFactory sqlSessionFactory; 
  8.     @Transactional(rollbackFor = Exception.class) 
  9.     public void addByOneSQL(List<User> users) { 
  10.         long startTime = System.currentTimeMillis(); 
  11.         userMapper.addByOneSQL(users); 
  12.         long endTime = System.currentTimeMillis(); 
  13.         logger.info("合并成一條 SQL 插入耗費時間 {}", (endTime - startTime)); 
  14.     } 

然后在單元測試中調一下這個方法:

  1. /** 
  2.  * 合并成一條 SQL 插入 
  3.  */ 
  4. @Test 
  5. @Transactional 
  6. void addByOneSQL() { 
  7.     List<User> users = new ArrayList<>(); 
  8.     for (int i = 0; i < 50000; i++) { 
  9.         User u = new User(); 
  10.         u.setAddress("廣州:" + i); 
  11.         u.setUsername("張三:" + i); 
  12.         u.setPassword("123:" + i); 
  13.         users.add(u); 
  14.     } 
  15.     userService.addByOneSQL(users); 

可以看到插入 5 萬條數據耗時 1805 毫秒。

可以看到,生成一條 SQL 的執行效率還是要差一點。

另外還需要注意,第二種方案還有一個問題,就是當數據量大的時候,生成的 SQL 將特別的長,MySQL 可能一次性處理不了這么大的 SQL,這個時候就需要修改 MySQL 的配置或者對待插入的數據進行分片處理了,這些操作又會導致插入時間更長。

2.3 對比分析

很明顯,方案一更具優勢。當批量插入十萬、二十萬數據的時候,方案一的優勢會更加明顯(方案二則需要修改 MySQL 配置或者對待插入數據進行分片)。

3. MP 怎么做的?

小伙伴們知道,其實 MyBatis Plus 里邊也有一個批量插入的方法 saveBatch,我們來看看它的實現源碼:

  1. @Transactional(rollbackFor = Exception.class) 
  2. @Override 
  3. public boolean saveBatch(Collection<T> entityList, int batchSize) { 
  4.     String sqlStatement = getSqlStatement(SqlMethod.INSERT_ONE); 
  5.     return executeBatch(entityList, batchSize, (sqlSession, entity) -> sqlSession.insert(sqlStatement, entity)); 

可以看到,這里拿到的 sqlStatement 就是一個 INSERT_ONE,即一條一條插入。

再來看 executeBatch 方法,如下:

  1. public static <E> boolean executeBatch(Class<?> entityClass, Log log, Collection<E> list, int batchSize, BiConsumer<SqlSession, E> consumer) { 
  2.     Assert.isFalse(batchSize < 1, "batchSize must not be less than one"); 
  3.     return !CollectionUtils.isEmpty(list) && executeBatch(entityClass, log, sqlSession -> { 
  4.         int size = list.size(); 
  5.         int i = 1; 
  6.         for (E element : list) { 
  7.             consumer.accept(sqlSession, element); 
  8.             if ((i % batchSize == 0) || i == size) { 
  9.                 sqlSession.flushStatements(); 
  10.             } 
  11.             i++; 
  12.         } 
  13.     }); 

這里注意 return 中的第三個參數,是一個 lambda 表達式,這也是 MP 中批量插入的核心邏輯,可以看到,MP 先對數據進行分片(默認分片大小是 1000),分片完成之后,也是一條一條的插入。繼續查看 executeBatch 方法,就會發現這里的 sqlSession 其實也是一個批處理的 sqlSession,并非普通的 sqlSession。

綜上,MP 中的批量插入方案跟我們 2.1 小節的批量插入思路其實是一樣的。

4. 小結

好啦,經過上面的分析,現在小伙伴們知道了批量插入該怎么做了吧?

本文轉載自微信公眾號「江南一點雨」,可以通過以下二維碼關注。轉載本文請聯系江南一點雨公眾號。

 

責任編輯:武曉燕 來源: 江南一點雨
相關推薦

2022-10-27 21:32:28

數據互聯網數據中心

2024-03-07 08:08:51

SQL優化數據

2025-09-01 01:45:00

數據虛擬列表

2019-07-16 08:51:03

熱搜新浪微博數據

2022-09-23 09:44:17

MyBatisforeach

2024-04-15 08:30:53

MySQLORM框架

2022-06-17 10:15:35

面試API前端

2021-10-12 10:22:33

數據庫架構技術

2023-10-19 15:13:25

2011-03-31 11:24:14

數據搜索本文字段

2019-11-28 18:54:50

數據庫黑客軟件

2019-07-02 10:22:15

TCP流量數據

2018-08-27 07:01:33

數據分析數據可視化租房

2017-06-05 14:53:05

2023-09-27 22:44:18

數據遷移數據庫

2022-06-20 08:01:56

Kafka服務器數據量

2022-04-28 20:12:44

二分法搜索算法

2024-05-31 11:37:20

2025-08-05 02:22:00

數據分析SQL工具人

2022-07-06 11:30:57

數據分析預測模型
點贊
收藏

51CTO技術棧公眾號

日韩欧美一区二区在线视频| av高清不卡在线| 一区二区中文字幕| 天天看片天天操| 黄色的视频在线观看| av中文字幕不卡| 国产精品亚洲网站| 亚洲国产精品成人无久久精品| 午夜欧洲一区| 91精品久久久久久久99蜜桃 | 欧美日韩国产高清电影| 欧美一区二区性放荡片| 狠狠97人人婷婷五月| 黄色免费网站在线| 久久久www成人免费无遮挡大片 | aa视频在线免费观看| 亚洲资源av| 久久国产精品影片| 国产精品天天干| 国产欧美自拍一区| 91精品国产综合久久久久久 | 精品亚洲国产视频| 青青草精品在线| 成人做爰免费视频免费看| 亚洲福利视频一区| 视色,视色影院,视色影库,视色网 日韩精品福利片午夜免费观看 | 在线播放日韩导航| 亚洲欧美日韩人成在线播放| 国产欧美精品va在线观看| 在线观看免费国产视频| 中文一区一区三区免费在线观看| 国产亚洲激情在线| 一级做a爰片毛片| 91欧美极品| 91精品国产一区二区三区| 午夜dv内射一区二区| 6699嫩草久久久精品影院| 最新久久zyz资源站| 亚洲成人av动漫| 青青草视频免费在线观看| 国产成人在线看| 亚洲一区二区三区在线视频| 国产精品久久影视| 免费观看在线色综合| 5566成人精品视频免费| 日本在线观看视频网站| 狠狠色丁香久久综合频道| 久久精品国产精品| 亚洲 欧美 变态 另类 综合| 成人激情开心网| 中文字幕亚洲专区| 日本成人精品视频| 欧美疯狂party性派对| 国产一区二区成人| 亚洲色图日韩精品| 欧美电影《轻佻寡妇》| 久久九九亚洲综合| 激情四射综合网| 亚洲午夜激情在线| 91精品国产91久久久久久不卡| 你懂的国产视频| 一区二区www| 日韩欧美高清在线播放| 一区二区三区视频免费| 精品手机在线视频| 亚洲国产不卡| 久久久久久久成人| 午夜精品三级久久久有码| 欧美亚洲免费| 国产精品亚洲片夜色在线| 国产免费一区二区三区最新不卡| 久久99热这里只有精品| 亚洲free性xxxx护士白浆| www.久久伊人| 91原创在线视频| 色就是色欧美| 人妖欧美1区| 欧美性猛交xxx| 美女在线视频一区二区| 免费欧美网站| 亚洲国产另类 国产精品国产免费| 欧美丰满少妇人妻精品| 色爱综合网欧美| 久久999免费视频| youjizz在线视频| 精品写真视频在线观看| 国产99在线免费| 九色在线观看| 一区二区三区四区高清精品免费观看| 又大又硬又爽免费视频| 日韩和的一区二在线| 欧美一卡2卡3卡4卡| 少妇饥渴放荡91麻豆| 国产精品久久久久久| 久久久影视精品| 中文在线观看免费高清| 国产aⅴ综合色| 午夜老司机精品| gogo高清午夜人体在线| 欧美性猛交xxxxxxxx| 国产a级片视频| 日韩精品四区| 777精品视频| 99国产精品欲| www.成人网.com| 中文字幕中文字幕在线中心一区| 玖玖在线播放| 欧美一级在线免费| 少妇人妻好深好紧精品无码| 黄色av一区| 国产免费一区二区三区在线观看| 神马午夜精品95| 亚洲欧洲美洲综合色网| 成人免费在线小视频| 欧美专区视频| 中国日韩欧美久久久久久久久| 国产真实乱偷精品视频| 精品制服美女久久| 欧美精品尤物在线| 爱情岛亚洲播放路线| 51精品秘密在线观看| 成人黄色a级片| 午夜在线精品偷拍| 国产v亚洲v天堂无码| 久久亚洲天堂| 欧美日韩国产一级片| 国产av自拍一区| 夜夜夜久久久| 国产精品区二区三区日本| 在线视频观看国产| 8v天堂国产在线一区二区| 亚洲色图日韩精品| 美女脱光内衣内裤视频久久影院| 免费在线成人av电影| 日本黄色免费在线| 日韩精品视频三区| 欧美激情亚洲综合| 99视频超级精品| 国产人妻777人伦精品hd| 午夜视频一区二区在线观看| 欧美成人精品三级在线观看| 国产乱淫av片免费| 自拍偷在线精品自拍偷无码专区 | 少妇影院在线观看| 国产麻豆精品视频| 中文字幕一区二区三区最新| japansex久久高清精品| 久久伊人免费视频| 国产美女明星三级做爰| 亚洲精品视频免费看| 中文字幕在线播放一区二区| 午夜久久福利| 国产精品免费一区二区三区四区 | 国产农村妇女精品一区二区| 久久久一本精品99久久精品66| 在线天堂资源| 一区二区三区四区精品| 正在播放木下凛凛xv99| 国产精品福利电影一区二区三区四区| 亚洲a级黄色片| 在线精品小视频| 国产超碰91| 中文在线资源| 在线精品国产成人综合| 国产精品无码免费播放| 亚洲小说欧美激情另类| 国产精品无码永久免费不卡| 日韩精品91亚洲二区在线观看| 亚洲欧洲一区二区在线观看| 日韩在线成人| 欧美亚洲激情在线| 国产二区在线播放| 欧美一个色资源| 国产成人精品一区二三区| 国产欧美日韩亚州综合| 91大神免费观看| 日韩亚洲在线| 视频一区二区在线| 91精品国产乱码久久久竹菊| 欧美亚洲视频一区二区| 天天影视久久综合| 精品国产髙清在线看国产毛片| 五月婷婷色丁香| 中文字幕在线不卡| 亚洲蜜桃精久久久久久久久久久久 | 久久这里只有精品99| 神马久久久久久久久久| 欧美日韩国产高清一区| 国产奶水涨喷在线播放| 日本一区二区在线不卡| 人妻 丝袜美腿 中文字幕| 日韩专区在线视频| 白白操在线视频| 一区二区美女| 成人国产一区二区| 成人精品高清在线视频| 国内精品小视频在线观看| 在线观看av黄网站永久| 亚洲黄色www网站| 国产又粗又长又大视频| 欧美日韩亚洲系列| 国产高清在线免费观看| 久久精品欧美一区二区三区麻豆| 免费在线观看日韩av| 日本午夜精品视频在线观看| 国产a级片网站| 国产高清欧美| 日本在线播放一区| 菁菁伊人国产精品| 亚洲在线一区二区| 国产福利一区二区三区在线播放| 69av视频在线播放| 少妇视频在线| www.亚洲天堂| 成人动漫在线免费观看| 日韩精品中文字幕在线观看| 亚洲精品久久久久久久久久| 欧美日韩国产大片| 人人妻人人爽人人澡人人精品 | 国产av麻豆mag剧集| 性欧美69xoxoxoxo| 亚洲精品一卡二卡三卡四卡| 国产成人精品免费视| 久久久久久久久久码影片| 视频一区国产| 一区二区三区在线视频免费| 草草久久久无码国产专区| 欧美高清一区| 樱空桃在线播放| 成人高清电影网站| 日产中文字幕在线精品一区 | 国产乱码精品| 三级在线免费观看| 在线观看免费一区二区| 99精品一级欧美片免费播放| 99国产**精品****| 亚洲一卡二卡区| 日韩欧美一区二区三区免费看| 欧美一区二区三区成人久久片| 色先锋久久影院av| 久久精品ww人人做人人爽| 国产精品中文字幕制服诱惑| 国产精品一国产精品最新章节| 亚洲亚洲一区二区三区| 亚洲精品女av网站| 日韩视频1区| 成人黄色片视频网站| 91麻豆精品激情在线观看最新| 成人av资源网| 奇米影视777在线欧美电影观看 | 久久综合99| 国产系列第一页| 亚洲五月综合| 欧美中日韩在线| 亚洲国产黄色| 99999精品视频| 日韩精品五月天| www.超碰97.com| 国产美女在线观看一区| 精人妻一区二区三区| 成人晚上爱看视频| 99久久久久久久久久| 欧美国产精品专区| 日本精品在线免费观看| 亚洲一本大道在线| 久久久蜜桃一区二区| 欧美日韩亚洲综合在线 | 欧美精品在线观看91| 欧美精品videossex少妇| 国模精品系列视频| 久久99久久99精品免观看软件| 国产精品午夜一区二区欲梦| 99tv成人影院| 精品国产综合久久| 成人中文视频| 日本人妻伦在线中文字幕| 中文亚洲欧美| 激情五月婷婷基地| 成人高清免费观看| 亚洲一级黄色录像| 亚洲综合在线视频| 亚洲大尺度在线观看| 91精品国产黑色紧身裤美女| 天天在线女人的天堂视频| 中文字幕在线国产精品| 免费在线观看的电影网站| 日韩美女视频免费看| 欧美影院在线| 日韩欧美亚洲日产国| 欧美涩涩视频| 五月婷婷激情久久| av在线一区二区| 国产精品国产三级国产传播| 欧美日韩激情视频| 国产哺乳奶水91在线播放| 亚洲另类激情图| 色呦呦在线观看视频| 国产福利视频一区二区| 在线观看视频一区二区三区| 五月天亚洲综合小说网| 亚洲黄色毛片| 色婷婷一区二区三区在线观看| 91香蕉视频在线| 欧美黑人猛猛猛| 欧美日韩亚洲高清一区二区| 手机看片国产1024| 操91在线视频| 国产亚洲人成a在线v网站 | 精品久久久久久中文字幕大豆网| 亚洲中文字幕一区二区| 亚洲男人天堂九九视频| 七七成人影院| 91麻豆国产语对白在线观看| 精品日韩欧美一区| 国模无码视频一区二区三区| 国产成人免费av在线| 女同久久另类69精品国产| 色综合天天视频在线观看| 丰满人妻一区二区三区四区53| 日韩中文字幕在线看| 国模一区二区| 欧美一区二区三区成人久久片| 国产精品女主播一区二区三区| 永久看看免费大片| 成人欧美一区二区三区白人| 一级特黄aaa大片在线观看| 亚洲色图美腿丝袜| 625成人欧美午夜电影| 精品国产乱码久久久久久蜜柚| 激情成人亚洲| 日本女人性视频| 亚洲精品亚洲人成人网| 国产乱淫片视频| 久久影视电视剧免费网站清宫辞电视| 欧美日韩国产网站| 日韩精品资源| 日韩福利视频导航| 久久丫精品忘忧草西安产品| 色狠狠av一区二区三区| 久久久资源网| 国产精品扒开腿做| 精品国产一区二区三区噜噜噜| 日韩无套无码精品| 国产日产欧美一区二区视频| 美女黄页在线观看| 丝袜亚洲另类欧美重口| 欧美美女被草| 一道本在线观看视频| 国产精品69久久久久水密桃| 欧美精品色哟哟| 精品国产亚洲在线| 国内精彩免费自拍视频在线观看网址| 好吊色欧美一区二区三区视频| 亚洲伦伦在线| 少妇久久久久久久久久| 欧美视频日韩视频在线观看| 日韩毛片久久久| 91成人伦理在线电影| 激情一区二区| 粉嫩av蜜桃av蜜臀av| 在线观看日产精品| 国产剧情在线| 精品国产aⅴ麻豆| 久久精品一区二区国产| 日韩欧美在线视频播放| 日韩欧美国产午夜精品| 精精国产xxxx视频在线播放| 欧美美乳视频网站在线观看| 美女看a上一区| 久久国产露脸精品国产| 精品无人国产偷自产在线| 91在线亚洲| 热久久最新地址| av成人动漫在线观看| 成人黄色片在线观看| 九九热最新视频//这里只有精品| 欧美美女在线直播| 欧美成人黄色网址| 亚洲永久精品国产| 色哟哟在线观看| 91精品视频免费看| 国产亚洲成人一区| 91狠狠综合久久久| 日韩av在线免费播放| 午夜不卡一区| 欧美日韩亚洲一| 亚洲色图视频网| 久久精品蜜桃| 99在线观看视频网站| 日本视频免费一区| 精品肉丝脚一区二区三区| 在线播放国产精品| 盗摄系列偷拍视频精品tp| 亚洲福利精品视频| 精品久久久久久中文字幕一区奶水| av在线天堂播放| 久久99精品久久久久久三级| 国产一区二区剧情av在线| www.国产毛片| 久久久久久久久久久av|