springboot application.yml 怎么配置2个数据库连接

springboot application.yml 怎么配置2个数据库连接,第1张

Spring Boot 是 Spring 产品中一个新的子项目,致力于简便快捷地搭建基于 Spring 的独立可运行的应用。大多数的 Spring Boot 应用只需要非常少的 Spring 配置。 你能够使用 Spring Boot 创建 Java 应用并通过 java -jar 来运行或者创建传统的通

查看一下maven dependence里面是什么版本的

如果是5x的版本,删掉cj。

如果是8x的版本,加上cj。

或者pomxml里面根据你要连接的数据库版本写对应版本的jar依赖

再根据版本写

MyBatis的插件MyBatis-Plus,又叫苞米豆(baomidou),简称MP,官方说,它是为了猿类崛起而生,为了提高生产率而生,为了简化开发而生,不管它为了什么而生吧,反正是它出生了。

MyBatis-Plus对MyBatis只做增强不做改变,所以引入它不会对现有工程产生影响,只需要做简单的配置,就可以快速进行单表的CRUD *** 作,从而节省时间,提高效率。

MyBatis-Plus插件有很丰富的功能,比如:单表CRUD *** 作、代码生成、自动分页、逻辑删除等。

下面我们来简单介绍一下MyBatis-Plus的使用

1、pomxml

去掉MyBatis的核心依赖(orgmybatisspringbootmybatis-spring-boot-starter),增加MyBatis-Plus的依赖:

2、配置applicationyml、po、dao和Application

applicationyml中配置数据库连接:

blog数据库中article表的实体类ArticlePo:

注解说明:

@TableName:表名注解,标识实体类对应的表

@TableId注解:主键注解,当type = IdTypeAUTO时,表示这个主键是自增主键

blog数据库中article表的dao,ArticleDao:

BaseMapper接口:利用Mybatis接口编程的实现机制,默认提供了一系列的增删改查的基础方法

在Article11Application中配置 MapperScan 注解:

3、增加数据

insert:增加数据,insert返回值int代表insert了多少条记录

示例:在ArticleController中编写增加数据的接口:

说明:

1)一般业务逻辑处理在service层,这里为了方便,直接在controller中演示了

2)@Resource注解:注入ArticleDao,后续的方法中不再重复注入

4、删除数据

delete:物理删除数据,返回删除了多少条数据

示例,删除title为Mybatis-Plus test的数据:

说明:

1)物理删除后,恢复数据很困难,所以一般情况下,业务处理采用逻辑删除的方式

5、更新数据

update: 更新数据

示例,修改title为Mybatis-Plus test的数据的title为Mybatis-Plus update:

updateById: 根据主键id更新数据

示例,修改id为7的数据的title为Mybatis-Plus updateById:

注意 :

1、updateById方法:若传入实体Model,则会根据主键把其他字段全部更新一遍

问题:使用baomidou拿出某条数据的数据实体后,有其他人把数据库中这条数据的某个字段更新了,再用baomidou的updateById方法更新时,会把此字段再更新回来

解决:

方法1:使用sql语句,只更新需要更新的字段

方法2:新建实体Model,Model中只放主键和需要更新的字段

6、查询数据

selectOne: 查询单条数据

示例,查询id为7的数据:

注意 :

1、selectOne方法

1)结果没有数据时,返回null

2)结果有一条数据时,返回此数据

3)结果有两条或两条以上数据时,报错

解决办法:在最后增加 last(" limit 1 ") 语句

selectList: 查询多条数据

示例:查询title为Mybatis-Plus update的数据

7、打印sql日志

打印执行的sql,在applicationyml中配置,一般配置在开发环境

MyBatis-Plus的其他注意事项

1、如果数据库表字段中有desc、describe等mysql关键词或预留关键词,使用selectList/selectOne会报错,需要单独写sql查询语句

2、有时我们需要在Dao中单独写方法来写sql语句,这时方法的命名跟baomidou自带的命名不要一样,否则即使参数不同,也会有问题:Dao中单独写的方法,会把baomidou的方法覆盖,就调用不到baomidou的方法了

本文示例代码, 详见

>

代码:

/

获取数据库连接方法

/

public Connection getConn() throws

Exception {

Connection conn = null;

try {

//connection原始的连接方式可以转换为OracleConnection

Connection con =

thiscommonDaogetCurrentConnection();

Connection conWas = null;

if(thiswasConnection){//使用tomcat请把biz-context-financexml中的wasConnection的值设置为false

注释掉biz-context-corexml中的id="websphereForOracleConnection"内容

WebSphereNativeJdbcExtractor websphereForOracleConnection =

(WebSphereNativeJdbcExtractor)SpringUtilsgetSpringBean("websphereForOracleConnection");

conWas = websphereForOracleConnectiongetNativeConnection(con);

}else{

conWas = con;

}

conWassetAutoCommit(false);

conn =

conWasgetMetaData()getConnection();

} catch (DaoException e) {

eprintStackTrace();

}

return conn;

}

以上就是关于springboot application.yml 怎么配置2个数据库连接全部的内容,包括:springboot application.yml 怎么配置2个数据库连接、idea springboot连接mysql 配置datasource报错、Spring Boot(十一):MyBatis插件之MyBatis-Plus等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/10048353.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-04
下一篇 2023-05-04

发表评论

登录后才能评论

评论列表(0条)

保存