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

网站开发费用算无形资产在线网页设计器

网站开发费用算无形资产,在线网页设计器,网页设计师培训费用预算图,wordpress 企业网站 免费前言 本博客姊妹篇 基于SpringBootDruid实现多数据源#xff1a;原生注解式基于SpringBootDruid实现多数据源#xff1a;注解编程式基于SpringBootDruid实现多数据源#xff1a;baomidou多数据源 一、功能描述 配置方式#xff1a;配置文件中配置默认数据源#xff0c…前言 本博客姊妹篇 基于SpringBootDruid实现多数据源原生注解式基于SpringBootDruid实现多数据源注解编程式基于SpringBootDruid实现多数据源baomidou多数据源 一、功能描述 配置方式配置文件中配置默认数据源使用数据库存储其他数据源配置使用方式使用注解切换数据源编程式切换数据源 二、代码实现 2.1 配置 # spring配置 spring:# 数据源配置datasource:type: com.alibaba.druid.pool.DruidDataSourcedruid:driver-class-name: com.mysql.cj.jdbc.Driverurl: jdbc:mysql://127.0.0.1:3306/boot_codegen?useUnicodetruecharacterEncodingUTF8serverTimezoneGMT%2B8useSSLfalseusername: 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: 20web-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: true2.2 配置类 package com.qiangesoft.datasourcepro.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 javax.sql.DataSource; import java.util.HashMap; import java.util.Map;/*** 多数据源配置** author qiangesoft* date 2024-03-14*/ Slf4j Configuration public class DataSourceConfiguration {Beanpublic DruidDataSource defaultDataSource() {return DruidDataSourceBuilder.create().build();}BeanPrimarypublic DynamicDataSource dynamicDataSource(DruidDataSource defaultDataSource) {MapObject, Object targetDataSources new HashMap();targetDataSources.put(default, defaultDataSource);return new DynamicDataSource(defaultDataSource, targetDataSources);} } 2.3 多数据源扩展实现 package com.qiangesoft.datasourcepro.core;import com.alibaba.druid.pool.DruidDataSource; import com.qiangesoft.datasourcepro.entity.BcgDataSource; import com.qiangesoft.datasourcepro.service.IBcgDataSourceService; import com.qiangesoft.datasourcepro.utils.SpringUtil; import org.springframework.boot.jdbc.DataSourceBuilder; import org.springframework.jdbc.datasource.lookup.AbstractRoutingDataSource;import java.util.Map;/*** 动态数据源** author qiangesoft* date 2024-03-14*/ public class DynamicDataSource extends AbstractRoutingDataSource {private MapObject, Object dynamicTargetDataSources;private Object dynamicDefaultTargetDataSource;public DynamicDataSource(DruidDataSource defaultTargetDataSource, MapObject, Object targetDataSources) {super.setDefaultTargetDataSource(defaultTargetDataSource);super.setTargetDataSources(targetDataSources);super.afterPropertiesSet();this.dynamicTargetDataSources targetDataSources;this.dynamicDefaultTargetDataSource defaultTargetDataSource;}Overrideprotected Object determineCurrentLookupKey() {String datasourceId DataSourceContext.getDataSource();if (datasourceId ! null this.dynamicTargetDataSources.containsKey(datasourceId)) {return datasourceId;}return null;}/*** 添加数据源** param dataSourceId*/public void addDataSource(String dataSourceId) {if (default.equals(dataSourceId)) {return;}int initialSize ((DruidDataSource) dynamicDefaultTargetDataSource).getInitialSize();BcgDataSource bcgDataSource SpringUtil.getBean(IBcgDataSourceService.class).getById(Long.valueOf(dataSourceId));if (bcgDataSource null) {throw new RuntimeException(数据源配置不存在);}String datasourceId String.valueOf(bcgDataSource.getId());MapObject, Object dynamicTargetDataSources this.dynamicTargetDataSources;if (!dynamicTargetDataSources.containsKey(datasourceId)) {DruidDataSource dataSourceInstance DataSourceBuilder.create().driverClassName(bcgDataSource.getDriverClassName()).url(bcgDataSource.getUrl()).username(bcgDataSource.getUsername()).password(bcgDataSource.getPassword()).type(DruidDataSource.class).build();dynamicTargetDataSources.put(datasourceId, dataSourceInstance);// 关键一步将TargetDataSources中的连接信息放入resolvedDataSources管理super.afterPropertiesSet();}} }2.4 切面 package com.qiangesoft.datasourcepro.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.datasourcepro.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(default);} 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.datasourcepro.core;import com.qiangesoft.datasourcepro.utils.SpringUtil;/*** 数据源上下文** author qiangesoft* date 2024-03-14*/ public class DataSourceContext {/*** 线程本地变量数据源*/private static final ThreadLocalString CONTEXT_HOLDER new ThreadLocal();/*** 设置数据源的变量*/public static void setDataSource(String dataSourceId) {SpringUtil.getBean(DynamicDataSource.class).addDataSource(dataSourceId);CONTEXT_HOLDER.set(dataSourceId);}/*** 获得数据源的变量*/public static String getDataSource() {return CONTEXT_HOLDER.get();}/*** 清空数据源变量*/public static void removeDataSource() {CONTEXT_HOLDER.remove();} }2.6 使用 package com.qiangesoft.datasourcepro.service.impl;import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; import com.qiangesoft.datasourcepro.core.DataSource; import com.qiangesoft.datasourcepro.core.DataSourceContext; import com.qiangesoft.datasourcepro.entity.BcgDataSource; import com.qiangesoft.datasourcepro.mapper.BcgDataSourceMapper; import com.qiangesoft.datasourcepro.service.IBcgDataSourceService; import lombok.RequiredArgsConstructor; import lombok.extern.slf4j.Slf4j; import org.springframework.stereotype.Service;import java.util.List;/*** p* 数据源 服务实现类* /p** author qiangesoft* since 2024-03-13*/ Slf4j RequiredArgsConstructor Service public class BcgBcgDataSourceServiceImpl extends ServiceImplBcgDataSourceMapper, BcgDataSource implements IBcgDataSourceService {Overridepublic ListBcgDataSource changeDataSource(String datasourceId) {try {DataSourceContext.setDataSource(datasourceId);return this.list();} catch (Exception e) {e.printStackTrace();throw new RuntimeException(数据源切换失败);} finally {DataSourceContext.removeDataSource();}}DataSource(value 1)Overridepublic ListBcgDataSource changeDataSourceByAnnotation() {return this.list();} }
http://www.hkea.cn/news/14487575/

相关文章:

  • 三合一网站管理系统国美在线网站域名建设
  • 博罗中山网站建设南京正规小程序开发公司
  • 南昌建网站单位如何建设与维护网站
  • 响应式设计网站seo哪家公司好
  • 网站的宣传推广方式网站设计与开发培训
  • 百度给做网站公司wordpress 删除插件
  • 网站百度无排名sae 网站备案信息
  • 哪里可以做营销型网站施工企业安全生产管理体系案例
  • h5效果展示网站濮阳网站怎么做seo
  • 如何跑网站建设业务哪些网站可以做微课
  • 西安住房建设局网站首页合肥网站建设费用
  • 郑州陆港开发建设有限公司网站wordpress视频不全屏播放
  • 酒店类的电影网站模板网站建设招标需求
  • 制作网站网络科技公司网站建设 思路
  • 网站源码还可以做授权么wordpress the_content() 不显示
  • 邢台网站建设要多少钱深圳网络营销方法
  • 企业网站优化分为两个方向怎么样建设一个网上教学网站
  • 大丰做网站哪家公司好企业网站建设论文
  • wordpress中文建站深圳通信管理局网站
  • 网站建设客户定位wordpress修改功能小工具栏
  • 优质做网站公司网站建设与管理logo
  • 兼职python做网站有关大学生做兼职的网站有哪些
  • 交通运输局网站建设方案广州做手机网站信息
  • 网站首图怎么做常宁网站建设
  • 鲜花网站建设的总体目标建设银行征信中心个人信用查询官方网站
  • 网站建设报价单表格模板网站建设需要什么工具
  • 论文网站建设格式网站设计是不是会要用代码做
  • 郑州网站制作开发天津网站建设设计费用
  • 网站建设 三乐重庆黄页网站
  • 栖霞酒店网站设计价格做网站电话销售