SpringBoot集成MyBatis遇到的问题总结(另附上@Resource和@Autowired的对比)

本文详细介绍了MySQL中常见的时区问题及解决方案,包括如何配置数据库连接和修改数据库默认时区。此外,还探讨了数据库表名使用-字符导致的语法错误,并对比了@Resource和@Autowired两个注解在Spring框架中的应用区别。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1. MySQL时区问题
java.sql.SQLException: The server time zone value 'Öйú (˜ËœÊ•r)' is unrecognized or represents more than one time zone. You must configure either the server or JDBC driver (via the serverTimezone configuration property) to use a more specifc time zone value if you want to utilize time zone support.
解决办法:(1):在数据库连接时加入时区等信息。
spring.datasource.url=jdbc:mysql://localhost:3306/microservice?useUnicode=true&characterEncoding=utf8&useSSL=false&serverTimezone=GMT%2B8   
解决办法:(2):修改MySQL数据库的默认时区

select curtime();或者select now(); ##查看当前数据库系统时间
show variables like “%time_zone%”; ##查看时区设置
修改时区:
set global time_zone = ‘+8:00’; ##修改mysql全局时区为北京时间,即我们所在的东8区
set time_zone = ‘+8:00’; ##修改当前会话时区
flush privileges; ##立即生效

2. MySQL数据库表名不能使用"-",否则会报如下的错误
java.sql.SQLSyntaxErrorException: You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near '-serv_user_tab' at line 1
3. @Resource和@Autowired的对比
  1. @Resource和@Autowired两者都是做bean的注入使用。
  2. 两者都可以写在字段和setter方法上。两者如果都写在字段上,就不需要写写setter方法。
  3. @Resource并不是Spring的注解,他的包是javax.annotation.Resource 需要导入。但是Spring支持该注解的注入。@Resource默认按 byName 自动注入,由J2EE提供。它同时支持按照byName和byType来注入,而Spring将@Resource注解的name属性解析为bean的名字,而type属性则解析为bean的类型。如果使用name属性,则使用byName的自动注入策略,而使用type属性时则使用 byType自动注入策略。如果既不指定name也不指定type属性,这时将通过反射机制使用byName自动注入策略。
  4. @Autowired为Spring提供的注解,需导入Package:org.springframework.beans.factory.annotation.Autowired;它只按照byType 注入,默认情况下它要求依赖对象必须存在,如果允许null值,可以设置它required属性为false。需要按照name注入的时候,需要辅助注解@Qualifier。

注:@Resource装配顺序
  (1). 如果同时指定了name和type,则从Spring上下文中找到唯一匹配的bean进行装配,找不到则抛出异常;
  (2). 如果指定了name,则从上下文中查找名称(id)匹配的bean进行装配,找不到则抛出异常;
  (3). 如果指定了type,则从上下文中找到类型匹配的唯一bean进行装配,找不到或者找到多个,都会抛出异常;
  (4). 如果既没有指定name,又没有指定type,则自动按照byName方式进行装配;如果没有匹配,则回退为一个原始类型进行匹配,如果匹配则自动装配;

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值