springdata-jpa与mysql

一 、springdata-jpa 的大小写

springdata-jpa默认是区分大小写的,但是生成的sql语句和字段名默认都是小写。且会将驼峰命名法转为对应的下划线。

如:
表名:USER--->user
属性:userName--->user_name

二、mysql的大小写

mysql在windows环境默认不区分大小写,但是在linux环境下默认区分大小写.

MySQL在Linux下数据库名、表名、列名、别名大小写规则是这样的:

  1. 数据库名与表名是严格区分大小写的。
  2. 表的别名是严格区分大小写的。
  3. 列名与列的别名在所有的情况下均是忽略大小写的。
  4. 变量名也是严格区分大小写的。

方案一 数据库的配置

如果想修改数据的默认配置课按照下面的步骤进行:

# 用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;
    }
}

四、参考链接:

  1. SpringBoot Jpa使用时碰到的问题总结一
  2. SpringBoot Jpa使用时碰到的问题总结二
  3. MYSQL中的COLLATE是什么?