SpringBoot 多数据库支持:
SpringBoot 多数据库支持:
springboot2.0+mybatis多数据源集成
https://www.cnblogs.com/cdblogs/p/9275883.html
Springboot + Mybatis 多数据源配置
https://www.cnblogs.com/dannyyao/p/7009264.html
springboot-mybatis整合多数据源
https://blog.csdn.net/tuesdayma/article/details/81081666
Springboot整合mybatis的多数据源配置与使用(XML版)
https://www.jianshu.com/p/6291068f130c
____SpringBoot +MSSQL________________________________________________________________________________
https://www.cnblogs.com/wang-yaz/p/9561188.html ******************这篇最重要
4.从事务管理器中选择一个事务,在方法上加@Transactional(value = "mysqlTransactionManager",rollbackFor = Exception.class)
https://www.cnblogs.com/memoryXudy/p/7767741.html
基本项目框架搭建 sqlserver druid配置
1. 我的连接池采用的是阿里云的druid的连接池,工具是IDEA 框架是springboot+maven
以下是我的项目框架结构
2. pom 中配置
<?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 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion> <groupId>cn.xudy.sqlservice</groupId>
<artifactId>StorageSqlService</artifactId>
<version>1.0-SNAPSHOT</version> <parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>1.5.4.RELEASE</version>
<relativePath/>
</parent> <dependencies> <dependency>
<groupId>com.alibaba</groupId>
<artifactId>druid</artifactId>
<version>1.0.25</version>
</dependency>
<dependency>
<groupId>com.microsoft.sqlserver</groupId>
<artifactId>sqljdbc4</artifactId>
<version>4.0</version>
</dependency>
<!-- Spring Boot JDBC -->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-jdbc</artifactId>
</dependency> <dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency> </dependencies> <build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
</plugins>
</build> </project>
2. .properties 配置
server.port=8011 druid.driver-class-name=com.microsoft.sqlserver.jdbc.SQLServerDriver druid.url=jdbc:sqlserver://localhost:1433;DatabaseName=test
druid.username=sa
druid.password=123456
3. SystemConfig 配置
package cn.xudy.group.config; import com.alibaba.druid.pool.DruidDataSource;
import org.springframework.beans.factory.annotation.Qualifier;
import org.springframework.boot.autoconfigure.jdbc.DataSourceBuilder;
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.jdbc.core.JdbcTemplate;
import org.springframework.stereotype.Component;
import org.springframework.web.servlet.config.annotation.CorsRegistry;
import org.springframework.web.servlet.config.annotation.WebMvcConfigurer;
import org.springframework.web.servlet.config.annotation.WebMvcConfigurerAdapter; import javax.sql.DataSource; /**
* Created by Ulegal on 2017/8/19.
*/
@Configuration
public class SystemConfig { @Bean(name = "dataSource")
@Qualifier(value = "dataSource")
@Primary
@ConfigurationProperties(prefix = "druid")
public DataSource dataSource() {
return DataSourceBuilder.create().type(DruidDataSource.class).build(); } /**
* 跨域
* @return
*/
@Bean
public WebMvcConfigurer corsConfigurer() {
return new WebMvcConfigurerAdapter() {
@Override
public void addCorsMappings(CorsRegistry registry) {
registry.addMapping("/**");
}
};
} }
4. dao数据层测试
@Repository
public class StorageDaoImpl implements StorageDao{ @Autowired
JdbcTemplate jdbcTemplate; @Override
public List<Map<String, Object>> getInfo() { // 传统方法
List<Map<String,Object>> list = new ArrayList<Map<String, Object>>();
String sql = "SELECT * FROM " + "Table_1" +";";
list = jdbcTemplate.queryForList(sql);
System.out.println("-------------"+list); return list;
}
搞定
______________________________________________________________________________________________________________
SpringBoot数据库连接池常用配置
关注公众号:程序猿王国 持续更新,每日分享
在配置文件中添加配置如下(我使用的是多数据源):
spring.datasource.primary.url=jdbc\:mysql\://localhost\:3306/test?useUnicode\=true&characterEncoding\=utf-8
spring.datasource.primary.username=test
spring.datasource.primary.password=123456
spring.datasource.primary.driver-class-name=com.mysql.jdbc.Driver
#验证连接的有效性
spring.datasource.primary.test-while-idle=true
#获取连接时候验证,会影响性能
spring.datasource.primary.test-on-borrow=false
#在连接归还到连接池时是否测试该连接
spring.datasource.primary.test-on-return=false
spring.datasource.primary.validation-query=SELECT 1 FROM DUAL
#空闲连接回收的时间间隔,与test-while-idle一起使用,设置5分钟
spring.datasource.primary.time-between-eviction-runs-millis=300000
#连接池空闲连接的有效时间 ,设置30分钟
spring.datasource.primary.min-evictable-idle-time-millis=1800000
spring.datasource.primary.initial-size=5
#指定连接池中最大的活跃连接数.
spring.datasource.primary.max-active=50
#指定连接池等待连接返回的最大等待时间,毫秒单位.
spring.datasource.primary.max-wait=60000
#指定必须保持连接的最小值
spring.datasource.primary.min-idle=5
spring.datasource.secondary.url=jdbc\:mysql\://localhost\:3306/test2?useUnicode\=true&characterEncoding\=utf-8
spring.datasource.secondary.username=test
spring.datasource.secondary.password=123456
spring.datasource.secondary.driver-class-name=com.mysql.jdbc.Driver
#验证连接的有效性
spring.datasource.secondary.test-while-idle=true
#获取连接时候验证,会影响性能
spring.datasource.secondary.test-on-borrow=false
#在连接归还到连接池时是否测试该连接
spring.datasource.secondary.test-on-return=false
spring.datasource.secondary.validation-query=SELECT 1 FROM DUAL
#空闲连接回收的时间间隔,与test-while-idle一起使用,设置5分钟
spring.datasource.secondary.time-between-eviction-runs-millis=300000
#连接池空闲连接的有效时间 ,设置30分钟
spring.datasource.secondary.min-evictable-idle-time-millis=1800000
spring.datasource.secondary.initial-size=5
#指定连接池中最大的活跃连接数.
spring.datasource.secondary.max-active=50
#指定连接池等待连接返回的最大等待时间,毫秒单位.
spring.datasource.secondary.max-wait=60000
#指定必须保持连接的最小值
spring.datasource.secondary.min-idle=5
datasource
spring.dao.exceptiontranslation.enabled是否开启PersistenceExceptionTranslationPostProcessor,默认为true
spring.datasource.abandon-when-percentage-full设定超时被废弃的连接占到多少比例时要被关闭或上报
spring.datasource.allow-pool-suspension使用Hikari pool时,是否允许连接池暂停,默认为: false
spring.datasource.alternate-username-allowed是否允许替代的用户名.
spring.datasource.auto-commit指定updates是否自动提交.
spring.datasource.catalog指定默认的catalog.
spring.datasource.commit-on-return设置当连接被归还时,是否要提交所有还未完成的事务
spring.datasource.connection-init-sql指定连接被创建,再被添加到连接池之前执行的sql.
spring.datasource.connection-init-sqls使用DBCP connection pool时,指定初始化时要执行的sql
spring.datasource.connection-properties.[key]在使用DBCP connection pool时指定要配置的属性
spring.datasource.connection-test-query指定校验连接合法性执行的sql语句
spring.datasource.connection-timeout指定连接的超时时间,毫秒单位.
spring.datasource.continue-on-error在初始化数据库时,遇到错误是否继续,默认false
spring.datasource.data指定Data (DML)脚本
spring.datasource.data-source-class-name指定数据源的全限定名.
spring.datasource.data-source-jndi指定jndi的地址
spring.datasource.data-source-properties.[key]使用Hikari connection pool时,指定要设置的属性
spring.datasource.db-properties使用Tomcat connection pool,指定要设置的属性
spring.datasource.default-auto-commit是否自动提交.
spring.datasource.default-catalog指定连接默认的catalog.
spring.datasource.default-read-only是否设置默认连接只读.
spring.datasource.default-transaction-isolation指定连接的事务的默认隔离级别.
spring.datasource.driver-class-name指定driver的类名,默认从jdbc url中自动探测.
spring.datasource.fair-queue是否采用FIFO返回连接.
spring.datasource.health-check-properties.[key]使用Hikari connection pool时,在心跳检查时传递的属性
spring.datasource.idle-timeout指定连接多久没被使用时,被设置为空闲,默认为10ms
spring.datasource.ignore-exception-on-pre-load当初始化连接池时,是否忽略异常.
spring.datasource.init-sql当连接创建时,执行的sql
spring.datasource.initial-size指定启动连接池时,初始建立的连接数量
spring.datasource.initialization-fail-fast当创建连接池时,没法创建指定最小连接数量是否抛异常
spring.datasource.initialize指定初始化数据源,是否用data.sql来初始化,默认: true
spring.datasource.isolate-internal-queries指定内部查询是否要被隔离,默认为false
spring.datasource.jdbc-interceptors使用Tomcat connection pool时,指定jdbc拦截器,分号分隔
spring.datasource.jdbc-url指定JDBC URL.
spring.datasource.jmx-enabled是否开启JMX,默认为: false
spring.datasource.jndi-name指定jndi的名称.
spring.datasource.leak-detection-threshold使用Hikari connection pool时,多少毫秒检测一次连接泄露.
spring.datasource.log-abandoned使用DBCP connection pool,是否追踪废弃statement或连接,默认为: false
spring.datasource.log-validation-errors当使用Tomcat connection pool是否打印校验错误.
spring.datasource.login-timeout指定连接数据库的超时时间.
spring.datasource.max-active指定连接池中最大的活跃连接数.
spring.datasource.max-age指定连接池中连接的最大年龄
spring.datasource.max-idle指定连接池最大的空闲连接数量.
spring.datasource.max-lifetime指定连接池中连接的最大生存时间,毫秒单位.
spring.datasource.max-open-prepared-statements指定最大的打开的prepared statements数量.
spring.datasource.max-wait指定连接池等待连接返回的最大等待时间,毫秒单位.
spring.datasource.maximum-pool-size指定连接池最大的连接数,包括使用中的和空闲的连接.
spring.datasource.min-evictable-idle-time-millis指定一个空闲连接最少空闲多久后可被清除.
spring.datasource.min-idle指定必须保持连接的最小值(For DBCP and Tomcat connection pools)
spring.datasource.minimum-idle指定连接维护的最小空闲连接数,当使用HikariCP时指定.
spring.datasource.name指定数据源名.
spring.datasource.num-tests-per-eviction-run指定运行每个idle object evictor线程时的对象数量
spring.datasource.password指定数据库密码.
spring.datasource.platform指定schema要使用的Platform(schema-${platform}.sql),默认为: all
spring.datasource.pool-name指定连接池名字.
spring.datasource.pool-prepared-statements指定是否池化statements.
spring.datasource.propagate-interrupt-state在等待连接时,如果线程被中断,是否传播中断状态.
spring.datasource.read-only当使用Hikari connection pool时,是否标记数据源只读
spring.datasource.register-mbeans指定Hikari connection pool是否注册JMX MBeans.
spring.datasource.remove-abandoned指定当连接超过废弃超时时间时,是否立刻删除该连接.
spring.datasource.remove-abandoned-timeout指定连接应该被废弃的时间.
spring.datasource.rollback-on-return在归还连接时,是否回滚等待中的事务.
spring.datasource.schema指定Schema (DDL)脚本.
spring.datasource.separator指定初始化脚本的语句分隔符,默认: ;
spring.datasource.sql-script-encoding指定SQL scripts编码.
spring.datasource.suspect-timeout指定打印废弃连接前的超时时间.
spring.datasource.test-on-borrow当从连接池借用连接时,是否测试该连接.
spring.datasource.test-on-connect创建时,是否测试连接
spring.datasource.test-on-return在连接归还到连接池时是否测试该连接.
spring.datasource.test-while-idle当连接空闲时,是否执行连接测试.
spring.datasource.time-between-eviction-runs-millis指定空闲连接检查、废弃连接清理、空闲连接池大小调整之间的操作时间间隔
spring.datasource.transaction-isolation指定事务隔离级别,使用Hikari connection pool时指定
spring.datasource.url指定JDBC URL.
spring.datasource.use-disposable-connection-facade是否对连接进行包装,防止连接关闭之后被使用.
spring.datasource.use-equals比较方法名时是否使用String.equals()替换==.
spring.datasource.use-lock是否对连接操作加锁
spring.datasource.username指定数据库名.
spring.datasource.validation-interval指定多少ms执行一次连接校验.
spring.datasource.validation-query指定获取连接时连接校验的sql查询语句.
spring.datasource.validation-query-timeout指定连接校验查询的超时时间.
spring.datasource.validation-timeout设定连接校验的超时时间,当使用Hikari connection pool时指定
spring.datasource.validator-class-name用来测试查询的validator全限定名.
spring.datasource.xa.data-source-class-name指定数据源的全限定名.
spring.datasource.xa.properties指定传递给XA data source的属性
SpringBoot 多数据库支持:的更多相关文章
- <<Python基础课程>>学习笔记 | 文章13章 | 数据库支持
备注:本章介绍了比较简单,只是比较使用样品,主要假设是把握连接,利用数据库.和SQLite做演示样本 ------ Python数据库API 为了解决Python中各种数据库模块间的兼容问题,如今已经 ...
- Django 多数据库支持
很多时候,需要去其他数据库查询数据,都将会面临多数据库支持问题. 1.在settings文件内添加多数据库连接 DATABASES = { 'default': { 'ENGINE': 'django ...
- [转] Springboot的数据库操作
转载自:https://www.cnblogs.com/juncaoit/p/7789034.html springBoot的数据库操作 一:操作数据库起步 1.Spring-Data-Jpa JPA ...
- SpringBoot使用数据库
这一篇简单介绍一下SpringBoot配置数据库的配置(依赖和application.properties),以下全是以本地数据库为例子,具体用户名密码地址都根据实际去修改. Mysql数据库: po ...
- 教你如何让数据库支持emoji表情符存储
From: http://www.cnblogs.com/janehoo/archive/2016/04/06/5359800.html 一.教你如何让数据库支持emoji表情符存储 解决方式:更换字 ...
- 解决springboot druid 数据库批量更新错误问题
原文:https://www.2cto.com/kf/201712/706399.html springboot druid 数据库多SQL错误multi-statement not allow Ca ...
- [Spring学习笔记 7 ] Spring中的数据库支持 RowMapper,JdbcDaoSupport 和 事务处理Transaction
1.Spring中的数据库支持 把具有相同功能的代码模板抽取到一个工具类中.2.关于jdbc template的应用 jdbcTemplate模板操作类,把访问jdbc的模板抽取到template中, ...
- native生成策略:由Hibernate根据所使用的数据库支持能力从identity、sequence或者等生成策略中选择一种
increment生成策略:当Hibernate准备在数据库表中插入一条新记录时,首先从数据库表中获取当前主键字段的最大值,然后在最大值基础上加1,作为当前持久化对象的标识符属性值.这种策略即incr ...
- springboot 配置jsp支持
springboot默认并不支持jsp模板,所以需要配置. 下面是一个可以运行的例子: 首先配置属性文件: spring.http.encoding.force=true spring.http. ...
随机推荐
- Codeforces 1163E Magical Permutation [线性基,构造]
codeforces 思路 我顺着图论的标签点进去的,却没想到-- 可以发现排列内每一个数都是集合里的数异或出来的. 考虑答案的上界是多少.如果能用小于\(2^k\)的数构造出\([0,2^k-1]\ ...
- c++ 获取字符串中最长的回文子串
#include <vector> #include <iostream> #include <string> using namespace std; strin ...
- CF830E Perpetual Motion Machine
题面 题解 神仙构造题. 分五种情况考虑: 如果存在一个环,那么令环上的点权值为\(1\),其余点权值为\(0\). 如果存在一个度数大于\(3\)的点,令这个点的权值为\(2\),和它相邻的点权值为 ...
- 当变量超过任意设定的变量限制时终止fluent模拟【翻译】
一些时候某个特定的变量(压力,速度,温度等)发散会造成不合理的计算结果.在许多算例,当变量超过某些合理的限制时,自动停止/打断模拟是有帮助的. 解决方法是联合UDF和scheme文件.UDF将会遍历所 ...
- Hadoop平台上HDFS和MapReduce的功能
1.用自己的话阐明Hadoop平台上HDFS和MapReduce的功能.工作原理和工作过程. HDFS (1)第一次启动 namenode 格式化后,创建 fsimage 和 edits 文件.如果不 ...
- 第06组 Beta版本演示
队名:福大帮 组长博客链接: https://www.cnblogs.com/mhq-mhq/p/12052263.html 作业博客 : https://edu.cnblogs.com/campus ...
- Spark2.x(五十九):yarn-cluster模式提交Spark任务,如何关闭client进程?
问题: 最近现场反馈采用yarn-cluster方式提交spark application后,在提交节点机上依然会存在一个yarn的client进程不关闭,又由于spark application都是 ...
- c# winform访问 带有windows身份验证的webservice
1 将webservice设置为windows身份验证iis10中,要确认已安装windows身份验证在 控制面板 - >打开或关闭Windows功能 - >万维网服务 - >安全性 ...
- vue前端项目中excel文件下载
模仿 https://github.com/PanJiaChen/vue-element-admin/ 的下载 创建文件夹vendor 创建文件 Export2Excel.js 内容: /* esli ...
- [LeetCode] 169. Majority Element 多数元素
Given an array of size n, find the majority element. The majority element is the element that appear ...