濮阳杆衣贸易有限公司

主頁(yè) > 知識(shí)庫(kù) > MySQL大小寫敏感的注意事項(xiàng)

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

熱門標(biāo)簽:400電話變更申請(qǐng) 武漢電銷機(jī)器人電話 大豐地圖標(biāo)注app 呂梁外呼系統(tǒng) 南太平洋地圖標(biāo)注 html地圖標(biāo)注并導(dǎo)航 400電話辦理服務(wù)價(jià)格最實(shí)惠 催天下外呼系統(tǒng) 北京金倫外呼系統(tǒng)

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

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

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

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

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

查看當(dāng)前mysql的大小寫敏感配置,可以使用如下語(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)文件是否大小寫敏感,只讀參數(shù),無(wú)法修改。ON 大小寫不敏感,OFF 大小寫敏感。

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

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

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

  • 如果要將lower_case_table_names從0(敏感)修改為1(不敏感)時(shí),必須先對(duì)舊數(shù)據(jù)表的表名進(jìn)行處理,把所有數(shù)據(jù)庫(kù)的表名先改為小寫,最后再設(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ū)分大小寫的文件系統(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)致大小寫敏感的默認(rèn)設(shè)置不一致,我們?cè)陂_發(fā)時(shí)一定要注意,應(yīng)該養(yǎng)成嚴(yán)格的意識(shí),SQL語(yǔ)句一律采用小寫字母,避免無(wú)意義的踩坑。

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

您可能感興趣的文章:
  • MySQL 字符類型大小寫敏感
  • mysql如何設(shè)置不區(qū)分大小寫
  • MySQL大小寫敏感導(dǎo)致的問(wèn)題分析
  • 解決MySQl查詢不區(qū)分大小寫的方法講解
  • MySQL數(shù)據(jù)庫(kù)大小寫敏感的問(wèn)題
  • mysql表名忽略大小寫配置方法詳解
  • Linux系統(tǒng)MySQL忘記密碼,重置密碼,忽略表名、列名大小寫的方法
  • 詳解MySQL查詢時(shí)區(qū)分字符串中字母大小寫的方法
  • MySql查詢不區(qū)分大小寫解決方案(兩種)
  • MySQL庫(kù)表名大小寫的選擇

標(biāo)簽:龍巖 南充 無(wú)錫 徐州 迪慶 自貢 麗水 西寧

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《MySQL大小寫敏感的注意事項(xiàng)》,本文關(guān)鍵詞  MySQL,大小寫,敏感,的,注意事項(xiàng),;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《MySQL大小寫敏感的注意事項(xiàng)》相關(guān)的同類信息!
  • 本頁(yè)收集關(guān)于MySQL大小寫敏感的注意事項(xiàng)的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    团风县| 惠州市| 东方市| 亚东县| 大关县| 湘乡市| 莆田市| 四平市| 天津市| 香格里拉县| 报价| 灯塔市| 建始县| 莆田市| 阿坝县| 霍邱县| 五常市| 兰州市| 奇台县| 博野县| 大悟县| 民县| 泸州市| 铅山县| 静安区| 郴州市| 安顺市| 鄄城县| 天台县| 宝兴县| 姚安县| 正阳县| 天柱县| 洮南市| 遂宁市| 新密市| 察哈| 中阳县| 无极县| 泾阳县| 福贡县|