文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

springboot 3 下连接 mysql 数据库以及整合 mybatis-plus

2023-08-16 16:58

关注

测试示例

在 Springboot 3.x版本下整合 mysql 以及mybatis-plus,并进行简单测试,解决实现过程中所遇到的常见 Bug。

引入依赖

    mysql    mysql-connector-java    org.projectlombok    lombok    com.baomidou    mybatis-plus-boot-starter    3.5.3

配置 application.yml

# mysql 配置  datasource:    driver-class-name: com.mysql.cj.jdbc.Driver    url: jdbc:mysql://localhost:3306/community?useSSL=false&serverTimezone=UTC&useUnicode=true&characterEncoding=utf8    username: root    password: yumuing    type: com.zaxxer.hikari.HikariDataSource    hikari:      maximum-pool-size: 15      minimum-idle: 5      idle-timeout: 30000# mybatis-plus 配置mybatis-plus:  configuration:    map-underscore-to-camel-case: true    auto-mapping-behavior: full    log-impl: org.apache.ibatis.logging.stdout.StdOutImpl    use-generated-keys: true  mapper-locations: classpath*:mapper*Mapper.xml  type-aliases-package: top.yumuing.community.entity

创建 MySQL 数据库

创建 community 数据库,运行以下 SQL 代码完成数据表创建:

INSERT INTO user (id, name, email) VALUES(1, 'Jone', 'test1@baomidou.com'),(2, 'Jack','test2@baomidou.com'),(3, 'Tom','test3@baomidou.com'),(4, 'Sandy', 'test4@baomidou.com'),(5, 'Billie','test5@baomidou.com');Query OK, 5 rows affected (0.01 sec)Records: 5  Duplicates: 0  Warnings: 0mysql> DROP TABLE IF EXISTS `user`;CREATE TABLE `user` (  `id` int DEFAULT NULL,  `name` varchar(20) COLLATE utf8_unicode_ci DEFAULT NULL,  `age` int DEFAULT NULL) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_unicode_ci;

测试 MySQL 连接

@ResourceDataSource dataSource;@Testvoid contextLoadsOne() throws Exception{    System.out.println("获取的数据库连接为:"+dataSource.getConnection());}

控制台输出以下内容即为 MySQL 连接配置成功:

获取的数据库连接为:HikariProxyConnection@54056059 wrapping com.mysql.cj.jdbc.ConnectionImpl@5611bba

测试整合 Mybatis-plus 简单配置

@Resourceprivate UserMapper userMapper;@Testvoid contextLoadsTwo() {    List list = userMapper.selectList(null);    list.forEach(item-> System.out.println(item));}

控制台输出以下内容即为配置 Mybatis-plus 成功

User(id=1, name=张三, age=20)User(id=2, name=李四, age=22)User(id=3, name=王五, age=30)

当然,我们也可以使用 MybatisX 插件对 mapper.class、mapper.xml、service.class、serviceImpl.class 进行生成,步骤如下:

MybatisX使用

并且,我们也能够使用 MybatisX 插件实现 xml 文件中,mapper 对应的 SQL 代码,在 mapper.class 中写出想要在 xml 中生成代码的方法名,一定要以 select、insert、update等等进行开头,之后就会有对应提示,选中即可,完成后,往前几格子,方法名变红,选择报错点右键选中以下内容即可生成相关代码:

屏幕截图_20230208_000238

xml 文件中 selectAllByIdOrderByAge 生成代码如下:

    id,name,age

测试代码如下:

@Testvoid cotextLoadsFour(){    List users = userMapper.selectAllByIdOrderByAge(3);    users.forEach(item-> System.out.println(item));}

Bug 总结

Property ‘sqlSessionFactory’ or ‘sqlSessionTemplate’ are required

springboot 3版本整合 mybatis 3.0.5版本控制台报错 Property ‘sqlSessionFactory’ or ‘sqlSessionTemplate’ are required,NestedIOException 这个类在 Spring 6 版本中直接删除了。对的,直接删除了。而 MyBatis 老版本还没有同步更新,所以直接就报红了。而整合 mybatis 的 mybatis-plus 自然也会报红。

2022 年 11 月26 日凌晨,mybatis-spring-boot 正式发布 3.0.0 版本,完全支持 Spring Boot 3 了。mybatis-plus 也在 2022.12.28 的 3.5.3 支持了 Spring Boot 3 。最好解决办法就是升级版本。

Could not autowire. No beans of ‘DataSource’ type found

  1. 检查项目结构,主启动类位置是否正确
  2. 把自动装配@Autowired换成@Resource

Driver com.mysql.jdbc.Driver claims to not accept jdbcUrl

该报错是配置文件路径错误,重点检查url路径,3306后的 test 为数据库名,注意修改成数据库已有数据库名

mysql8.x版本URL为 jdbc:mysql://localhost:3306/test?useSSL=false&serverTimezone=UTC&useUnicode=true&characterEncoding=utf8

Cannot resolve method ‘assertEquals’ in ‘Assert’

在测试方法中,使用该方法报错,没引入 import org.junit.Assert; 的Assert 包,解决方法如下:

  1. 引入 junit 依赖

        junit    junit    4.12
  2. 导入正确包 import org.junit.Assert; 的Assert

Injection of resource dependencies failed

测试方法控制台输出:Injection of resource dependencies failed

确定报错对象为 userMapper,发现没有指定 MapperScan,解决如下:

在启动类加入:@MapperScan(“top.yumuing.community.mapper”) 即可

Could not autowire. No beans of ‘DataSource’ type found.

编译报错:Could not autowire. No beans of ‘DataSource’ type found. 代码如下:

@AutowiredDataSource dataSource;

修改 @Autowired 为 @Resource 即可解决

Could not autowire. No beans of ‘UserMapper’ type found.

@Autowiredprivate UserMapper userMapper;

修改 @Autowired 为 @Resource 即可解决
求点赞转发

来源地址:https://blog.csdn.net/yumuing/article/details/128928272

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     807人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     351人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     314人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     433人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     221人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-数据库
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯