码迷,mamicode.com
首页 > 数据库 > 详细

Linux下MySQL默认对表名区分大小写

时间:2017-09-25 00:46:22      阅读:266      评论:0      收藏:0      [点我收藏+]

标签:ble   body   table   访问   lsp   mac os   解决   nbsp   lower   

有个项目部署到服务器上,日志里老是提示找不到表。

原来Linux下MySQL默认对表名区分大小写。

解决方法:

一、规范代码,表名全部大写

二、修改MySQL配置,使表名全部自动转为小写。

  1.用ROOT登录,修改/etc/my.cnf
  2.在[mysqld]下加入一行:lower_case_table_names=1
  3.重新启动数据库

 

                                             解释
0 使用CREATE TABLE或CREATE DATABASE语句指定的大小写字母在硬盘上保存表名和数据库名。名称比较对大小写敏感。在大小写不敏感的操作系统如windows或Mac OS x上我们不能将该参数设为0,如果在大小写不敏感的文件系统上将--lowercase-table-names强制设为0,并且使用不同的大小写访问MyISAM表名,可能会导致索引破坏。
1 表名在硬盘上以小写保存,名称比较对大小写不敏感。MySQL将所有表名转换为小写在存储和查找表上。该行为也适合数据库名和表的别名。该值为Windows的默认值。
2 表名和数据库名在硬盘上使用CREATE TABLE或CREATE DATABASE语句指定的大小写字母进行保存,但MySQL将它们转换为小写在查找表上。名称比较对大小写不敏感,即按照大小写来保存,按照小写来比较。注释:只在对大小写不敏感的文件系统上适用! innodb表名用小写保存。

Linux下MySQL默认对表名区分大小写

标签:ble   body   table   访问   lsp   mac os   解决   nbsp   lower   

原文地址:http://www.cnblogs.com/xiao-fy/p/7589369.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!