栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 系统运维 > 运维 > Linux

Linux Mysql表名默认区分大小写【已解决】

Linux 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

Linux Mysql表名默认区分大小写【已解决】

解决项目部署到Linux时报错表找不到的问题

原因

Linux下MySQL默认表名区分大小写
查看全局变量lower_case_file_system

lower_case_table_names=0 表名存储为给定的大小和比较是区分大小写的
lower_case_table_names = 1 表名存储在磁盘是小写的,但是比较的时候是不区分大小写
lower_case_table_names=2, 表名存储为给定的大小写但是比较的时候是小写的

解决办法

注意:lower_case_file_system 是一个只读参数,无法被修改,只能在MySQL配置文件中修改
1.查看MySQL位置

which mysql // 需要配置mysql的环境变量

显示目录,我的MySQL位置如下

/opt/mysql-5.7.18/bin/mysql

2.查看MySQL配置文件的优先级目录

[root@iZbp18g9d6dss1w9whxn3sZ bin]# /opt/mysql-5.7.18/bin/mysql --verbose --help | grep -A 1 'Default options'
Default options are read from the following files in the given order:
/etc/my.cnf /etc/mysql/my.cnf /usr/local/mysql/etc/my.cnf ~/.my.cnf

3.查找Linux上my.cnf

[root@iZbp18g9d6dss1w9whxn3sZ bin]# find -name my.cnf
[root@iZbp18g9d6dss1w9whxn3sZ bin]# find -name my-default.cnf // 若my.cnf不存在则拷贝默认配置文件

4.如果查不到则是因为版本高于5.7.18,官网解释:从5.7.18开始不在二进制包中提供my-default.cnf文件。参考:https://dev.mysql.com/doc/refman/5.7/en/binary-installation.html
解决办法:找旧版本的源文件提取my-default.cnf文件
或 下载我分享的my.cnf文件 https://www.aliyundrive.com/s/xtS3HdYhJ3y
5.修改my.cnf内容, [mysqld]下面加一行:lower_case_table_names设置为1

lower_case_table_names=1

6.重启MySQL
7.再次查询lower_case_file_system的值和表,顺利解决

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/885207.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号