MySQL大小寫敏感的注意事項
由于這個原因,在阿里巴巴規(guī)約中這樣要求:
【強制】表名、字段名必須使用小寫字母或數(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ā)注意事項 如果要將lower_case_table_names從0(敏感)修改為1(不敏感)時,必須先對舊數(shù)據(jù)表的表名進(jìn)行處理,把所有數(shù)據(jù)庫的表名先改為小寫,最后再設(shè)置lower_case_table_names為1,否則依然會出現(xiàn)無法找到表名的問題。 在Windows上lower_case_table_names默認(rèn)值為1(不敏感),在macOS上默認(rèn)值為2(不敏感)。在Linux上不支持值2,服務(wù)器強制該值為0(敏感)。 并且MySQL官方也提示說:如果在數(shù)據(jù)目錄駐留在不區(qū)分大小寫的文件系統(tǒng)(例如Windows或macOS)上,則不應(yīng)將lower_case_table_names設(shè)置為0。 否則將出現(xiàn)MySQL服務(wù)無法啟動的問題。 總結(jié)由于操作系統(tǒng)不同導(dǎo)致大小寫敏感的默認(rèn)設(shè)置不一致,我們在開發(fā)時一定要注意,應(yīng)該養(yǎng)成嚴(yán)格的意識,SQL語句一律采用小寫字母,避免無意義的踩坑。
以上就是MySQL大小寫敏感的注意事項的詳細(xì)內(nèi)容,更多關(guān)于MySQL大小寫敏感的資料請關(guān)注好吧啦網(wǎng)其它相關(guān)文章!
相關(guān)文章:
1. MySQL 字符串函數(shù):字符串截取2. DB2高可用性災(zāi)難恢復(fù)(HADR)的限制3. Microsoft Office Access調(diào)整字段位置的方法4. MySQL之mysqldump的使用詳解5. DB2數(shù)據(jù)庫導(dǎo)出表結(jié)構(gòu)與導(dǎo)入導(dǎo)出表數(shù)據(jù)6. MySQL雙主(主主)架構(gòu)配置方案7. MySQL CHAR和VARCHAR該如何選擇8. DB2數(shù)據(jù)庫代碼頁不兼容的問題的另類解決9. RHAS 3.0上的Oracle 9i的安裝10. mysql group by 對多個字段進(jìn)行分組操作
