小編給大家分享一下如何解決MySQL大小寫敏感導致的問題,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!
成都創(chuàng)新互聯(lián)長期為超過千家客戶提供的網(wǎng)站建設服務,團隊從業(yè)經(jīng)驗10年,關注不同地域、不同群體,并針對不同對象提供差異化的產(chǎn)品和服務;打造開放共贏平臺,與合作伙伴共同營造健康的互聯(lián)網(wǎng)生態(tài)環(huán)境。為宛城企業(yè)提供專業(yè)的成都網(wǎng)站制作、成都網(wǎng)站建設,宛城網(wǎng)站改版等技術服務。擁有十載豐富建站經(jīng)驗和眾多成功案例,為您定制開發(fā)。
MYSQL對大小寫敏感
見字如面,見標題知內(nèi)容。你有遇到過因為MYSQL對大小寫敏感而被坑的體驗嗎?
之前看過阿里巴巴Java開發(fā)手冊,在MySql建表規(guī)約里有看到:
【強制】表名、字段名必須使用小寫字母或數(shù)字 , 禁止出現(xiàn)數(shù)字開頭,禁止兩個下劃線中間只 出現(xiàn)數(shù)字。數(shù)據(jù)庫字段名的修改代價很大,因為無法進行預發(fā)布,所以字段名稱需要慎重考慮。
說明: MySQL 在 Windows 下不區(qū)分大小寫,但在 Linux 下默認是區(qū)分大小寫。因此,數(shù)據(jù)庫名、 表名、字段名,都不允許出現(xiàn)任何大寫字母,避免節(jié)外生枝。
正例: aliyun _ admin , rdc _ config , level 3_ name 反例: AliyunAdmin , rdcConfig , level 3 name
如果沒有真正遇到過類似的問題,有時候干巴巴的看這些規(guī)約體會不深,理解起來似懂非懂,并且也只是死記硬背而已。
01 一個表字母大小故事
最近自己在鼓搗一個項目玩玩,在自己本機上開發(fā)和測試過程中一直沒有問題,但是部署到Linux服務器上后,發(fā)現(xiàn)有報錯,日志信息大概是:
MySQLSyntaxErrorException: Table 'kytu.tb_sutyHo' doesn't exist
出現(xiàn)了問題,有點郁悶,本地開發(fā)好好的,怎么部署服務器就不行了。有鬼……不過莫慌??粗e誤提示很明顯,不就是tb_sutyHo 表不存在嗎!
①于是我不慌不忙打開nv(navicat),查看這個表在不在,一看還真在,數(shù)據(jù)庫中顯示的tb_sutyho ,不過h是小寫;
②查看代碼發(fā)現(xiàn)代碼中還真把表名寫成tb_sutyHo ,就一個h寫成大寫H了。
問題找到了,原來是不小心寫SQL的時候沒有寫對表名,改一下表名就搞定了,功能也一切正常了。一般情況下故事到這里也就應該結束了?問題找到了,也修復了,萬事大吉了,稍后就可以吃雞了。
對于不會玩吃雞的我,到這里并沒有結束,找到問題和解決問題的確很重要,但是找到問題出現(xiàn)的根源更重要,這樣就能在下次規(guī)避此類問題,作為一個程序員不要兩次掉入一個坑里。
我在想這個問題,本地Window環(huán)境怎么就一直沒有出現(xiàn)這個報錯提示呢?非要等我部署服務器才出現(xiàn),這到底是什么問題?(如果你對Mysql大小敏感很了解,以下內(nèi)容可以跳過….)
于是就利用搜索引擎,發(fā)現(xiàn)Mysql中控制數(shù)據(jù)庫名和表名的大小寫敏感由參數(shù)lower_case_table_names控制。
在本機Window環(huán)境查看如下:
mysql> show variables like '%case%'; +------------------------+-------+ | Variable_name | Value | +------------------------+-------+ | lower_case_file_system | ON | | lower_case_table_names | 1 | +------------------------+-------+
在Linux服務器查看如下:
mysql> show variables like '%case%'; +------------------------+-------+ | Variable_name | Value | +------------------------+-------+ | lower_case_file_system | OFF | | lower_case_table_names | 0 | +------------------------+-------+
從上面的結果已經(jīng)可以看出不同了,然而對這兩個參數(shù)還沒有感覺,不知道具體是什么意思。
在介紹lower_case_table_names的時候,順便也說一下lower_case_file_system。
lowercasefile_system
此變量描述數(shù)據(jù)目錄所在的文件系統(tǒng)上文件名的區(qū)分大小寫。 OFF表示文件名區(qū)分大小寫,ON表示它們不區(qū)分大小寫。此變量是只讀的,因為它反映了文件系統(tǒng)屬性并設置它對文件系統(tǒng)沒有影響。
lowercasetable_names
該參數(shù)為靜態(tài),可設置為0、1、2。
0 --大小寫敏感。(Unix,Linux默認) 創(chuàng)建的庫表將原樣保存在磁盤上。如create database TeSt;將會創(chuàng)建一個TeSt的目錄,create table AbCCC …將會原樣生成AbCCC.frm。 SQL語句也會原樣解析。
1 --大小寫不敏感。(Windows默認) 創(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默認) 創(chuàng)建的庫表將原樣保存在磁盤上。 但SQL語句將庫表名轉(zhuǎn)換成小寫。
On Windows the default value is 1. On macOS, the default value is 2. On Linux, a value of 2 is not supported; the server forces the value to 0 instead.
在Windows上,默認值為1。在macOS上,默認值為2。在Linux上不支持值2;服務器強制該值為0。
并且官網(wǎng)也提示說:如果在數(shù)據(jù)目錄駐留在不區(qū)分大小寫的文件系統(tǒng)(例如Windows或macOS)上的系統(tǒng)上運行MySQL,則不應將lowercasetable_names設置為0。
我自己在我的window10環(huán)境嘗試設置lower_case_table_names為0的時候,MySQL的服務怎么也啟動不能,啟動服務報錯。windows系統(tǒng)對大小寫不敏感,見下圖:
注: 如果要修改lower_case_table_names這個值,windows下修改my.ini ,Linux下修改my.cnf配置文件,需要重啟服務,具體操作可以自行上網(wǎng)找資料。
02 注意事項
修改lowercasetable_names導致的常見不良隱患: 如果在lower_case_table_names=0時,創(chuàng)建了含有大寫字母的庫表,改為lower_case_table_names=1后,則會無法被查到。
首先設置lower_case_table_names=0
CREATE TABLE `Student` ( `id` int(11) unsigned NOT NULL AUTO_INCREMENT, `name` varchar(25) NOT NULL, PRIMARY KEY (`id`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8; show tables; +----------------+ | Tables_in_aflyun | +----------------+ | Student | +----------------+
再設置lower_case_table_names=1,執(zhí)行查詢,不管表名是大寫還是小寫,都提示表不存在。
mysql> select * from Student; 1146 - Table 'aflyun.Student' doesn't exist mysql> select * from student; 1146 - Table 'aflyun.student' doesn't exist
解決方法:如果要將默認的lower_case_tables_name為0設置成1,需先將已經(jīng)存在的庫表名轉(zhuǎn)換為小寫。
針對僅表名存在大寫字母的情況:
①、lower_case_tables_name=0時,執(zhí)行rename table成小寫。
②、設置lower_case_tables_name=1,重啟生效。
針對庫名存在大寫字母的情況:
①、lower_case_tables_name=0時,使用mysqldump導出,并刪除老的數(shù)據(jù)庫。
②、設置lower_case_tables_name=1,重啟生效。
③、導入數(shù)據(jù)至實例,此時包含大寫字母的庫名已轉(zhuǎn)換為小寫。
以上是“如何解決MySQL大小寫敏感導致的問題”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對大家有所幫助,如果還想學習更多知識,歡迎關注創(chuàng)新互聯(lián)行業(yè)資訊頻道!