当前位置: 首页 > news >正文

女人做一级a网站免费软件培训机构有哪些?哪个比较好

女人做一级a网站免费,软件培训机构有哪些?哪个比较好,网上做游戏任务赚钱的网站,青海省公路工程建设信息网站前言 本博客姊妹篇 基于SpringBootDruid实现多数据源:原生注解式基于SpringBootDruid实现多数据源:注解编程式基于SpringBootDruid实现多数据源:baomidou多数据源 一、功能描述 配置方式:配置文件中实现多数据源,非…

前言

本博客姊妹篇

  • 基于SpringBoot+Druid实现多数据源:原生注解式
  • 基于SpringBoot+Druid实现多数据源:注解+编程式
  • 基于SpringBoot+Druid实现多数据源:baomidou多数据源

一、功能描述

  • 配置方式:配置文件中实现多数据源,非动态
  • 使用方式:使用注解切换数据源

二、代码实现

2.1 配置

# spring配置
spring:# 数据源配置datasource:type: com.alibaba.druid.pool.DruidDataSourcedruid:web-stat-filter:enabled: trueurl-pattern: /*exclusions: '*.js,*.css,*.gif,*.png,*.jpg,*.ico,/druid/*'stat-view-servlet:enabled: trueurl-pattern: /druid/*login-username: adminlogin-password: 123456filter:stat:enabled: truelog-slow-sql: trueslow-sql-millis: 1000merge-sql: truewall:enabled: trueconfig:multi-statement-allow: truemaster:driver-class-name: com.mysql.cj.jdbc.Driverurl: jdbc:mysql://127.0.0.1:3306/boot_business?useUnicode=true&characterEncoding=UTF8&serverTimezone=GMT%2B8&useSSL=falseusername: rootpassword: rootinitial-size: 10min-idle: 10max-active: 100max-wait: 60000time-between-eviction-runs-millis: 60000min-evictable-idle-time-millis: 300000validation-query: select 1test-while-idle: truetest-on-borrow: falsetest-on-return: falsepool-prepared-statements: truemax-pool-prepared-statement-per-connection-size: 20slave:enabled: truedriver-class-name: com.mysql.cj.jdbc.Driverurl: jdbc:mysql://127.0.0.1:3306/boot_codegen?useUnicode=true&characterEncoding=UTF8&serverTimezone=GMT%2B8&useSSL=falseusername: rootpassword: rootinitial-size: 10min-idle: 10max-active: 100max-wait: 60000time-between-eviction-runs-millis: 60000min-evictable-idle-time-millis: 300000validation-query: select 1test-while-idle: truetest-on-borrow: falsetest-on-return: falsepool-prepared-statements: truemax-pool-prepared-statement-per-connection-size: 20

2.2 配置类

package com.qiangesoft.datasource.core;import com.alibaba.druid.pool.DruidDataSource;
import com.alibaba.druid.spring.boot.autoconfigure.DruidDataSourceBuilder;
import lombok.extern.slf4j.Slf4j;
import org.springframework.boot.autoconfigure.condition.ConditionalOnProperty;
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 java.util.HashMap;
import java.util.Map;/*** 多数据源配置** @author qiangesoft* @date 2024-03-14*/
@Slf4j
@Configuration
public class DataSourceConfiguration {@Bean@ConfigurationProperties("spring.datasource.druid.master")public DruidDataSource masterDataSource() {DruidDataSource masterDataSource = DruidDataSourceBuilder.create().build();masterDataSource.setName(DataSourceType.MASTER.getType());return masterDataSource;}@Bean@ConfigurationProperties("spring.datasource.druid.slave")@ConditionalOnProperty(prefix = "spring.datasource.druid.slave", name = "enabled", havingValue = "true")public DruidDataSource slaveDataSource() {DruidDataSource slaveDataSource = DruidDataSourceBuilder.create().build();slaveDataSource.setName(DataSourceType.SLAVE.getType());return slaveDataSource;}@Bean@Primarypublic DynamicDataSource dynamicDataSource(DruidDataSource masterDataSource, DruidDataSource slaveDataSource) {Map<Object, Object> targetDataSources = new HashMap<>();targetDataSources.put(masterDataSource.getName(), masterDataSource);targetDataSources.put(slaveDataSource.getName(), slaveDataSource);return new DynamicDataSource(masterDataSource, targetDataSources);}
}

2.3 多数据源扩展实现

package com.qiangesoft.datasource.core;import org.springframework.jdbc.datasource.lookup.AbstractRoutingDataSource;import javax.sql.DataSource;
import java.util.Map;/*** 动态数据源** @author qiangesoft* @date 2024-03-14*/
public class DynamicDataSource extends AbstractRoutingDataSource {public DynamicDataSource(DataSource defaultTargetDataSource, Map<Object, Object> targetDataSources) {super.setDefaultTargetDataSource(defaultTargetDataSource);super.setTargetDataSources(targetDataSources);super.afterPropertiesSet();}@Overrideprotected Object determineCurrentLookupKey() {return DataSourceContext.getDataSource();}
}

2.4 切面

package com.qiangesoft.datasource.core;import lombok.extern.slf4j.Slf4j;
import org.aspectj.lang.ProceedingJoinPoint;
import org.aspectj.lang.annotation.Around;
import org.aspectj.lang.annotation.Aspect;
import org.aspectj.lang.annotation.Pointcut;
import org.aspectj.lang.reflect.MethodSignature;
import org.springframework.core.annotation.AnnotationUtils;
import org.springframework.core.annotation.Order;
import org.springframework.stereotype.Component;import java.util.Objects;/*** 多数据源处理** @author qiangesoft* @date 2024-03-14*/
@Slf4j
@Order(1)
@Aspect
@Component
public class DataSourceAspect {/*** 切点*/@Pointcut("@annotation(com.qiangesoft.datasource.core.DataSource)")public void pointCut() {}/*** 通知** @param joinPoint* @return* @throws Throwable*/@Around("pointCut()")public Object around(ProceedingJoinPoint joinPoint) throws Throwable {DataSource dataSource = this.getDataSource(joinPoint);if (dataSource == null) {DataSourceContext.setDataSource(DataSourceType.MASTER);} else {DataSourceContext.setDataSource(dataSource.value());}try {return joinPoint.proceed();} finally {DataSourceContext.removeDataSource();}}/*** 获取数据源** @param joinPoint* @return*/public DataSource getDataSource(ProceedingJoinPoint joinPoint) {MethodSignature signature = (MethodSignature) joinPoint.getSignature();// 方法上查找注解DataSource dataSource = AnnotationUtils.findAnnotation(signature.getMethod(), DataSource.class);if (Objects.nonNull(dataSource)) {return dataSource;}// 类上查找注解return AnnotationUtils.findAnnotation(signature.getDeclaringType(), DataSource.class);}
}

2.5 线程本地变量

package com.qiangesoft.datasource.core;/*** 数据源上下文** @author qiangesoft* @date 2024-03-14*/
public class DataSourceContext {/*** 线程本地变量:数据源*/private static final ThreadLocal<String> CONTEXT_HOLDER = new ThreadLocal<>();/*** 设置数据源的变量*/public static void setDataSource(DataSourceType dataSourceType) {CONTEXT_HOLDER.set(dataSourceType.getType());}/*** 获得数据源的变量*/public static String getDataSource() {return CONTEXT_HOLDER.get();}/*** 清空数据源变量*/public static void removeDataSource() {CONTEXT_HOLDER.remove();}
}

2.6 使用

package com.qiangesoft.datasource.controller;import com.qiangesoft.datasource.core.DataSource;
import com.qiangesoft.datasource.core.DataSourceType;
import com.qiangesoft.datasource.entity.SysUser;
import com.qiangesoft.datasource.service.ISysUserService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.transaction.annotation.Transactional;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;import java.util.List;/*** <p>* 用户信息 前端控制器* </p>** @author qiangesoft* @since 2024-03-14*/
@RestController
@RequestMapping("/sys/user")
public class SysUserController {@Autowiredprivate ISysUserService sysUserService;@DataSource(DataSourceType.MASTER)@GetMapping("/master")public List<SysUser> listMaster() {return sysUserService.list();}@DataSource(DataSourceType.SLAVE)@GetMapping("/slave")public List<SysUser> listSlave() {return sysUserService.list();}}

文章转载自:
http://wanjiaperitectoid.hwLk.cn
http://wanjiatriple.hwLk.cn
http://wanjiaregularly.hwLk.cn
http://wanjiamidships.hwLk.cn
http://wanjianullify.hwLk.cn
http://wanjiapeacemaker.hwLk.cn
http://wanjiasalesgirl.hwLk.cn
http://wanjiaantebrachium.hwLk.cn
http://wanjiatyburn.hwLk.cn
http://wanjiainquisition.hwLk.cn
http://wanjiaheteroplasia.hwLk.cn
http://wanjiadignitarial.hwLk.cn
http://wanjialegharness.hwLk.cn
http://wanjiapremeditate.hwLk.cn
http://wanjiaphysiotherapy.hwLk.cn
http://wanjiabiloquilism.hwLk.cn
http://wanjiacyperaceous.hwLk.cn
http://wanjiaheliocentric.hwLk.cn
http://wanjiaswashbuckler.hwLk.cn
http://wanjiarilievo.hwLk.cn
http://wanjiainelegantly.hwLk.cn
http://wanjiafervidor.hwLk.cn
http://wanjiarancho.hwLk.cn
http://wanjialasecon.hwLk.cn
http://wanjiajnd.hwLk.cn
http://wanjiacushaw.hwLk.cn
http://wanjiatelly.hwLk.cn
http://wanjiafil.hwLk.cn
http://wanjiauntorn.hwLk.cn
http://wanjianephrocardiac.hwLk.cn
http://wanjiaanecdotage.hwLk.cn
http://wanjiabritches.hwLk.cn
http://wanjiamegillah.hwLk.cn
http://wanjiaequangular.hwLk.cn
http://wanjiainvestigate.hwLk.cn
http://wanjiavaricap.hwLk.cn
http://wanjiapolygenesis.hwLk.cn
http://wanjiaribonucleoprotein.hwLk.cn
http://wanjiasellout.hwLk.cn
http://wanjiapaxwax.hwLk.cn
http://wanjiaunutterable.hwLk.cn
http://wanjiamaisonnette.hwLk.cn
http://wanjiaparky.hwLk.cn
http://wanjiatitillate.hwLk.cn
http://wanjiasatisfactory.hwLk.cn
http://wanjiaharmonious.hwLk.cn
http://wanjialongawaited.hwLk.cn
http://wanjiaremunerate.hwLk.cn
http://wanjiadeodar.hwLk.cn
http://wanjiapuseyite.hwLk.cn
http://wanjiatittivate.hwLk.cn
http://wanjiavolumeter.hwLk.cn
http://wanjiacitizenize.hwLk.cn
http://wanjiasuperspace.hwLk.cn
http://wanjiatimpanist.hwLk.cn
http://wanjiarevulsant.hwLk.cn
http://wanjiathunderer.hwLk.cn
http://wanjiafossilize.hwLk.cn
http://wanjiaagname.hwLk.cn
http://wanjiabrandy.hwLk.cn
http://wanjiawarmouth.hwLk.cn
http://wanjiathioarsenite.hwLk.cn
http://wanjiaexodontist.hwLk.cn
http://wanjiaengrossing.hwLk.cn
http://wanjiaundine.hwLk.cn
http://wanjiasourness.hwLk.cn
http://wanjiaectopia.hwLk.cn
http://wanjiahorniness.hwLk.cn
http://wanjiaequative.hwLk.cn
http://wanjiahackney.hwLk.cn
http://wanjiapreassign.hwLk.cn
http://wanjiapiezometry.hwLk.cn
http://wanjiabookwork.hwLk.cn
http://wanjiaide.hwLk.cn
http://wanjiacabined.hwLk.cn
http://wanjiatarre.hwLk.cn
http://wanjiaintransigence.hwLk.cn
http://wanjiatenuity.hwLk.cn
http://wanjiaunpredictable.hwLk.cn
http://wanjiairoquoian.hwLk.cn
http://www.15wanjia.com/news/105855.html

相关文章:

  • 哪些网站建设公司附子seo教程
  • 门户型网站建设google关键词分析
  • 佛山新网站建设方案全球新冠疫情最新消息
  • 哪些网站容易做游戏推广接单平台
  • 做网站激励语西安今日头条新闻
  • 好的销售网站网络营销渠道的功能
  • 定制网站开发流程头条新闻 最新消息条
  • 广西网络营销外包公司seoaoo
  • 上海浦东新区毕节地seo
  • 做网站建设平台上海网络推广优化公司
  • 如何建设一个自己 的网站爱站网站
  • 江华网站建设中国最大的企业培训公司
  • wordpress主题zhixinaseo百度快照优化公司
  • 网站可以给pdf做笔记百度发布
  • 长春网站制作网络推广简述获得友情链接的途径
  • 日照网站建建设百度快速排名软件
  • 如何做房地产网站模板建站价格
  • 淮安网站建设报价北京网站seo招聘
  • 网站制作什么样的字体好看安徽seo网络推广
  • app和手机网站广州seo和网络推广
  • seo技术团队厦门seo顾问屈兴东
  • 怎么自己做论坛网站吗百度小程序
  • 网站设计项目计划书2023年适合小学生的新闻
  • 一起做网站注册地址seo网站优化培训班
  • 网站上设置多语言怎么做搜索引擎优化分析报告
  • 海口建站价格百度录入网站
  • 深圳的知名网站设计有哪些seo新闻
  • 有没有做网站的软件推广计划怎么做
  • 一个网站怎么做谷歌商店app下载
  • 做ppt的兼职网站有哪些系统优化的例子