用惯了windows下面的不区分大小写的mysql语句,到了linux下面还真的很多不习惯。
奇怪的是列名与列的别名在所有的情况下均是忽略大小写的,而表的别名又是区分大小写的。
要避免这个问题,你最好在定义数据库命名规则的时候就全部采用小写字母加下划线的组合,而不使用任何的大写字母。
或者也可以强制以 -O lower_case_table_names=1
参数启动 mysqld
(如果使用 –defaults-file=…\my.cnf 参数来读取指定的配置文件启动 mysqld 的话,你需要在配置文件的 [mysqld] 区段下增加一行 lower_case_table_names=1)。这样MySQL 将在创建与查找时将所有的表名自动转换为小写字符(这个选项缺省地在 Windows 中为 1 ,在 Unix 中为 0。从 MySQL 4.0.2 开始,这个选项同样适用于数据库名)。
当你更改这个选项时,你必须在启动 mysqld
前首先将老的表名转换为小写字母。
换句话说,如果你希望在数据库里面创建表的时候保留大小写字符状态,则应该把这个参数置0:
即:unix下面默认是区分大小写的,而winodws下面是不区分的。为了设置unix下面不区分大小写,要设置unix下面的数据库表名都是小写的,并在配置文件my.conf上面,的mysqld字段增加lower_case_table_name=1,1为不区分大小写,0是区分大小写。。。并/etc/init.d/mysql restart即可。。。
转自:http://blog.sina.com.cn/s/blog_6870d1e00100jary.html