让 MySQL 在 Linux 下表名不区分大小写(实为表名全小写)

把 Windows 下的应用部署到 Linux 下,使用到了 Quartz 集群的特性,因此建了 MySql 的中间表,一启动看到报错:mysql

Invocation of init method failed; nested exception is org.quartz.JobPersistenceException: Couldn't retrieve trigger: Table 'unmijob.QRTZ_TRIGGERS' doesn't exist [See nested exception: com.mysql.jdbc.exceptions.jdbc4.MySQLSyntaxErrorException: Table 'unmijob.QRTZ_TRIGGERS' doesn't exist]linux

用 MySQL 客户端链接到那个数据库,看到 qrtz_triggers 表确确实实是存在的,MySQL 也是安装在 Linux 下的。在大小写敏感的操做系统中,估摸着会不会是表名大小的因素呢? 因而把 qrtz_triggers 改成大写的 QRTZ_TRIGGERS,再次启动应用服务器,这时候出现的是:sql

Invocation of init method failed; nested exception is org.quartz.JobPersistenceException: Couldn't retrieve trigger: Table 'unmijob.QRTZ_CRON_TRIGGERS' doesn't exist [See nested exception: com.mysql.jdbc.exceptions.jdbc4.MySQLSyntaxErrorException: Table 'unmijob.QRTZ_CRON_TRIGGERS' doesn't exist]数据库

说明表 QRTZ_TRIGGERS 表是找到了,找不到下面的  QRTZ_CRON_TRIGGERS 表。这样的现像面前说明在 Linux 下 MySQL 代表是区分大小写是暴露无疑了,之前可能是在 windows 下写程序,并且代码中的 sql 语句代表也都是用小写,因此未碰到。如今 Quartz 偏喜欢大写,问题也就这样来了。windows

知道缘由,找解决办法就可有的放矢了,google mysql linux 表名不区分大小写,答案立马找到:服务器

须要改 MySQL 的配置文件,Linux 下 MySQL 的配置文件多是 /etc/my.cnf,或 /etc/mysql/my.cnf,这依赖于你的安装方式。假如是 /etc/my.cnf,那么执行google

sudo vi /etc/my.cnfspa

在 [mysqld] 节中添加:操作系统

lower_case_table_names=1rest

而后保存,用 sudo /etc/init.d/mysql restart 重启 MySQL 服务便让 Linux 系统对表名大小写不敏感了。

其实准确来讲不是说 Linux 对于 MySQL 表名忽略大小写,而是应用上面的配置后,MySQL 服务程序会来自于应用程序里的请求的表名转换为小写,如你查询 select*  UNMI_TABLE,MySQL 会认为是查询的 select * from unmi_table,因此在加入

lower_case_table_names=1

以前时你必须把表名都改成小写。也就是在建立表时都用小写名字,若是建立的表名为 UNMI_TABLE,那么程序中不管是执行 select * from UNMI_TABLE 仍是执行 select * from unmi_table 都会碰到相似下面的错误:

Invocation of init method failed; nested exception is org.quartz.JobPersistenceException: Couldn't retrieve trigger: Table 'unmijob.qrtz_triggers' doesn't exist [See nested exception: com.mysql.jdbc.exceptions.jdbc4.MySQLSyntaxErrorException: Table 'unmijob.qrtz_triggers' doesn't exist]

由于 MySQL 服务程序认为表名就是小写的 unmi_table,而在数据库中的表名不是这样子的。

并且此时在 MySQL 客户端都没法把 QRTZ_TRIGGERS 改为 qrtz_triggers. 由于表名的大小写是与文件系统中的数据目录下的 frm 文件相对应的。

相关文章
相关标签/搜索