MySQL表名大小写问题

最近将一MySQL数据库从window是系统迁移到了Linux系统下发现程序报错,找不到某些表。

原因:数据库中的某些表名带有大写字母,导出后再次导入时,这些表名中的大写就会自动变成小写,而默认情况下,Linux系统下MySQL是区分大小写的,所以导致了无法找到这些表。

解决:在Linux系统下修改配置文件 vi /etc/my.cnf,使其不区分大小写,
在这里插入图片描述
在末尾添加一行lower_case_table_names=1

在这里插入图片描述

修改的前提

须删除数据库中数据(可直接删除数据库),这些数据是指安装好MySQL之后,自己新建的数据库、表等数据。

另外,
window系统下MySQL默认不区分大小写。但是,为了减少很多不必要的麻烦,就得遵循MySQL的建表规范

表名、字段名必须使用小写字母或数字,禁止以数字开头,禁止两条下划线之间只出现数字。数据库名、表名、字段名,都不允许出现任何大写字母。

猜你喜欢

转载自blog.csdn.net/qq_29025955/article/details/109615889