springdata-jpa与mysql
一 、springdata-jpa 的大小写
springdata-jpa默认是区分大小写的,但是生成的sql语句和字段名默认都是小写。且会将驼峰命名法转为对应的下划线。
如:
表名:USER--->user
属性:userName--->user_name
二、mysql的大小写
mysql在windows环境默认不区分大小写,但是在linux环境下默认区分大小写.
MySQL在Linux下数据库名、表名、列名、别名大小写规则是这样的:
- 数据库名与表名是严格区分大小写的。
- 表的别名是严格区分大小写的。
- 列名与列的别名在所有的情况下均是忽略大小写的。
- 变量名也是严格区分大小写的。
方案一 数据库的配置
如果想修改数据的默认配置课按照下面的步骤进行:
# 用root帐号登录后,在/etc/my.cnf 中的[mysqld]后添加添加
lower_case_table_names=1
# 重启MYSQL服务,这时已设置成功:不区分表名的大小写,0:区分大小写,1:不区分大小写
方案二 建表语句的配置
当然建表的时候也可以指定 COLLATE
修改,参考:MYSQL中的COLLATE是什么?
设置表或行的collation,使其为binary或case sensitive。在MySQL中,对于Column Collate其约定的命名方法如下:
*_bin: 表示的是binary case sensitive collation,也就是说是区分大小写
*_cs: case sensitive collation,区分大小写
*_ci: case insensitive collation,不区分大小写
需要注意的是:mysql 8.0开始,mysql默认的CHARSET
已经不再是Latin1
了,改为了utf8mb4
,并且默认的COLLATE也改为了utf8mb4_0900_ai_ci
。
三、springdata-jpa 大小写敏感切换:
在yml中配置如下配置(以下二选一):
#直接映射,不会做过多任何的处理和转换
org.hibernate.boot.model.naming.PhysicalNamingStrategyStandardImpl
#表名,字段为小写,当有大写字母的时候会添加下划线分隔符号(默认是这个)
org.springframework.boot.orm.jpa.hibernate.SpringPhysicalNamingStrategy
如果还不满足你的要求可以自定义,如:你想使用SpringPhysicalNamingStrategy ,又想命名不被转化为小写,可以自定义实现自己的逻辑,像SpringPhysicalNamingStrategy 中isCaseInsensitive方法是用来指定数据库是否区分大小写的。
//自定义配置类
public class MySQLUpperCaseStrategy extends SpringPhysicalNamingStrategy {
@Override
protected boolean isCaseInsensitive(JdbcEnvironment jdbcEnvironment) {
return false;
}
}
四、参考链接: