《MYSQL教程庫名表名大小寫問題與sqlserver兼容的啟動配置方法》要點(diǎn):
本文介紹了MYSQL教程庫名表名大小寫問題與sqlserver兼容的啟動配置方法,希望對您有用。如果有疑問,可以聯(lián)系我們。
將全局變量 lower_case_table_names 設(shè)置為1
實(shí)驗(yàn):
1.lower_case_tables_name=0的情況(Linux默認(rèn)) 直接啟動mysql,在mytest庫中新建表MyTable和mytable
mysql> use mytest;
mysql> create table MyTable(id int not null,name varchar(10),dt date);
mysql> create table mytable(id int not null,name varchar(10),dt date);
mysql> show tables;
+------------------+
| Tables_in_mytest |
+------------------+
| MyTable |
| mytable |
+------------------+
默認(rèn)情況下,可以同時創(chuàng)建mytable和MyTable兩個表
2.lower_case_tables_name=1的情況(我們需要設(shè)置成這種情況)
進(jìn)入到etc目錄,編輯my.cnf文件
[root@MYSQLServer etc]# vi my.cnf
找到 [mysqld]
在它的全局變量的最后面加入一行:lower_case_table_names = 1
保存,退出,然后重新啟動mysql
[root@MYSQLServer etc]# service mysqld restart;
進(jìn)入到mysql
[root@MYSQLServer mysql]# bin/mysql
mysql> use mytest;
mysql> select * from MyTable;
mysql> select * from mytable;
兩個查詢的結(jié)果一樣,都是查詢mytable表,而MyTable表已經(jīng)找不到了(可以看到,但查詢不到)
我們再試著創(chuàng)建MyTable表
mysql> create table MyTable(id int not null,name varchar(10),dt date);
ERROR 1050 (42S01): Table 'mytable' already exists
將得到表已經(jīng)存在的提示
同樣,我們可以試著創(chuàng)建MyTest庫
mysql> create database MyTest;
ERROR 1007 (HY000): Can't create database 'mytest'; database exists
也會得到庫已經(jīng)存在的提示
在這種情況下,表名和庫名都不區(qū)分大小寫了.
注意:在Unix中將lower_case_tables_name設(shè)置為1之前,重啟mysqld之前, 必須先將舊的數(shù)據(jù)庫名和表名轉(zhuǎn)換為小寫,否則設(shè)置后,將找不到以前的表.
(上面的實(shí)驗(yàn)中,MyTable表在lower_case_tables_name=1時已經(jīng)找不到了)
維易PHP培訓(xùn)學(xué)院每天發(fā)布《MYSQL教程庫名表名大小寫問題與sqlserver兼容的啟動配置方法》等實(shí)戰(zhàn)技能,PHP、MYSQL、LINUX、APP、JS,CSS全面培養(yǎng)人才。
轉(zhuǎn)載請注明本頁網(wǎng)址:
http://www.snjht.com/jiaocheng/10427.html