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

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

【springboot整合多数据源】

發布時間:2023/12/20 编程问答 32 豆豆
生活随笔 收集整理的這篇文章主要介紹了 【springboot整合多数据源】 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

springboot整合多數據源

  • 配置多數據
    • application.yaml
    • 動態路由數據源
    • 數據源上下文管理
    • 數據源切面
    • MybatisPlusConfig配置
    • 自定義方法注入器
  • 擴展配置,幫助我們批量更新、新增等操作
    • RootMapper
    • InsertBatchMethod
    • UpdateBatchMethod

配置多數據

application.yaml

spring:application:name: erp9-synaop:proxy-target-class: trueauto: truemain:allow-bean-definition-overriding: truedatasource:erp9:driver-class-name: com.mysql.cj.jdbc.Driverurl: jdbc:mysql://192.168.80.211:3306/1231?useUnicode=true&characterEncoding=utf8&useSSL=false&serverTimezone=GMT%2b8&allowPublicKeyRetrieval=trueusername: b1b_goodspassword: asdadinitialSize: 10minIdle: 10maxActive: 80type: com.alibaba.druid.pool.DruidDataSourcerate:driver-class-name: com.microsoft.sqlserver.jdbc.SQLServerDriverurl: jdbc:sqlserver://101.200.55.149:6522;Databasename=sacsacusername: ascacpassword: 121sadsinitialSize: 5minIdle: 5maxActive: 40type: com.alibaba.druid.pool.DruidDataSource # 日志配置 mybatis-plus:mapper-locations: classpath:xml/**/*Mapper.xmltypeAliasesPackage: com.yuanda.erp9.syn.entityconfiguration:map-underscore-to-camel-case: true# console輸出日志log-impl: org.apache.ibatis.logging.stdout.StdOutImpl

動態路由數據源

package com.yuanda.erp9.syn.config;import lombok.extern.slf4j.Slf4j; import org.springframework.core.annotation.Order; import org.springframework.jdbc.datasource.lookup.AbstractRoutingDataSource;/*** 動態路由數據源*/ @Order(1) @Slf4j public class DynamicDataSource extends AbstractRoutingDataSource {@Overrideprotected Object determineCurrentLookupKey() {String datasource = DynamicDataSourceContextHolder.getDataSourceKey();super.setDefaultTargetDataSource(datasource);log.debug("使用數據源 {}", datasource);return datasource;} }

數據源上下文管理

package com.yuanda.erp9.syn.config;import com.yuanda.erp9.syn.contant.DatabaseGlobal; import java.util.ArrayList; import java.util.Collection; import java.util.List;/*** @ClassName DynamicDataSourceContextHolder* @Description 數據上下文管理* @Date 2022/12/15* @Author myq*/ public class DynamicDataSourceContextHolder {/*** 實際上就是開啟多個線程,每個線程進行初始化一個數據源*/private static final ThreadLocal<String> CONTEXT_HOLDER = new ThreadLocal<String>() {/*** 將 master 數據源的 key作為默認數據源的 key*/@Overrideprotected String initialValue() {return DatabaseGlobal.erp9;}};/*** 數據源的 key集合,用于切換時判斷數據源是否存在*/public static List<Object> dataSourceKeys = new ArrayList<Object>();/*** 切換數據源** @param key*/public static void setDataSourceKey(String key) {CONTEXT_HOLDER.set(key);}/*** 獲取數據源** @return*/public static String getDataSourceKey() {return CONTEXT_HOLDER.get();}/*** 重置數據源*/public static void clearDataSourceKey() {CONTEXT_HOLDER.remove();}/*** 判斷是否包含數據源** @param key 數據源key* @return*/public static boolean containDataSourceKey(String key) {return dataSourceKeys.contains(key);}/*** 添加數據源keys** @param keys* @return*/public static boolean addDataSourceKeys(Collection<? extends Object> keys) {return dataSourceKeys.addAll(keys);} }

數據源切面

package com.yuanda.erp9.syn.config;import com.yuanda.erp9.syn.contant.DatabaseGlobal; import lombok.extern.slf4j.Slf4j; import org.aspectj.lang.annotation.Aspect; import org.aspectj.lang.annotation.Before; import org.aspectj.lang.annotation.Pointcut; import org.springframework.core.annotation.Order; import org.springframework.stereotype.Component;@Component @Order(value = -100) @Aspect @Slf4j public class DataSourceAspect {@Pointcut("execution( * com.yuanda.erp9.syn.service.erp9.impl..*.*(..))")private void erp9Aspect() {}@Pointcut("execution(* com.yuanda.erp9.syn.service.rate.impl..*.*(..))")private void rateAspect() {}@Before("erp9Aspect()")public void cyz() {log.debug("切換到{} 數據源...", DatabaseGlobal.erp9);DynamicDataSourceContextHolder.setDataSourceKey(DatabaseGlobal.erp9);}@Before("rateAspect()")public void pveStandard() {log.debug("切換到{} 數據源...", DatabaseGlobal.rate);DynamicDataSourceContextHolder.setDataSourceKey(DatabaseGlobal.rate);} }

MybatisPlusConfig配置

package com.yuanda.erp9.syn.config;import com.alibaba.druid.spring.boot.autoconfigure.DruidDataSourceBuilder; import com.alibaba.druid.wall.WallConfig; import com.baomidou.mybatisplus.core.MybatisConfiguration; import com.baomidou.mybatisplus.core.config.GlobalConfig; import com.baomidou.mybatisplus.extension.spring.MybatisSqlSessionFactoryBean; import com.yuanda.erp9.syn.contant.DatabaseGlobal; import com.yuanda.erp9.syn.core.CustomizedSqlInjector; import org.apache.ibatis.session.SqlSessionFactory; import org.apache.ibatis.type.JdbcType; import org.mybatis.spring.annotation.MapperScan; import org.springframework.beans.factory.annotation.Qualifier; import org.springframework.boot.context.properties.ConfigurationProperties; import org.springframework.context.annotation.Bean; import org.springframework.context.annotation.Configuration; import org.springframework.context.annotation.Primary; import org.springframework.core.io.support.PathMatchingResourcePatternResolver; import org.springframework.transaction.annotation.EnableTransactionManagement; import javax.sql.DataSource; import java.util.HashMap; import java.util.Map;/*** @ClassName MybatisPlusConfig* @Description 配置文件-自定義sql注入器* @Date 2022/11/16* @Author myq*/ @MapperScan({"com.yuanda.erp9.syn.mapper.erp9", "com.yuanda.erp9.syn.mapper.rate"}) @Configuration @EnableTransactionManagement @ConfigurationProperties(prefix = "mybatis-plus") public class MybatisPlusConfig {/*** 可以寫死 可以沖配置文件中讀取*/private Class logImpl;static {System.setProperty("druid.mysql.usePingMethod","false");}@Beanpublic CustomizedSqlInjector customizedSqlInjector() {return new CustomizedSqlInjector();}/*** 這個bean可以幫助我們一次執行多條dml語句,沒有哦這個配置會出現執行多次sql會出現報錯。*/@Beanpublic WallConfig wallConfig() {WallConfig config = new WallConfig();config.setMultiStatementAllow(true);//允許一次執行多條語句config.setNoneBaseStatementAllow(true);//允許非基本語句的其他語句return config;}@Bean(name = DatabaseGlobal.erp9)@ConfigurationProperties(prefix = "spring.datasource.erp9")public DataSource erp9() {return DruidDataSourceBuilder.create().build();}@Bean(name = DatabaseGlobal.rate)@ConfigurationProperties(prefix = "spring.datasource.rate")public DataSource rate() {return DruidDataSourceBuilder.create().build();}/*** 動態數據源配置** @return*/@Bean@Primarypublic DataSource multipleDataSource(@Qualifier(DatabaseGlobal.erp9) DataSource erp9DataSource,@Qualifier(DatabaseGlobal.rate) DataSource rateDataSource) {DynamicDataSource dynamicDataSource = new DynamicDataSource();Map<Object, Object> targetDataSources = new HashMap<Object, Object>();targetDataSources.put(DatabaseGlobal.erp9, erp9DataSource);targetDataSources.put(DatabaseGlobal.rate, rateDataSource);dynamicDataSource.setTargetDataSources(targetDataSources);// 程序默認數據源,這個要根據程序調用數據源頻次,經常把常調用的數據源作為默認dynamicDataSource.setDefaultTargetDataSource(erp9DataSource);return dynamicDataSource;}@Bean("sqlSessionFactory")public SqlSessionFactory sqlSessionFactory(@Qualifier(DatabaseGlobal.erp9) DataSource erp9DataSource,@Qualifier(DatabaseGlobal.rate) DataSource rateDataSource) throws Exception {MybatisSqlSessionFactoryBean sqlSessionFactory = new MybatisSqlSessionFactoryBean();// 多數據源必須設置sqlSessionFactory.setMapperLocations(new PathMatchingResourcePatternResolver().getResources("classpath:xml/**/*Mapper.xml"));sqlSessionFactory.setDataSource(multipleDataSource(erp9DataSource, rateDataSource));MybatisConfiguration configuration = new MybatisConfiguration();configuration.setJdbcTypeForNull(JdbcType.NULL);configuration.setMapUnderscoreToCamelCase(true);configuration.setCacheEnabled(false);configuration.setLogImpl(logImpl);sqlSessionFactory.setGlobalConfig(globalConfiguration());sqlSessionFactory.setConfiguration(configuration);return sqlSessionFactory.getObject();}@Beanpublic GlobalConfig globalConfiguration() {GlobalConfig conf = new GlobalConfig();// 自定義的注入需要在這里進行配置conf.setSqlInjector(customizedSqlInjector());return conf;}}

自定義方法注入器

package com.yuanda.erp9.syn.core;import com.baomidou.mybatisplus.core.injector.AbstractMethod; import com.baomidou.mybatisplus.core.injector.DefaultSqlInjector; import org.springframework.stereotype.Component;import java.util.List;/*** 自定義方法SQL注入器*/ @Component public class CustomizedSqlInjector extends DefaultSqlInjector {/*** 如果只需增加方法,保留mybatis plus自帶方法,* 可以先獲取super.getMethodList(),再添加add*/@Overridepublic List<AbstractMethod> getMethodList(Class<?> mapperClass) {List<AbstractMethod> methodList = super.getMethodList(mapperClass);## 這倆是mybatisPlus實現的批量更新操作 也可以注釋掉methodList.add(new InsertBatchMethod());methodList.add(new UpdateBatchMethod());return methodList;} }

擴展配置,幫助我們批量更新、新增等操作

RootMapper

package com.yuanda.erp9.syn.core;import com.baomidou.mybatisplus.core.mapper.BaseMapper; import com.baomidou.mybatisplus.core.toolkit.Constants; import org.apache.ibatis.annotations.Param;import java.util.List;/*** 根Mapper,給表Mapper繼承用的,可以自定義通用方法* {@link com.baomidou.mybatisplus.core.mapper.BaseMapper}* {@link com.baomidou.mybatisplus.extension.service.IService}* {@link com.baomidou.mybatisplus.extension.service.impl.ServiceImpl}*/ public interface RootMapper<T> extends BaseMapper<T> {/*** 自定義批量插入* 如果要自動填充,@Param(xx) xx參數名必須是 list/collection/array 3個的其中之一*/int insertBatch(@Param("list") List<T> list);/*** 自定義批量更新,條件為主鍵* 如果要自動填充,@Param(xx) xx參數名必須是 list/collection/array 3個的其中之一*/int updateBatch(@Param("list") List<T> list);}

InsertBatchMethod

package com.yuanda.erp9.syn.core;import com.baomidou.mybatisplus.core.injector.AbstractMethod; import com.baomidou.mybatisplus.core.metadata.TableInfo; import lombok.extern.slf4j.Slf4j; import org.apache.ibatis.executor.keygen.NoKeyGenerator; import org.apache.ibatis.mapping.MappedStatement; import org.apache.ibatis.mapping.SqlSource;/*** 批量插入方法實現*/ @Slf4j public class InsertBatchMethod extends AbstractMethod {/*** insertBatch into user(id, name, age) values (1, "a", 17), (2, "b", 18);<script>insertBatch into user(id, name, age) values<foreach collection="list" item="item" index="index" open="(" separator="),(" close=")">#{item.id}, #{item.name}, #{item.age}</foreach></script>*/@Overridepublic MappedStatement injectMappedStatement(Class<?> mapperClass, Class<?> modelClass, TableInfo tableInfo) {final String sql = "<script>insert into %s %s values %s</script>";final String fieldSql = prepareFieldSql(tableInfo);final String valueSql = prepareValuesSql(tableInfo);final String sqlResult = String.format(sql, tableInfo.getTableName(), fieldSql, valueSql);log.debug("sqlResult----->{}", sqlResult);SqlSource sqlSource = languageDriver.createSqlSource(configuration, sqlResult, modelClass);// 第三個參數必須和RootMapper的自定義方法名一致return this.addInsertMappedStatement(mapperClass, modelClass, "insertBatch", sqlSource, new NoKeyGenerator(), null, null);}private String prepareFieldSql(TableInfo tableInfo) {StringBuilder fieldSql = new StringBuilder();fieldSql.append(tableInfo.getKeyColumn()).append(",");tableInfo.getFieldList().forEach(x -> {fieldSql.append(x.getColumn()).append(",");});fieldSql.delete(fieldSql.length() - 1, fieldSql.length());fieldSql.insert(0, "(");fieldSql.append(")");return fieldSql.toString();}private String prepareValuesSql(TableInfo tableInfo) {final StringBuilder valueSql = new StringBuilder();valueSql.append("<foreach collection=\"list\" item=\"item\" index=\"index\" open=\"(\" separator=\"),(\" close=\")\">");valueSql.append("#{item.").append(tableInfo.getKeyProperty()).append("},");tableInfo.getFieldList().forEach(x -> valueSql.append("#{item.").append(x.getProperty()).append("},"));valueSql.delete(valueSql.length() - 1, valueSql.length());valueSql.append("</foreach>");return valueSql.toString();} }

UpdateBatchMethod

package com.yuanda.erp9.syn.core;import com.baomidou.mybatisplus.core.injector.AbstractMethod; import com.baomidou.mybatisplus.core.metadata.TableInfo; import lombok.extern.slf4j.Slf4j; import org.apache.ibatis.mapping.MappedStatement; import org.apache.ibatis.mapping.SqlSource;/*** 批量更新方法實現,條件為主鍵,選擇性更新*/ @Slf4j public class UpdateBatchMethod extends AbstractMethod {/*** update user set name = "a", age = 17 where id = 1;* update user set name = "b", age = 18 where id = 2;<script><foreach collection="list" item="item" separator=";">update user<set><if test="item.name != null and item.name != ''">name = #{item.name,jdbcType=VARCHAR},</if><if test="item.age != null">age = #{item.age,jdbcType=INTEGER},</if></set>where id = #{item.id,jdbcType=INTEGER}</foreach></script>*/@Overridepublic MappedStatement injectMappedStatement(Class<?> mapperClass, Class<?> modelClass, TableInfo tableInfo) {String sql = "<script>\n<foreach collection=\"list\" item=\"item\" separator=\";\">\nupdate %s %s where %s=#{%s} %s\n</foreach>\n</script>";String additional = tableInfo.isWithVersion() ? tableInfo.getVersionFieldInfo().getVersionOli("item", "item.") : "" + tableInfo.getLogicDeleteSql(true, true);String setSql = sqlSet(tableInfo.isWithLogicDelete(), false, tableInfo, false, "item", "item.");String sqlResult = String.format(sql, tableInfo.getTableName(), setSql, tableInfo.getKeyColumn(), "item." + tableInfo.getKeyProperty(), additional);log.debug("sqlResult----->{}", sqlResult);SqlSource sqlSource = languageDriver.createSqlSource(configuration, sqlResult, modelClass);// 第三個參數必須和RootMapper的自定義方法名一致return this.addUpdateMappedStatement(mapperClass, modelClass, "updateBatch", sqlSource);}}

總結

以上是生活随笔為你收集整理的【springboot整合多数据源】的全部內容,希望文章能夠幫你解決所遇到的問題。

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

999视频网 | 国产精品久久一区二区三区不卡 | 久久精品视频在线播放 | 亚洲精品小视频在线观看 | 精品国产乱码久久久久久1区2匹 | 久久久受www免费人成 | aaa免费毛片| 91在线国产观看 | 亚洲精品一区二区三区在线观看 | 欧美日韩国产精品爽爽 | 欧美在线视频a | 成人免费观看完整版电影 | 又黄又刺激视频 | 麻豆视频大全 | 尤物九九久久国产精品的分类 | 久久精品视频日本 | 六月丁香色婷婷 | 久久女教师 | 9ⅰ精品久久久久久久久中文字幕 | 国产一区高清在线 | 国产婷婷视频在线 | 亚洲一二三在线 | 91免费的视频在线播放 | 麻豆精品在线 | 久久综合婷婷国产二区高清 | 日韩成人高清在线 | 高清不卡一区二区三区 | 日韩天天操| 四虎小视频 | 久久精品艹 | 欧美精品久久久久久 | 婷婷久操 | 日韩天天干 | 国内精品国产三级国产aⅴ久 | 久久99久久99精品 | 狠狠色丁香 | 成人福利av| 九九视频网 | 久久成人一区 | 天天翘av| 国产精品久久久久久久久久久杏吧 | 久久综合久久综合久久 | 国产网站av | 日韩在线观看视频免费 | 日韩午夜网站 | 国内精品免费 | 片网址| 美女福利视频一区二区 | 91精品久久香蕉国产线看观看 | 少妇bbbb | 99久久er热在这里只有精品15 | 免费a v在线 | 九九久 | 97在线影视 | 麻花豆传媒一二三产区 | 亚洲 综合 专区 | 91视频免费网址 | 91中文在线视频 | 色操插 | 公开超碰在线 | 国产亚洲精品福利 | 手机看片1042 | 成人免费视频a | 在线观看你懂的网站 | 三级黄色网址 | 人人爽人人爽人人爽 | 五月开心激情网 | 99激情网 | 亚洲精品美女免费 | 天天干天天插伊人网 | 99九九热只有国产精品 | 国产精品久久久久久一区二区 | 五月天亚洲激情 | 日韩av影视在线观看 | 在线视频在线观看 | 亚洲精品免费在线播放 | 在线免费观看一区二区三区 | 国产专区免费 | 欧美一级日韩免费不卡 | 久久精品中文字幕少妇 | 亚洲精品免费视频 | 久久久久久久久亚洲精品 | 久久99网 | 国产精品手机播放 | 中文字幕在线观看2018 | 欧美日韩精品在线免费观看 | 五月天婷婷在线视频 | 美女视频黄免费的 | 狠狠久久婷婷 | 久久久精品视频网站 | 久久久久女人精品毛片 | 国产高清精品在线观看 | 日韩小视频 | 69av网| 国产黄色片网站 | 天天色影院 | 狠狠色丁香婷婷综合最新地址 | 超级碰碰碰视频 | 91夜夜夜| 激情婷婷丁香 | 五月天综合色激情 | 国产成人精品免费在线观看 | 国产黄色精品在线观看 | 久久久久久麻豆 | 天天草视频 | 一二三区在线 | 玖草在线观看 | 99精品视频免费观看 | 手机色在线 | 中文字幕在线影视资源 | 国产高清免费在线播放 | av成人免费在线看 | 91在线免费看片 | 亚洲一区二区三区91 | 国产一区观看 | 天天躁天天躁天天躁婷 | 亚洲精品视频一二三 | 黄色网中文字幕 | 国产高清一级 | 麻豆 videos | 国产精品美女久久久久久 | 超级碰碰碰视频 | 97超碰在| 国产一区91| 91香蕉视频好色先生 | 久久综合射| 欧美一级特黄高清视频 | 日韩激情片在线观看 | 日韩乱色精品一区二区 | 国产日韩在线播放 | av网址最新 | 久久中文字幕导航 | 亚洲japanese制服美女 | av亚洲产国偷v产偷v自拍小说 | 色婷婷综合在线 | 欧美日韩久 | 在线观看的av网站 | 午夜精选视频 | 99夜色| 久久er99热精品一区二区三区 | 成人蜜桃网 | 国产精品第72页 | 国产精品入口麻豆 | 狠狠综合 | 在线观看91 | 久草在线免费电影 | 国产三级国产精品国产专区50 | 在线观看国产永久免费视频 | 免费色网站 | 久久a热6 | 国产区av在线 | 国产xvideos免费视频播放 | 国产一区成人在线 | 99久久毛片 | 国产一区二区在线免费 | 欧美日在线 | 国产精品五月天 | 免费看色网站 | 波多野结衣一区三区 | 国产精品中文久久久久久久 | 久久精品国产成人精品 | 色www精品视频在线观看 | 97网站| 91欧美精品 | 91精品久久久久久久91蜜桃 | 欧美精品免费一区二区 | 国产成人精品一区二区三区免费 | 四虎成人精品在永久免费 | 亚洲一区视频免费观看 | 成人av在线影院 | 日本丰满少妇免费一区 | 中文理论片| 久久97超碰| 欧美地下肉体性派对 | 亚洲精选视频免费看 | 日韩精品无 | 亚洲婷婷在线 | 日本不卡一区二区三区在线观看 | 婷婷六月在线 | 日韩中文字幕免费 | 日韩欧美视频 | 亚洲精品动漫在线 | 91精品欧美一区二区三区 | 欧美专区国产专区 | 精品99视频 | 亚洲视频电影在线 | 欧美视频xxx| 国产精品嫩草影视久久久 | 99精品网站| 99精品热视频只有精品10 | www.久久久com | 久久国内免费视频 | 人人澡人摸人人添学生av | 久草免费在线观看视频 | 欧美精品三级在线观看 | 久久午夜免费视频 | www.久久免费| 国产淫片免费看 | 香蕉视频18 | 欧美一级片在线免费观看 | 玖玖精品在线 | 美女在线观看av | 麻豆91视频| 日批视频国产 | 国产区免费在线 | 精品96久久久久久中文字幕无 | 日韩免费中文字幕 | 在线播放视频一区 | 91丨porny丨九色| 成人动图 | 日韩av在线不卡 | av天天干| 不卡在线一区 | 久久人人97超碰精品888 | 在线观看免费观看在线91 | 特级毛片网 | 干干日日 | 中文字幕久久精品 | 成人97视频一区二区 | 欧美a级片免费看 | 欧美在线aaa | 成人免费在线观看入口 | 黄色软件网站在线观看 | 国产首页 | 中文字幕在线看视频 | 麻豆一区在线观看 | 二区视频在线 | 亚洲综合视频网 | 久久亚洲精品国产亚洲老地址 | 日韩大片在线播放 | 在线国产日本 | 国产精品久久久久久久久免费看 | 久久91久久久久麻豆精品 | 久久精品一区二区三区视频 | 国产明星视频三级a三级点| 天天射综合网站 | 天天操天天操天天操天天 | 日批视频| av丝袜在线 | 国内精品久久久久久久影视麻豆 | 午夜视频在线观看一区二区三区 | 久久av免费| 欧美国产高清 | 日本不卡视频 | 97香蕉超级碰碰久久免费软件 | 久久综合欧美精品亚洲一区 | 免费h精品视频在线播放 | 久久久久久毛片精品免费不卡 | 久久久国产视频 | 亚洲电影影音先锋 | 亚州av一区 | 91在线亚洲| 中文字幕在线不卡国产视频 | 色婷婷激情综合 | 国产成人精品久久亚洲高清不卡 | 日韩最新在线视频 | 五月激情六月丁香 | 香蕉视频网站在线观看 | 在线中文日韩 | 91精品久久久久久久91蜜桃 | 97精品在线观看 | 91久久久久久久一区二区 | 五月婷婷一级片 | 日韩欧美综合 | 日韩精品中文字幕av | 波多野结衣视频一区二区三区 | 国产欧美日韩一区 | 成年人在线观看 | 综合网天天 | 97视频免费观看 | 色多多在线观看 | 国产成视频在线观看 | 国产中文字幕精品 | 日韩欧美一区二区三区黑寡妇 | 色欧美视频 | 五月天综合激情网 | 久久草网 | 在线一级片 | 天天天操天天天干 | 97色在线观看免费视频 | 中文字幕在线观看第一区 | 色吧久久 | 国产黄色片在线 | 手机在线黄色网址 | www久久九| av超碰免费在线 | 欧美亚洲国产日韩 | 久久精品国产成人 | 精品国产免费人成在线观看 | 中文免费在线观看 | 一区 在线 影院 | 国产精品第二页 | 国产亚洲婷婷 | 四虎影视成人精品国库在线观看 | 天天射天天干天天操 | 国产精品久久久久久五月尺 | 国产精品国产三级国产aⅴ无密码 | 国产麻豆精品一区二区 | 免费黄色在线网址 | 好看av在线| 波多野结衣最新 | 一区二区三区视频在线 | 国内精品久久久久影院男同志 | 久草精品网 | 亚洲va天堂va欧美ⅴa在线 | 亚洲一级片av| 丰满少妇在线观看网站 | 国产流白浆高潮在线观看 | 国产一级免费观看视频 | 日本久久久影视 | 日韩亚洲在线观看 | 免费在线精品视频 | 五月婷婷av | 91精品国自产在线观看欧美 | av中文国产 | 欧美一级片免费观看 | 久久久国产精华液 | 91精品老司机久久一区啪 | 91激情视频在线观看 | 欧美一区二区三区四区夜夜大片 | 国产中文字幕视频在线观看 | 亚洲激情五月 | 96国产精品 | 激情在线网站 | av在线之家电影网站 | 免费在线激情电影 | 日本三级吹潮在线 | 久久久久久久久久久免费视频 | 欧美日韩中文国产 | 免费网站在线观看人 | 91九色在线观看 | 激情网综合| 欧美日韩精品区 | 亚洲视频999 | 中文字幕在线视频精品 | 亚洲视频 中文字幕 | 国产专区在线 | 五月婷婷在线观看 | 在线观看成人一级片 | 日日夜夜干 | 久久久黄色 | 91丨九色丨91啦蝌蚪老版 | 亚洲精品视频久久 | 天天伊人网 | 久久久久久久99 | 91视频麻豆视频 | 在线观看韩日电影免费 | 99爱国产精品 | 欧美另类重口 | 中文字幕91 | av网在线观看 | 欧美另类高清 videos | 日本精品视频在线观看 | 我爱av激情网 | 狠狠色2019综合网 | 97国产精品亚洲精品 | 亚洲精品自拍 | 久久艹国产 | 国产精品久久嫩一区二区免费 | 精品自拍网 | 色精品视频 | 日日干日日操 | 伊人婷婷| 亚洲专区免费观看 | 91在线视频一区 | 色综合久久久久 | 日韩欧美在线不卡 | 欧美日韩p片 | 欧美999| 伊色综合久久之综合久久 | 91一区啪爱嗯打偷拍欧美 | 色在线最新 | 五月天激情婷婷 | 狠狠干婷婷 | 免费久久视频 | 亚洲国产美女精品久久久久∴ | 黄色软件大全网站 | 成人免费大片黄在线播放 | 日韩有码欧美 | 91资源在线播放 | 一区二区三区手机在线观看 | 久久午夜免费观看 | 日韩精品一区二区不卡 | 亚洲欧美成aⅴ人在线观看 四虎在线观看 | 欧美大片在线观看一区 | 人人狠狠 | 国产在线观看一 | 欧美日韩精品区 | 狠狠的日 | 黄色精品网站 | 夜夜操夜夜干 | 99在线精品免费视频九九视 | 黄色av一级 | 久久久国产日韩 | 人人爽人人做 | 久久国产精品一区二区三区 | 日日夜夜综合网 | 久久免费黄色 | 黄色成人小视频 | 四虎影院在线观看av | 欧美另类v | 国产精品自产拍在线观看网站 | 精品产品国产在线不卡 | 亚洲综合一区二区精品导航 | 久久久久电影 | 日本黄色免费网站 | 99久久999久久久精玫瑰 | 日韩久久精品一区二区三区 | 欧美精品在线免费 | 久久在线一区 | 亚洲激情| 国产成人精品亚洲a | 人人澡人人添人人爽一区二区 | 亚洲国产精品免费 | 91理论电影| 欧美日本日韩aⅴ在线视频 插插插色综合 | 久草在线视频网站 | 天天干天天干天天操 | 天天干天天操天天入 | 97色在线视频 | 丁香视频免费观看 | 国产一区视频在线观看免费 | 四川妇女搡bbbb搡bbbb搡 | 久久国产精品久久w女人spa | 欧美在线一二 | 91精品入口 | 永久精品视频 | 亚洲日韩中文字幕在线播放 | 亚洲在线看 | 国产1区2区3区精品美女 | 国产综合精品久久 | 精品国产诱惑 | 亚洲天堂激情 | 久久av在线播放 | 91免费观看| 久久综合狠狠综合 | 国产午夜一区 | 亚洲精品乱码久久久久 | 一区二区三区高清在线观看 | 国内精品亚洲 | 手机看片99 | 六月婷婷网| 四虎在线观看网址 | 特级a毛片 | 亚洲午夜精品久久久 | 五月天久久激情 | 亚洲专区免费观看 | 69久久久| 一级黄色片毛片 | 日韩av图片 | 97超碰中文字幕 | 日韩av一区二区三区 | 久久亚洲综合国产精品99麻豆的功能介绍 | 中文字幕在线播放av | 久亚洲精品| 欧美天堂视频在线 | 久久久久久国产精品久久 | 久久久久久蜜av免费网站 | 亚洲综合成人婷婷小说 | 婷婷久久综合九色综合 | 99精品国产亚洲 | 亚洲电影毛片 | 久久99精品国产麻豆婷婷 | 999电影免费在线观看 | 色视频网页| 亚洲永久精品在线 | 天天操夜夜操夜夜操 | 免费瑟瑟网站 | 最新在线你懂的 | 欧美激精品 | 天天干天天干天天干天天干天天干天天干 | 手机看国产毛片 | 免费一级日韩欧美性大片 | 96亚洲精品久久久蜜桃 | 久久国产精品99久久人人澡 | 91热精品| 成人在线你懂得 | 五月激情丁香婷婷 | 亚洲精品久久久久久国 | 国产淫片免费看 | 婷婷丁香色 | 蜜臀av网站 | 国产亚洲精品久久久久久久久久久久 | 国产精品美女免费看 | 亚洲天天在线日亚洲洲精 | 四虎在线永久免费观看 | 丁香婷婷激情啪啪 | 国产精品综合久久久久 | 91丨九色丨高潮 | 超碰在线97国产 | a亚洲视频 | 久久精品一区二区国产 | 久草久草在线 | 在线看的毛片 | 色综合人人 | 999久久久久久久久久久 | 少妇视频在线播放 | 丁香视频在线观看 | 成人在线免费视频 | 亚洲欧美精品在线 | 天天人人| 国外av在线 | 免费观看一区二区 | 五月婷婷综合久久 | 久久久久久久久久久久久久电影 | 天天操天天舔天天爽 | 天天操天天操天天干 | 九九精品久久 | 亚洲视频456 | 国产视频资源 | 久久免费影院 | 欧美日韩国产一二三区 | 日韩网站在线观看 | 精品视频久久久久久 | 日韩色一区二区三区 | 青草视频在线免费 | 久久人人97超碰com | 97超碰网| av免费网站在线观看 | 成人欧美日韩国产 | 日日夜夜天天射 | 久久午夜剧场 | 人人精品久久 | 日日干天夜夜 | 久产久精国产品 | 国产明星视频三级a三级点| a级国产乱理论片在线观看 伊人宗合网 | 日韩在线视频精品 | 91丨九色丨国产丨porny精品 | 国产精品久久99精品毛片三a | 一本一本久久a久久精品综合 | 最近久乱中文字幕 | 国产精品美女久久久免费 | 国产精品嫩草在线 | 99视频国产精品免费观看 | 在线观看av不卡 | 国产视频美女 | 日韩在线观看你懂得 | 成年人免费av网站 | 高清有码中文字幕 | 国产另类xxxxhd高清 | 日韩超碰 | 狠狠色丁香久久婷婷综合_中 | 搡bbbb搡bbb视频 | 天天爽天天爽天天爽 | 少妇bbb| 天天操天天干天天爽 | 伊甸园av在线 | 国产日韩欧美在线观看 | 国产精品不卡在线观看 | 国产中文在线视频 | 免费看黄色毛片 | 色哟哟国产精品 | 亚洲高清资源 | 麻豆视频国产精品 | 99久久久成人国产精品 | 久久怡红院 | 女人高潮特级毛片 | 日本丶国产丶欧美色综合 | 日韩黄色在线 | 中文字幕在线视频一区二区三区 | 国产一级视频免费看 | 在线视频一二区 | 精品久久在线 | 亚洲精品一区二区三区在线观看 | 99精品欧美一区二区 | 亚洲va欧美va国产va黑人 | 亚洲免费av在线播放 | 久久久免费观看 | 在线精品视频免费观看 | 日日爽 | 激情偷乱人伦小说视频在线观看 | 在线免费av网 | 麻豆传媒视频在线免费观看 | 超碰九九 | 亚洲一区二区三区精品在线观看 | 久久99久久99精品免视看婷婷 | 韩日成人av | 久久精品韩国 | 91桃色在线观看视频 | 激情欧美国产 | 亚洲激情小视频 | 免费在线观看午夜视频 | 中文字幕在线看视频国产 | 成人在线播放视频 | 五月激情综合婷婷 | 国产99久久久精品 | 成人av免费在线看 | 91理论片午午伦夜理片久久 | 国产资源在线视频 | www.久久成人| 超碰人人超 | 碰碰影院| 伊人一级 | 日韩精品视频免费专区在线播放 | 国产一区二区精品久久91 | 国产综合精品一区二区三区 | 婷婷精品在线 | 日本韩国中文字幕 | 亚洲精品国偷自产在线91正片 | 亚洲欧美在线综合 | 久久久久一区 | av大全在线看 | www.天天干.com | 99久久精品免费看国产免费软件 | 婷婷av色综合 | 久久大视频 | www四虎影院 | 精品国产不卡 | 中文字幕乱在线伦视频中文字幕乱码在线 | 国产精品videossex国产高清 | 在线观看麻豆av | 成年人视频免费在线 | 综合网天天射 | 国产一区二区三区视频在线 | 国产亚洲在线视频 | 久久久久久久久福利 | 欧洲视频一区 | 国产淫片免费看 | 一区二区三区在线视频111 | 亚洲久久视频 | 久久永久视频 | 久久99偷拍视频 | 午夜精品久久久久久久99无限制 | 国产视频在线观看一区 | 在线观看视频一区二区三区 | 久草在线免费在线观看 | 日韩精品专区 | 97精品国产97久久久久久久久久久久 | 国产精品美女久久久网av | 国产精品高潮久久av | 热久久国产精品 | 亚洲在线综合 | 成人在线观看你懂的 | 亚洲精品视频偷拍 | 国产亚洲精品中文字幕 | 人人玩人人添人人澡超碰 | 亚洲成人精品国产 | 国产精品毛片久久久久久久 | 日本二区三区在线 | 亚洲精品国产拍在线 | 国产第一页精品 | 国产精品高潮呻吟久久久久 | 中文字幕日韩电影 | 黄色精品久久久 | 激情欧美一区二区三区 | 国产精品久久久久久久久久久久午 | 香蕉影院在线观看 | 久草成人在线 | 一区二区三区污 | 超碰在线日本 | 久久狠狠干 | 国产色秀视频 | 国模视频一区二区三区 | 一区二区三区电影在线播 | 美女视频黄频 | 国产精品久久99综合免费观看尤物 | 久久国内视频 | 在线观看亚洲精品视频 | 四虎在线免费观看 | 99热精品国产一区二区在线观看 | 日韩美视频 | 成人免费中文字幕 | 精品亚洲一区二区 | 国产精品99久久久久久人免费 | 在线观看成人av | 亚洲精品456在线播放第一页 | 91视频xxxx| 久草视频免费观 | 午夜精品久久久久久99热明星 | 91成人欧美 | 深爱激情五月网 | 91九色蝌蚪视频 | 狠狠的日| 成人高清av在线 | 成人在线视频免费观看 | 日韩精品视频一二三 | 久热久草在线 | 天天干夜夜干 | 国产高清不卡在线 | 日韩免费三级 | 最近中文字幕免费 | 91九色精品国产 | 国内丰满少妇猛烈精品播放 | 999成人 | 久久久精品免费观看 | 夜夜夜夜夜夜操 | 黄色电影在线免费观看 | 超碰在线天天 | 久久久久激情电影 | 最近2019中文免费高清视频观看www99 | 1024在线看片| 午夜精品久久久久久久99 | 日韩免费电影一区二区 | 伊人色综合久久天天 | 欧美精品v国产精品 | 欧美成人日韩 | 91精彩视频 | 一级黄色片在线观看 | 成人精品久久久 | 中文字幕国产精品一区二区 | 国产高清在线一区 | 欧美日韩视频免费 | 综合久久影院 | 国产一区视频在线观看免费 | 亚洲国产久| www.黄色片网站 | 欧美精品小视频 | 国产日韩精品一区二区在线观看播放 | 最新日韩在线观看视频 | a在线一区 | 欧美视频日韩视频 | 国产成人精品一区二区三区福利 | 97成人精品 | 亚洲精品动漫在线 | 久久成人精品电影 | 91手机电影 | 99精品免费久久久久久久久日本 | 日韩在线二区 | 国产在线不卡一区 | 精品国产一区在线观看 | 日韩av免费一区 | 精品久久久久久久久久久久久久久久久久 | 久久久久久毛片精品免费不卡 | 中文字幕网址 | 激情电影影院 | 久热免费 | 人人搞人人干 | 丁香婷婷久久 | 久久视频6 | 国产成人高清 | 国产亚洲视频中文字幕视频 | 狠狠色香婷婷久久亚洲精品 | 久久久久国 | 国产经典 欧美精品 | 欧美国产亚洲精品久久久8v | 毛片视频网址 | 五月天婷婷狠狠 | 午夜久久福利 | 狠狠狠狠狠狠干 | 欧美激情视频一区二区三区 | 久久精品国产一区二区电影 | 久久国产精品99久久久久久进口 | 国产一二区视频 | 天天插天天爱 | 日本性动态图 | 六月丁香色婷婷 | 亚av在线 | 国产精品女人网站 | 91在线免费播放 | 日韩中文在线电影 | 国产一区二区不卡在线 | 日日操日日插 | 久久福利精品 | 香蕉视频在线播放 | 99资源网 | 夜夜操天天干 | 亚洲综合视频在线观看 | 亚洲高清激情 | 黄色小说在线观看视频 | 国产午夜精品一区二区三区 | 一区二区三区电影在线播 | 亚洲国产精品一区二区久久,亚洲午夜 | 国产一区二区不卡视频 | www.国产毛片 | 人人玩人人添人人 | 久久精品屋| 日韩av资源站 | 91热| 免费人成在线观看网站 | 久久不见久久见免费影院 | av短片在线 | 91在线视频免费观看 | 99精品久久久久久久 | 日批视频在线观看免费 | 国产99久久久久久免费看 | 岛国av在线不卡 | 最近中文字幕免费av | 精品亚洲视频在线 | www在线观看视频 | 国产乱对白刺激视频在线观看女王 | 成人在线视 | 欧美日韩另类视频 | 92精品国产成人观看免费 | 在线成人免费 | 中文字幕日韩无 | 久久五月天婷婷 | 中文字幕在线中文 | 一级精品视频在线观看宜春院 | 四虎影视国产精品免费久久 | 天天草天天干 | 日韩在线欧美在线 | 国产精品123 | 久久久免费精品 | 亚洲成人av在线电影 | 国产小视频在线免费观看 | 日韩av电影网站在线观看 | 在线观看国产www | sesese图片| 成人cosplay福利网站 | 日韩r级电影在线观看 | 日韩毛片在线免费观看 | www免费视频com━ | 国产在线污 | 看v片 | 色噜噜日韩精品一区二区三区视频 | 国产精品免费不卡 | 久久婷婷丁香 | 精品一区 在线 | 精品国自产在线观看 | 成人av影视在线 | 91亚洲精品久久久久图片蜜桃 | 美女久久一区 | 久久中文欧美 | 国产护士av| 日本三级不卡视频 | 97人人看 | 久久综合偷偷噜噜噜色 | 日韩中文在线观看 | 日韩欧美高清视频在线观看 | 亚洲成年片| 中文字幕亚洲在线观看 | 96香蕉视频 | 日韩丝袜| 丁香色婷婷 | 免费情缘 | 亚洲欧美视频网站 | 久草色在线观看 | 四虎在线视频免费观看 | 91亚洲网| av国产网站 | 又黄又刺激又爽的视频 | 国产91av视频在线观看 | 久久99久久99精品免视看婷婷 | 日韩精品专区 | 成人av在线影院 | 色噜噜噜噜 | 久久精品免视看 | 九九九热精品免费视频观看网站 | 日韩一区在线播放 | 亚洲一区二区三区精品在线观看 | 99精品在线免费视频 | 久久视频网址 | 99久久久久久久久久 | 国产亚洲人成网站在线观看 | 色多视频在线观看 | 一区二区三区在线观看免费 | 国产美女久久久 | 黄色成人av在线 | 最近中文字幕高清字幕免费mv | 国产999精品久久久久久绿帽 | 亚洲影视九九影院在线观看 | 综合网伊人| 97成人精品区在线播放 | 国产精品6 | 天天草天天干 | 成人精品影视 | 精品视频网站 | 2019中文最近的2019中文在线 | 国产色婷婷精品综合在线手机播放 | 91精品国产自产在线观看 | 婷婷免费在线视频 | 日本精品在线 | 久久久久久久久久久国产精品 | 中日韩免费视频 | 婷婷精品国产欧美精品亚洲人人爽 | 久久天天躁夜夜躁狠狠躁2022 | 日日干干夜夜 | 日韩mv欧美mv国产精品 | 天天色婷婷 | 免费av大全 | 免费看片网页 | 国产一区二区中文字幕 | 久久色视频| 精品亚洲男同gayvideo网站 | 国产高清日韩欧美 | 九九免费精品视频在线观看 | 国产v在线观看 | 高清一区二区 | 69亚洲乱 | 97超碰在线视 | 亚洲一区黄色 | 国产黄| 五月天中文字幕 | 91九色成人蝌蚪首页 | 99久久影院| 少妇bbw搡bbbb搡bbbb | 久久人人爽爽人人爽人人片av | 亚洲一区视频在线播放 | 国产午夜精品一区二区三区在线观看 | 亚洲国产av精品毛片鲁大师 | 色婷婷综合久久久久 | 久久人91精品久久久久久不卡 | 欧美日韩高清免费 | 精品国产三级a∨在线欧美 免费一级片在线观看 | 久久久在线观看 | 久久久久久久久久久久久久免费看 | 精品国产乱码久久久久久1区2匹 | 免费av高清| 亚洲最大成人网4388xx | 亚洲欧洲国产视频 | 天天爽综合网 | 亚洲精品在线观看中文字幕 | 日韩精品一区二区三区免费视频观看 | 91成人小视频 | 久久久久这里只有精品 | 999电影免费在线观看 | 日韩激情中文字幕 | 精品亚洲免费视频 | 亚洲激情在线 | 欧美日韩中文字幕综合视频 | 午夜国产成人 | 亚洲视频精品在线 | 黄色性av | 91麻豆文化传媒在线观看 | 免费国产在线视频 | 免费看日韩片 | 国产精品一区二区av日韩在线 | 色婷婷免费视频 | 亚洲综合在线五月天 | 一区二区不卡视频在线观看 | 久久,天天综合 | 激情电影影院 | 一区二区三区影院 | 精品国产精品久久 | 18av在线视频 | 国内精品久久久久久久久 | 99久高清在线观看视频99精品热在线观看视频 | 亚洲精品在线视频 | 美女黄久久 | 色婷婷亚洲综合 | 色成人亚洲 | 日韩在线视频在线观看 | 亚洲人成人在线 | 久久激情五月激情 | 欧美成年人在线观看 | 香蕉视频网址 | 五月激情六月丁香 | 91最新网址 | 日韩中文字幕亚洲一区二区va在线 | 欧美五月婷婷 | 777视频在线观看 | 在线观看91久久久久久 | 福利二区视频 | 日韩成人在线免费观看 | 国产精品人成电影在线观看 | 日韩欧美亚州 | 高清不卡一区二区三区 | 国产精选在线观看 | 夜夜躁日日躁狠狠躁 | 国产精品一区二区 91 | 日韩av一卡二卡三卡 | 97超碰成人在线 | 高清av免费一区中文字幕 | 久久久不卡影院 | 亚洲精品毛片一级91精品 | 亚洲精品在线二区 | 亚洲天堂网站 | 国产欧美精品一区aⅴ影院 99视频国产精品免费观看 | 综合久久网站 | 国产一级免费av | 久久久午夜精品福利内容 | 国产精品资源在线观看 | 四虎在线影视 | 视频在线91 | 99视频精品在线 | 中文字幕日本在线观看 | 91亚色免费视频 | 久草免费在线 | 免费毛片一区二区三区久久久 | 久久久久电影网站 | 国产涩涩网站 | 免费久久99精品国产婷婷六月 | 欧美激情视频一二区 | 99久久日韩精品免费热麻豆美女 | 伊人天天综合 | 国产成人一区二区三区电影 | 日日弄天天弄美女bbbb | 综合激情伊人 | 日韩免费成人av | 欧美性色网站 | 日韩精品中文字幕有码 | 欧美日韩精品在线视频 | 欧美日韩视频精品 | 久草在线视频中文 | 99精品一区二区三区 | 美女久久视频 | 国产欧美最新羞羞视频在线观看 | 久久夜夜操 | 玖玖玖在线观看 | 日本中文一区二区 | 成人免费一级 | 2019中文字幕网站 | 久久这里只有精品久久 | 91av在| 国产精品成人一区二区三区吃奶 | 国产高清在线 | 月丁香婷婷 |