国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

MySQL大小寫(xiě)敏感的注意事項(xiàng)

瀏覽:125日期:2023-10-02 15:42:19
目錄MySQL的大小寫(xiě)敏感是由參數(shù)控制的MySQL大小寫(xiě)敏感如何設(shè)置開(kāi)發(fā)注意事項(xiàng)總結(jié)

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

【強(qiáng)制】表名、字段名必須使用小寫(xiě)字母或數(shù)字 , 禁止出現(xiàn)數(shù)字開(kāi)頭,禁止兩個(gè)下劃線(xiàn)中間只 出現(xiàn)數(shù)字。數(shù)據(jù)庫(kù)字段名的修改代價(jià)很大,因?yàn)闊o(wú)法進(jìn)行預(yù)發(fā)布,所以字段名稱(chēng)需要慎重考慮。

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

MySQL的大小寫(xiě)敏感是由參數(shù)控制的

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

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

show global variables like ’%lower_case%’;+------------------------+-------+| Variable_name | Value |+------------------------+-------+| lower_case_file_system | ON || lower_case_table_names | 0 |+------------------------+-------+

參數(shù)說(shuō)明如下:

1.lower_case_file_system,代表當(dāng)前系統(tǒng)文件是否大小寫(xiě)敏感,只讀參數(shù),無(wú)法修改。ON 大小寫(xiě)不敏感,OFF 大小寫(xiě)敏感。

此變量描述數(shù)據(jù)所在的操作系統(tǒng)的文件目錄是否區(qū)分大小寫(xiě)。 OFF表示文件名區(qū)分大小寫(xiě),ON表示它們不區(qū)分大小寫(xiě)。此變量是只讀的,因?yàn)樗从沉宋募到y(tǒng)的屬性,設(shè)置它對(duì)文件系統(tǒng)沒(méi)有影響。

2.lower_case_table_names,代表表名是否大小寫(xiě)敏感,可以修改,參數(shù)有0、1、2三種。

0 大小寫(xiě)敏感。(Unix,Linux默認(rèn)) 創(chuàng)建的庫(kù)表將原樣保存在磁盤(pán)上。如create database TeSt;將會(huì)創(chuàng)建一個(gè)TeSt的目錄,create table AbCCC …將會(huì)原樣生成AbCCC.frm文件,SQL語(yǔ)句也會(huì)原樣解析。 1 大小寫(xiě)不敏感。(Windows默認(rèn)) 創(chuàng)建的庫(kù)表時(shí),MySQL將所有的庫(kù)表名轉(zhuǎn)換成小寫(xiě)存儲(chǔ)在磁盤(pán)上。 SQL語(yǔ)句同樣會(huì)將庫(kù)表名轉(zhuǎn)換成小寫(xiě)。 如需要查詢(xún)以前創(chuàng)建的Testtable(生成Testtable.frm文件),即便執(zhí)行select * from Testtable,也會(huì)被轉(zhuǎn)換成select * from testtable,致使報(bào)錯(cuò)表不存在。 2 大小寫(xiě)不敏感(OS X默認(rèn)) 創(chuàng)建的庫(kù)表將原樣保存在磁盤(pán)上, 但SQL語(yǔ)句將庫(kù)表名轉(zhuǎn)換成小寫(xiě)。MySQL大小寫(xiě)敏感如何設(shè)置

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

lower_case_table_names = 0 或 lower_case_table_names = 1

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

開(kāi)發(fā)注意事項(xiàng) 如果要將lower_case_table_names從0(敏感)修改為1(不敏感)時(shí),必須先對(duì)舊數(shù)據(jù)表的表名進(jìn)行處理,把所有數(shù)據(jù)庫(kù)的表名先改為小寫(xiě),最后再設(shè)置lower_case_table_names為1,否則依然會(huì)出現(xiàn)無(wú)法找到表名的問(wèn)題。 在Windows上lower_case_table_names默認(rèn)值為1(不敏感),在macOS上默認(rèn)值為2(不敏感)。在Linux上不支持值2,服務(wù)器強(qiáng)制該值為0(敏感)。 并且MySQL官方也提示說(shuō):如果在數(shù)據(jù)目錄駐留在不區(qū)分大小寫(xiě)的文件系統(tǒng)(例如Windows或macOS)上,則不應(yīng)將lower_case_table_names設(shè)置為0。 否則將出現(xiàn)MySQL服務(wù)無(wú)法啟動(dòng)的問(wèn)題。 總結(jié)

由于操作系統(tǒng)不同導(dǎo)致大小寫(xiě)敏感的默認(rèn)設(shè)置不一致,我們?cè)陂_(kāi)發(fā)時(shí)一定要注意,應(yīng)該養(yǎng)成嚴(yán)格的意識(shí),SQL語(yǔ)句一律采用小寫(xiě)字母,避免無(wú)意義的踩坑。

以上就是MySQL大小寫(xiě)敏感的注意事項(xiàng)的詳細(xì)內(nèi)容,更多關(guān)于MySQL大小寫(xiě)敏感的資料請(qǐng)關(guān)注好吧啦網(wǎng)其它相關(guān)文章!

標(biāo)簽: MySQL 數(shù)據(jù)庫(kù)
相關(guān)文章:
主站蜘蛛池模板: 精品视频 久久久 | 久草视屏 | 欧洲一级鲁丝片免费 | 久久99国产乱子伦精品免 | 国产综合精品在线 | 国产精品无圣光一区二区 | 亚洲成人福利网站 | 波多野结衣在线观看免费区 | 最新理论三级中文在线观看 | 最新理论三级中文在线观看 | 91久久99久91天天拍拍 | 一区二区三区四区五区六区 | 国产精品永久免费视频观看 | 欧美成人免费在线 | 国产欧美日韩图片一区二区 | 在线亚洲日产一区二区 | 久草5| 一级片免费观看视频 | 美女扒开腿让男人桶个爽 | 亚洲欧美国产精品专区久久 | 国产三级网 | 亚洲综合天堂 | 免费观看成年人网站 | 一级做a免费视频观看网站 一级做a爰 | 99aiav国产精品视频 | 亚洲免费视频网 | 国产日韩亚洲欧美 | 亚洲天堂精品在线观看 | 中国国语毛片免费观看视频 | 国产日本韩国 | 高清国产一级精品毛片基地 | 深夜福利视频在线观看免费视频 | 国产免费一区二区三区 | 欧美日韩一区二区在线 | 日韩美女免费线视频 | 一级黄网站| 欧美日本在线视频 | 欧美有码在线观看 | 国产精品2020观看久久 | 久久手机免费视频 | 日本特黄特色大片免费看 |