18

我正在开发一个曾经托管在 Apple 服务器上的旧网站。当它迁移到新的 Linux 服务器时,它停止工作。我很确定这是因为 php 脚本中使用的所有 MySQL 查询对表名都有不同的大小写组合(我不知道为什么原始开发人员在创建表名或 php 脚本时没有遵循任何约定) 这并不重要,因为 Mac 和 Windows MySQL 服务器默认情况下都不区分大小写。但是,Linux 不是。

有没有办法改变 MySQL 上的 Linux 默认值,使它变得不区分大小写并且像 Mac 或 Windows 一样工作?我一直在寻找,但没有找到任何不涉及更改脚本或表名或两者的答案。该网站必须是使用某些 CMS 生成的,因此有几十个页面,并且在每个表和数百个表中包含具有多个查询的文件。我开始尝试以我能想到的最聪明的方式实现这种类型的解决方案,但是如果我触摸表名,那么其他当前工作的页面就会停止工作(我试图避免进一步破坏网站)。

在 Linux 服务器的 Webmin 中的 MySQL 服务器控制台中有一个系统变量(lower_case_table_names),我读取的可以从 0 更改为 1 以解决此问题,但 Webmin 不允许我更改它,因为它是“只读“ 多变的。

你会认为这将是一个很容易解决的问题,但到目前为止我正在失去希望。我希望有人能得到一个目前可能让我难以捉摸的答案。

4

6 回答 6

20

MySQL 的大小写敏感性默认由文件系统处理,这就是您发现这种差异的原因:

9.2.2. 标识符大小写敏感性

在 MySQL 中,数据库对应于数据目录中的目录。数据库中的每个表对应于数据库目录中的至少一个文件(可能更多,取决于存储引擎)。因此,底层操作系统的大小写敏感性在数据库和表名的大小写敏感性中起作用。这意味着数据库和表名在 Windows 中不区分大小写,而在大多数 Unix 中区分大小写。一个值得注意的例外是 Mac OS X,它基于 Unix,但使用不区分大小写的默认文件系统类型 (HFS+)。但是,Mac OS X 也支持 UFS 卷,它与任何 Unix 一样区分大小写。请参阅第 1.8.4 节,“标准 SQL 的 MySQL 扩展”。

幸运的是,下一句话可以帮助你:

lower_case_table_names系统变量也会影响服务器如何处理标识符区分大小写,如本节后面所述。

lower_case_table_names简介:

如果设置为 0,则按指定存储表名,并且比较区分大小写。如果设置为 1,则表名以小写形式存储在磁盘上,并且比较不区分大小写。如果设置为 2,则表名按给定方式存储,但以小写形式进行比较。此选项也适用于数据库名称和表别名。有关其他信息,请参阅第 9.2.2 节,“标识符大小写敏感性”。

如果您在具有不区分大小写文件名的系统(例如 Windows 或 Mac OS X)上运行 MySQL,则不应将此变量设置为 0。如果在这样的系统上将此变量设置为 0 并使用不同的字母大小写访问 MyISAM 表名,则可能会导致索引损坏。在 Windows 上,默认值为 1。在 Mac OS X 上,默认值为 2。

所以看起来你应该lower_case_table_names1MySQL 配置文件中设置。

于 2012-06-23T01:20:23.380 回答
13

一个同名的 MySQL 服务器变量。您可能需要在系统启动时设置该特定变量,如本帮助页面中所述。您必须/etc/my.cnf为您的数据库服务器实例找到 MySQL 选项文件的位置(我的位于 ),然后将此选项编辑/添加到该[mysqld]部分。

之后不要忘记重新启动 MySQL 守护进程...

于 2012-06-23T01:16:23.457 回答
11

编辑mysql配置文件

nano /etc/mysql/my.cnf

或任何其他my.cnf用于配置您的mysql.

在下面

[mysqld]

添加行

lower_case_table_names=1

sudo service mysqld restart

您可能希望将您的 windows 数据库重新导入到您的 linux 数据库中。最好从头开始,使用添加表和插入语句。

很好!

于 2015-01-06T20:16:50.103 回答
3

您不能更改lower_case_table_namesmysql 运行时的值 - 它需要在启动时设置。您将需要编辑my.cnf(可能在 中/etc,可能在其他地方,不确定)。然后重启mysql,应该就好了。

于 2012-06-23T01:15:21.967 回答
1

这是因为您使用的文件系统。这被解释为

In MySQL, databases correspond to directories within the data directory.
Each table within a database corresponds to at least one file within the database directory (and possibly more, depending on the storage engine). 
Triggers also correspond to files. Consequently, the case sensitivity of the underlying operating system plays a part in the case sensitivity of database, table, and trigger names. 
This means such names are not case-sensitive in Windows, but are case-sensitive in most varieties of Unix. 
One notable exception is macOS, which is Unix-based but uses a default file system type (HFS+) that is not case-sensitive. 
However, macOS also supports UFS volumes, which are case-sensitive just as on any Unix.

您可以在 mysql 官方网站上阅读更多内容

您必须通过运行以下查询来检查区分大小写,以了解数据库的区分大小写:

SHOW VARIABLES LIKE "lower_case_table_names";

值 0(Linux 上的默认值)表示名称比较区分大小写,值 1(Windows 上的默认值)表示不区分大小写,而值 2(macOS 上的默认值)也可以视为不区分大小写。

现在,如果查询结果为 0,那么您需要更改 lower_case_table_names变量以使您的数据库不区分大小写。

请记住备份您的数据库,因为更改此变量的值后,您的数据库可能表现不佳。您可以恢复数据库后使其不区分大小写。使用以下命令备份您的数据库(并应在备份后将其删除):

mysqldump -u username -p db_name > dump.sql

现在,您需要找到您的 mysql 配置文件。配置文件可能在

/etc/mysql/my.cnf

/etc/mysql/mysql.conf.d/mysqld.cnf

您需要查找 [mysqld],无论您找到哪个文件的详细信息,例如(其中一个):

[mysqld]
user            = mysql
pid-file        = /***
socket          = /***
port            = ****
basedir         = /***
datadir         = /***
tmpdir          = /tmp
lc-messages-dir = /****

编辑您的文件:

vi /etc/mysql/mysql.conf.d/mysqld.cnf

并粘贴lower_case_table_names=1下面的行 [mysqld]

您需要重新启动mysql:

sudo service mysql restart

您现在可以使用以下命令恢复数据库:

mysql -u username -p db_name < dump.sql

完毕。干杯。

于 2021-07-28T20:33:17.883 回答
0

在创建数据库实例之前,应将 lower_case_table_names 参数设置为自定义数据库参数组的一部分。您应该避免更改现有数据库实例的 lower_case_table_names 参数,因为这样做可能会导致与时间点恢复备份和只读副本数据库实例不一致。

于 2015-11-21T21:54:20.590 回答