踩坑了咪奖,MySQL到底大小寫敏感還是不敏感

一、MySQL是大小寫敏感的嗎

MySQL 在 Windows 下不區(qū)分大小寫酱床,但在 Linux 下默認(rèn)是區(qū)分大小寫羊赵。如果你稍加不注意就會出現(xiàn)在本機(jī)開發(fā)的程序運(yùn)行一切正常,發(fā)布到服務(wù)器行就出現(xiàn)表名找不到的問題扇谣,一頭霧水昧捷。

由于這個原因,在阿里巴巴規(guī)約中這樣要求:

【強(qiáng)制】表名罐寨、字段名必須使用小寫字母或數(shù)字 靡挥, 禁止出現(xiàn)數(shù)字開頭,禁止兩個下劃線中間只 出現(xiàn)數(shù)字衩茸。數(shù)據(jù)庫字段名的修改代價很大芹血,因為無法進(jìn)行預(yù)發(fā)布,所以字段名稱需要慎重考慮楞慈。

因此幔烛,數(shù)據(jù)庫名、 表名囊蓝、字段名饿悬,都不允許出現(xiàn)任何大寫字母,避免引起不必要的麻煩聚霜。

二狡恬、MySQL的大小寫敏感是由參數(shù)控制的

mysql大小寫敏感配置相關(guān)的兩個參數(shù)珠叔,lower_case_file_system 和 lower_case_table_names。

查看當(dāng)前mysql的大小寫敏感配置弟劲,可以使用如下語句

show global variables like '%lower_case%';

+------------------------+-------+
| Variable_name          | Value |
+------------------------+-------+
| lower_case_file_system | ON    |
| lower_case_table_names | 0     |
+------------------------+-------+

參數(shù)說明如下:

  1. lower_case_file_system祷安,代表當(dāng)前系統(tǒng)文件是否大小寫敏感,只讀參數(shù)兔乞,無法修改汇鞭。ON 大小寫不敏感,OFF 大小寫敏感庸追。

    • 此變量描述數(shù)據(jù)所在的操作系統(tǒng)的文件目錄是否區(qū)分大小寫霍骄。 OFF表示文件名區(qū)分大小寫,ON表示它們不區(qū)分大小寫淡溯。此變量是只讀的读整,因為它反映了文件系統(tǒng)的屬性,設(shè)置它對文件系統(tǒng)沒有影響咱娶。
  2. lower_case_table_names米间,代表表名是否大小寫敏感,可以修改豺总,參數(shù)有0车伞、1、2三種喻喳。

    • 0 大小寫敏感另玖。(Unix,Linux默認(rèn)) 創(chuàng)建的庫表將原樣保存在磁盤上表伦。如create database TeSt;將會創(chuàng)建一個TeSt的目錄谦去,create table AbCCC …將會原樣生成AbCCC.frm文件,SQL語句也會原樣解析蹦哼。

    • 1 大小寫不敏感鳄哭。(Windows默認(rèn)) 創(chuàng)建的庫表時,MySQL將所有的庫表名轉(zhuǎn)換成小寫存儲在磁盤上纲熏。 SQL語句同樣會將庫表名轉(zhuǎn)換成小寫妆丘。 如需要查詢以前創(chuàng)建的Testtable(生成Testtable.frm文件),即便執(zhí)行select * from Testtable局劲,也會被轉(zhuǎn)換成select * from testtable勺拣,致使報錯表不存在。

    • 2 大小寫不敏感(OS X默認(rèn)) 創(chuàng)建的庫表將原樣保存在磁盤上鱼填, 但SQL語句將庫表名轉(zhuǎn)換成小寫药有。

三、MySQL大小寫敏感如何設(shè)置

在Linux系統(tǒng)中修改my.cnf文件,在Windows下修改my.ini文件愤惰,新增或修改以下內(nèi)容苇经。

lower_case_table_names = 0 或 lower_case_table_names = 1

然后重啟MySQL服務(wù)才可以生效。

四宦言、開發(fā)注意事項

  1. 如果要將lower_case_table_names從0(敏感)修改為1(不敏感)時扇单,必須先對舊數(shù)據(jù)表的表名進(jìn)行處理,把所有數(shù)據(jù)庫的表名先改為小寫蜡励,最后再設(shè)置lower_case_table_names為1令花,否則依然會出現(xiàn)無法找到表名的問題。
  2. 在Windows上lower_case_table_names默認(rèn)值為1(不敏感)凉倚,在macOS上默認(rèn)值為2(不敏感)。在Linux上不支持值2嫂沉,服務(wù)器強(qiáng)制該值為0(敏感)稽寒。
  3. 并且MySQL官方也提示說:如果在數(shù)據(jù)目錄駐留在不區(qū)分大小寫的文件系統(tǒng)(例如Windows或macOS)上,則不應(yīng)將lower_case_table_names設(shè)置為0趟章。
  4. 否則將出現(xiàn)MySQL服務(wù)無法啟動的問題杏糙。

五、總結(jié)

由于操作系統(tǒng)不同導(dǎo)致大小寫敏感的默認(rèn)設(shè)置不一致蚓土,我們在開發(fā)時一定要注意宏侍,應(yīng)該養(yǎng)成嚴(yán)格的意識,SQL語句一律采用小寫字母蜀漆,避免無意義的踩坑谅河。

MySQL是日常工作中使用最對的數(shù)據(jù)庫之一,所以必須要要較為深入和全面的掌握确丢,對于高階人員還要掌握分布式事務(wù)绷耍、各種數(shù)據(jù)庫鎖、傳播機(jī)制等鲜侥。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末褂始,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子描函,更是在濱河造成了極大的恐慌崎苗,老刑警劉巖,帶你破解...
    沈念sama閱讀 217,406評論 6 503
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件舀寓,死亡現(xiàn)場離奇詭異胆数,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)基公,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,732評論 3 393
  • 文/潘曉璐 我一進(jìn)店門幅慌,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人轰豆,你說我怎么就攤上這事胰伍〕莸” “怎么了?”我有些...
    開封第一講書人閱讀 163,711評論 0 353
  • 文/不壞的土叔 我叫張陵骂租,是天一觀的道長祷杈。 經(jīng)常有香客問我,道長渗饮,這世上最難降的妖魔是什么但汞? 我笑而不...
    開封第一講書人閱讀 58,380評論 1 293
  • 正文 為了忘掉前任,我火速辦了婚禮互站,結(jié)果婚禮上私蕾,老公的妹妹穿的比我還像新娘。我一直安慰自己胡桃,他們只是感情好踩叭,可當(dāng)我...
    茶點故事閱讀 67,432評論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著翠胰,像睡著了一般容贝。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上之景,一...
    開封第一講書人閱讀 51,301評論 1 301
  • 那天斤富,我揣著相機(jī)與錄音,去河邊找鬼锻狗。 笑死满力,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的屋谭。 我是一名探鬼主播脚囊,決...
    沈念sama閱讀 40,145評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼桐磁!你這毒婦竟也來了悔耘?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,008評論 0 276
  • 序言:老撾萬榮一對情侶失蹤我擂,失蹤者是張志新(化名)和其女友劉穎衬以,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體校摩,經(jīng)...
    沈念sama閱讀 45,443評論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡看峻,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,649評論 3 334
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了衙吩。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片互妓。...
    茶點故事閱讀 39,795評論 1 347
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出冯勉,到底是詐尸還是另有隱情澈蚌,我是刑警寧澤,帶...
    沈念sama閱讀 35,501評論 5 345
  • 正文 年R本政府宣布灼狰,位于F島的核電站宛瞄,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏交胚。R本人自食惡果不足惜份汗,卻給世界環(huán)境...
    茶點故事閱讀 41,119評論 3 328
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望蝴簇。 院中可真熱鬧杯活,春花似錦、人聲如沸熬词。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,731評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽荡澎。三九已至,卻和暖如春晤锹,著一層夾襖步出監(jiān)牢的瞬間摩幔,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,865評論 1 269
  • 我被黑心中介騙來泰國打工鞭铆, 沒想到剛下飛機(jī)就差點兒被人妖公主榨干…… 1. 我叫王不留或衡,地道東北人。 一個月前我還...
    沈念sama閱讀 47,899評論 2 370
  • 正文 我出身青樓车遂,卻偏偏與公主長得像封断,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子舶担,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 44,724評論 2 354

推薦閱讀更多精彩內(nèi)容