解决SpringBoot整合SpringDataJPA配置自动创建表不报错,却不创建表问题

坑:


网上无数的解决办法,试过后均不对,包括以下几种:

1)使用@Entity注解时,包导的不对。
2)application.properties配置文件中的各项配置写的不对。
3)注解写的不对。

4)要先验证SpringBoot可以连接上Mysql。


最后终于发现问题所在:
SpringBoot的入口文件与实体类文件,不在同一父目录下:

一个是com.java  一个是com.lk下  

重名为com.java.entity名字后,重新编译即可成功

当在Spring Boot 3中尝试整合MyBatis-Plus时,遇到`Property 'sqlSessionFactory' or 'sqlSessionTemplate' are required`这个错误,通常是由于你没有正确配置Spring和MyBatis-Plus之间的依赖关系。这是必要的,因为MyBatis-Plus依赖于MyBatis的`SqlSessionFactory`或`SqlSessionTemplate`来执行SQL操作。 以下是解决这个问题的步骤: 1. **配置MyBatis**: 在Spring Boot应用的配置文件(application.yml 或 application.properties)中添加MyBatis和MyBatis-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 Boot、Spring 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`的错误。如果你在配置过程中还是遇到问题,可以提供具体的错误堆栈以便更精确地诊断。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值