问题描述:

一开发同事在linux下调一个程序老是报错说找不到表,但是登陆mysql,show tables查看明明是已经创建了这张表的!!如下:

mysql> show tables;

+-------------------------------------------+

| Tables_in_huan_db |

+-------------------------------------------+

| advertisement |

| message_queue |

| message_sys_user |

| message_user |

| opHistory |

| opHistory_queue |

| opHistory_queue_result_log |

| opHistory_queue_send_fail_log |

+-------------------------------------------+

8 rows in set (0.00 sec)

mysql> desc opHistory;

ERROR 1146 (42S02): Table 'haun_db.opHistory' doesn't exist

mysql> desc opHistory_queue;

ERROR 1146 (42S02): Table 'haun_db.opHistory_queue' doesn't exist

mysql> desc opHistory_queue_result_log;

ERROR 1146 (42S02): Table 'haun_db.opHistory' doesn't exist

mysql> desc opHistory_queue_send_fail_log;

ERROR 1146 (42S02): Table 'haun_db.opHistory_queue_send_fail_log' doesn't exist

这张表明明存在,为什么程序就找不到表呢??

原因查找:

因为linux下mysql默认是要区分表名大小写的。mysql是否区分大小写设置是由参数lower_case_table_names决定的,其中:

1)lower_case_table_names = 0

区分大小写(即对表名大小写敏感),默认是这种设置。这样设置后,在mysql里创建的表名带不带大写字母都没有影响,都可以正常读出和被引用。变量lower_case_file_system说明是否数据目录所在的文件系统对文件名的大小写敏感,其中:ON说明对文件名的大小写不敏感,OFF表示敏感。

mysql> show variables like "%case%";

+------------------------+-------+

| Variable_name | Value |

+------------------------+-------+

| lower_case_file_system | ON |

| lower_case_table_names | 0 |

+------------------------+-------+

2 rows in set (0.00 sec)

2)lower_case_table_names = 1

不区分大小写(即对表名大小写不敏感)。这样设置后,表名在硬盘上以小写保存,MySQL将所有表名转换为小写存储和查找表上。该行为也适合数据库名和表的别名。

也就是说,mysql设置为不分区大小写后,创建库或表时,不管创建时使用大写字母,创建成功后,都是强制以小写保存!

mysql> show variables like "%case%";

+------------------------+-------+

| Variable_name | Value |

+------------------------+-------+

| lower_case_file_system | OFF |

| lower_case_table_names | 1 |

+------------------------+-------+

2 rows in set (0.00 sec)

上面的报错是因为:

开发之前在mysql里创建这张带有大写字母的表时,mysql还是默认的区分大小写设置,即对大小写不敏感。

后来运维同事又将mysql改成不分区大小写设置了,此时mysql都是强制以小写保存的表,所以开发后面再次在程序里引用这张表的时候,就会报错说不存在!

解决办法:

1)先在my.cnf里将lower_case_table_names参数再次调整为0,改成区分大小写

2)然后mysqladmin -uroot -p shutdown 以安全模式关闭数据库

3)登陆mysql数据库,"alter table 旧表名 rename 新表名" 将带大写字母的旧表改为小写表名

4)最后再启动mysql即可!

==========================================================

MySQL在Linux下数据库名、表名、列名、别名大小写规则是这样的:

1)数据库名与表名是严格区分大小写的;

2)表的别名是严格区分大小写的;

3)列名与列的别名在所有的情况下均是忽略大小写的;

4)变量名也是严格区分大小写的;

5)MySQL在Windows下都不区分大小写,但是在Linux下默认是区分大小写的。

6)如果想在查询时区分字段值的大小写,则字段值需要设置BINARY属性,设置的方法有多种:

a)创建时设置:

CREATE TABLE T(A VARCHAR(10) BINARY);

b)使用alter修改

所以在不同操作系统中为了能使程序和数据库都能正常运行,最好的办法是在设计表的时候都转为小写!!

修改mysql为不区分大小写设置:

[root@test-huanqiu ~]# mysqladmin -uroot -p shutdown               //以安全模式关闭数据库

[root@test-huanqiu ~]# cat /etc/my.cnf                                          //添加下面一行设置

.....

[mysqld]

lower_case_table_names=1

.....

[root@test-huanqiu ~]# /etc/init.d/mysql start                                 //启动mysql

========================================================

Mysql表名大小写区分规则

1)linux下:

数据库名与表名是严格区分大小写的;

表的别名是严格区分大小写的;

列名与列的别名在所有的情况下均是忽略大小写的;

变量名也是严格区分大小写的;

2)windows下:

都不区分大小写

3)Mac OS下(非UFS卷):

都不区分大小写

参数说明(lower_case_table_names)

Lunix下lower_case_table_names默认值为 0 ;Windows下默认值是 1 ;Mac OS X下默认值是 2 。

参数值

解释

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表名用小写保存。

由大小写敏感转换为不敏感方法

如果原来所建立库及表都是对大小写敏感的,想要转换为对大小写不敏感,主要需要进行如下3步:

1)将数据库数据通过mysqldump导出。

2)在my.cnf中更改lower_case_tables_name = 1,并重启mysql数据库。

3)将导出的数据导入mysql数据库。

注意事项

为了避免大小写引发的问题,一种推荐的命名规则是:在定义数据库、表、列的时候全部采用小写字母加下划线的方式,不使用任何大写字母。

在任何系统中可以使用lower_case_tables_name=1。使用该选项的不利之处是当使用SHOW TABLES或SHOW DATABASES时,看不出名字原来是用大写还是小写。

请注意在Unix中如果以前lower_case_tables_name = 0将lower_case_tables_name设置为1之前,重启mysqld之前,必须先将旧的数据库名和表名转换为小写。

mysql 忽略表大小写_mysql表名忽略大小写问题记录相关推荐

  1. mysql忽略表名大小写_Mysql 表名忽略大小写-连接字符集随笔记录

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

  2. mysql 库名大小写_MySQL 库名、表名、字段名区分大小写吗???

    上周末写了一篇MySQL where查询字段值不区分大小写的文章(MySQL的where查询不区分字段大小写!!!),有个兄弟留言说经常遇到库名.表名.字段名的大小写问题.我想既然研究了大小写的问题, ...

  3. mysql表类型_MySQL表类型的选择

    P131)创建表时的默认引擎是InnoDB,如果要修改默认的存储引擎,可以在参数文件中设置default-table-type.查看当前的默认存储引擎,可以使用一下命令: 创建新表的时候可以通过增加E ...

  4. mysql关系表控制_mysql表关系

    一.表的详细操作 1.修改表名 alter table 旧表名 rename 新表名; ​2.修改表的引擎与字符编码 alter table 表名 engine="引擎名" ch ...

  5. mysql 查看锁表日志_MYSQL 表锁情况查看

    查看锁表情况 mysql> show status like 'Table%'; +----------+--–+ | Variable_name | Value | +----------+- ...

  6. MySQL笔记创建表结构_MySQL表结构笔记9

    本篇大纲 MySQL数据表 创建表 创建主键 AUTO_INCREATE 指定默认值 更新表结构 删除表,重命名表 01:表 MySQL 数据库的表是一个二维表,由一个或多个数据列构成 每个数据列都有 ...

  7. mysql约束条件整型_MySQL 表的操作

    表的操作 创建表的完整语法: create table 表名( 字段名1 字段类型[(宽度) 约束条件], 字段名1 字段类型[(宽度) 约束条件], 字段名1 字段类型[(宽度) 约束条件] ); ...

  8. mysql myisam表分区_MySQL 表分区详解MyiSam引擎和InnoDb 区别(实测)

    一.什么是表分区 通俗地讲表分区是将一大表,根据条件分割成若干个小表.mysql5.1开始支持数据表分区了. 如:某用户表的记录超过了1000万条,那么就可以根据入库日期将表分区,也可以根据所在地将表 ...

  9. mysql查看表备注_mysql表中如何查看备注

    mysql表中查看备注的方法:1.通过"information_schema.TABLES"语句查看所有表的注释:2.通过"information_schema. TAB ...

最新文章

  1. 网页拼图游戏html代码,网页设计(一):拼图游戏
  2. 愿只有一个Grid Layout
  3. Oracle笔记之表空间
  4. OpenJudge 2796: 数字求和
  5. 5.1 jQuery基础
  6. (转)深入理解Java的接口和抽象类
  7. 解决UITableView分割线距左边有距离的办法
  8. adminlte3 动态菜单_一本科学菜单,十倍利润增长 | 跟巴奴学餐饮业的精简风:菜单越薄,利润越厚!...
  9. python命令行安装pandas_python中安装pandas
  10. 小甲鱼解密系列调试篇——OD使用教程笔记(持续更新中)
  11. mysql 空串 0_casewhen遇到空串转成0
  12. 车辆vin信息(含发动机号)
  13. php网页能实现飘窗吗,网站飘窗广告的实现方法
  14. SSL基础:23:生成Kubernetes集群证书(OpenSSL方式)
  15. dom4j解析XML入门指北
  16. 般若波罗蜜多心经-梵文(收藏)
  17. 世界名画陈列馆(最少机器人问题和不重复监视问题)
  18. 腾讯社招 —— 腾讯游戏后端工程师(一面)
  19. meb4.0.3(mysql enterprise backup)原理分析
  20. python3编写http代理服务器_HTTP代理服务器[Python]

热门文章

  1. jQuery文档操作之删除操作
  2. Python数据科学平台Anaconda的最新发布中增加了Microsoft VS Code
  3. 如何使用GitLab和Rancher构建CI/CD流水线–Part 1
  4. 最新 IntelliJ Idea 2017 激活方法(转)
  5. Golang遇到的一些问题总结
  6. eclipse中配置server
  7. 多旋翼飞行器控制的难点
  8. Redis 2.8.9源码 - Redis中的字符串实现 sds
  9. Luogu-P1018 乘积最大
  10. Java容器List接口