MySQL关于表名的大小写问题

在Linux环境下,MySQL表名区分大小写,而Windows环境则不区分。这可能导致跨平台应用错误。通过调整my.cnf配置文件中的lower_case_table_names参数,可以统一不同操作系统下表名的处理方式。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

MySQL关于表名的大小写问题
 
来源: ChinaUnix博客  日期: 2007.12.12 19:44 (共有条评论) 我要评论
 
在linux环境下,表的名称是区分大小写的,而在winodws环境下,表名则不区分大小写。因而如果设置不当,windows下的应用程序连接linux下的MySQL数据库常常提示table xxx doesn't exits的情况。
    
        
    
        
            
一、MySQL中关于大小写有两个变量:
                        · 
                        
                        lower_case_file_system
                        
该变量说明是否数据目录所在的文件系统对文件名的大小写敏感。ON说明对文件名的大小写不敏感,OFF表示敏感。
                        
                        ·  
                        lower_case_table_names
                        
如果设置为1,表名用小写保存到硬盘上,并且表名比较时不对大小写敏感。如果设置为2,按照指定的保存表名,但按照小写来比较。该选项还适合数据库名和表的别名。
                        
如果你正使用InnoDB表,你应在所有平台上将该变量设置为1,强制将名字转换为小写。
                        
如果运行MySQL的系统对文件名的大小写不敏感(例如Windows或Mac 
                        OS X),你不应将该变量设置为0。如果启动时没有设置该变量,并且数据目录所在文件系统对文件名的大小写不敏感,MySQL自动将lower_case_table_names设置为2。
二、为了消除linux环境下大小写敏感问题,笔者的设置如下:
1.修改my.cnf配置文件
shell>vi /etc/my.cnf
[mysqld]
                        lower_case_table_names=1
                
                
                

本文来自ChinaUnix博客,如果查看原文请点:http://blog.chinaunix.net/u1/42825/showart_441144.html

转载于:https://www.cnblogs.com/ygr158930/archive/2013/05/23/3094288.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值