Spring整合MyBatis连接数据库报错

项目场景:

项目相关背景:

通过SSM框架搭建仿牛客网论坛项目。在Spring中整合MyBatis,并通过MyBatis操作MySQL数据库community中的表user。
已经引入相应的依赖,在entity下构建对应的实体类User存放user表中的所有字段,并添加对应的get和set方法、toString()方法;创建dao层的接口UserMapper,在UserMapper接口中声明需要使用的数据库操作方法;在mapper下新建对应的Mapper文件UserMapper.xml。
以上编写完毕后,编写测试类进行测试。

public class MapperTests {

    @Autowired
    private UserMapper userMapper;

    @Test
    public void testSelectUser(){
        User user = userMapper.selectById(101);
        System.out.println(user);
    }
}

问题描述

项目中遇到的问题:

就非常的无语。但是我忘记截图了。。。文字记录一下吧。
问题1:
Access denied for user 'root'@'localhost' (using password: YES)
经过我不懈的百度,ERROR变成了如下,
问题2:
Unknown database 'community'
再次经过我不懈的百度,ERROR又变成了如下,
问题3:
Could not create connection to database server.
再然后我又去修改了application.properties文件中urlserverTimeZone=UTC,运行一下MapperTests,居然莫名其妙的成功了!我也还不知道为啥。


原因分析:

对于问题1:我找了很多参考方案,主要是说配置文件.properties或者.yml中的usernamepassword设置出现问题。之前通过workbench远程连接数据库时,由于当时不会修改root用户的Host值为%,所以新建了一个rootnew用户,通过rootnew成功连上了数据库,这次出现问题我首先觉得是不是因为这个rootnew用户的关系,于是我卸载了MySQL,重装。并修改了root的用户的Host值为%。然后按照各种参考解决方案反复的修改spring.datasource.url。功夫不负有心人,变成了新的问题2.

# DataSourceProperties
spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver
spring.datasource.url=jdbc:mysql://localhost:3306/community?characterEncoding=utf-8&useSSL=false&serverTimezone=HongKong
spring.datasource.username=root
spring.datasource.password=root

对于问题2:我参考了http://t.csdn.cn/a4dlB,之后重启了mysql,重启了电脑。然后变成了问题3。。。

对于问题3:我又修改了url中的serverTimezone=UTC,然后 就可以了。
运行成功截图


总结:

我也没法总结了。莫名其妙的就好了。

总之,要走的路还很长。Be patience, and work harder!
第一次解决问题、记录问题,无论是排版还是内容都还有很多不足之处,多多努力~

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
当在Spring Boot 3中尝试整合MyBatis-Plus时,遇到`Property 'sqlSessionFactory' or 'sqlSessionTemplate' are required`这个错误,通常是由于你没有正确配置SpringMyBatis-Plus之间的依赖关系。这是必要的,因为MyBatis-Plus依赖于MyBatis的`SqlSessionFactory`或`SqlSessionTemplate`来执行SQL操作。 以下是解决这个问题的步骤: 1. **配置MyBatis**: 在Spring Boot应用的配置文件(application.yml 或 application.properties)中添加MyBatisMyBatis-Plus相关的配置。例如: ```yaml mybatis: type-aliases-package: com.example.demo.entity # 如果你的实体类包名在此 mapper-locations: classpath:mapper/*.xml # XML映射文件的位置 config-location: classpath:mybatis-config.xml # 配置文件位置(可选) mybatis-plus: global-config: # 全局配置类 db-config: # 数据库配置 id-type: ID_WORKER # 自增主键策略 table-prefix: "tb_" # 表前缀 ``` 2. **添加依赖**: 确保在你的`pom.xml`或`build.gradle`文件中包含了Spring BootSpring Data JPA(如果使用)、MyBatis以及MyBatis-Plus的依赖。例如: ```xml <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-data-jpa</artifactId> </dependency> <dependency> <groupId>org.mybatis.spring.boot</groupId> <artifactId>mybatis-spring-boot-starter</artifactId> </dependency> <dependency> <groupId>com.baomidou</groupId> <artifactId>mybatis-plus-boot-starter</artifactId> </dependency> ``` 3. **注入SqlSessionFactory或SqlSessionTemplate**: 在你的Repository或Service类上,需要通过`@Autowired`注解来注入`SqlSessionFactory`或`SqlSessionTemplate`。例如: ```java @Autowired private SqlSessionFactory sqlSessionFactory; ``` 4. **检查是否扫描Mapper接口**: 如果你使用的是Java配置(即不使用XML),记得在`@Configuration`类中启用Mapper扫描: ```java @MapperScan("com.example.demo.mapper") // 替换为你的Mapper接口所在的包名 ``` 按照以上步骤检查并配置,应该能解决`Property 'sqlSessionFactory' or 'sqlSessionTemplate' are required`的错误。如果你在配置过程中还是遇到问题,可以提供具体的错误堆栈以便更精确地诊断。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值