Chinaunix首页 | 论坛 | 博客
  • 博客访问: 380129
  • 博文数量: 120
  • 博客积分: 5051
  • 博客等级: 大校
  • 技术积分: 1255
  • 用 户 组: 普通用户
  • 注册时间: 2007-07-03 01:25
文章分类

全部博文(120)

文章存档

2011年(2)

2010年(11)

2009年(28)

2008年(26)

2007年(53)

我的朋友

分类: LINUX

2007-12-12 19:44:20

在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

阅读(984) | 评论(0) | 转发(0) |
0

上一篇:MySQL 配置

下一篇:mysql字符集归类

给主人留下些什么吧!~~