欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

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

 更新時(shí)間:2021年05月24日 10:11:28   作者:尹洪亮Kevin  
MySQL 在 Windows 下不區(qū)分大小寫(xiě),但在 Linux 下默認(rèn)是區(qū)分大小寫(xiě)。如果你稍加不注意就會(huì)出現(xiàn)在本機(jī)開(kāi)發(fā)的程序運(yùn)行一切正常,發(fā)布到服務(wù)器行就出現(xiàn)表名找不到的問(wèn)題,一頭霧水。

由于這個(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)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • windows下Mysql多實(shí)例部署的操作方法

    windows下Mysql多實(shí)例部署的操作方法

    這篇文章主要介紹了windows下Mysql多實(shí)例部署,需要部署Mysql多個(gè)實(shí)例,原理很簡(jiǎn)單,多個(gè)mysql服務(wù)運(yùn)行使用不同的配置及數(shù)據(jù)管理,需要的朋友可以參考下
    2022-09-09
  • MySQL高級(jí)查詢(xún)示例詳細(xì)介紹

    MySQL高級(jí)查詢(xún)示例詳細(xì)介紹

    這篇文章主要介紹了MySQL高級(jí)查詢(xún)示例,在面試過(guò)程中經(jīng)常會(huì)遇到sq查詢(xún)問(wèn)題,今天小編通過(guò)本文給大家介紹下MySQL高級(jí)查詢(xún)語(yǔ)法分析,感興趣的朋友跟隨小編一起看看吧
    2023-02-02
  • Navicat中新建MySQL數(shù)據(jù)庫(kù)與新建、修改、刪除數(shù)據(jù)表及刪除數(shù)據(jù)庫(kù)詳細(xì)操作方法

    Navicat中新建MySQL數(shù)據(jù)庫(kù)與新建、修改、刪除數(shù)據(jù)表及刪除數(shù)據(jù)庫(kù)詳細(xì)操作方法

    Navicat是一套快速、可靠并價(jià)格相當(dāng)便宜的數(shù)據(jù)庫(kù)管理工具,專(zhuān)為簡(jiǎn)化數(shù)據(jù)庫(kù)的管理及降低系統(tǒng)管理成本而設(shè),這篇文章主要給大家介紹了關(guān)于Navicat中新建MySQL數(shù)據(jù)庫(kù)與新建、修改、刪除數(shù)據(jù)表及刪除數(shù)據(jù)庫(kù)詳細(xì)操作的相關(guān)資料,需要的朋友可以參考下
    2023-11-11
  • mysql數(shù)據(jù)庫(kù)忘記管理員密碼的解決方法

    mysql數(shù)據(jù)庫(kù)忘記管理員密碼的解決方法

    我們?cè)赪indows操作系統(tǒng)下編程會(huì)使用到MySQL數(shù)據(jù)庫(kù)。但是有時(shí),我們會(huì)忘記數(shù)據(jù)庫(kù)的登錄密碼?當(dāng)我們忘記了登錄密碼,無(wú)法進(jìn)入mysql時(shí),該怎么辦呢?這里我們提供mysql的登錄秘密的修改
    2018-02-02
  • 深入淺出的學(xué)習(xí)Mysql

    深入淺出的學(xué)習(xí)Mysql

    最近看了一本小書(shū),網(wǎng)易技術(shù)部的《深入淺出MySQL數(shù)據(jù)庫(kù)開(kāi)發(fā)、優(yōu)化與管理維護(hù)》,算是回顧一下mysql基礎(chǔ)知識(shí)。下面這篇文章主要介紹了學(xué)習(xí)Mysql的相關(guān)資料,需要的朋友可以參考借鑒,下面來(lái)一起看看吧。
    2017-02-02
  • 一次現(xiàn)場(chǎng)mysql重復(fù)記錄數(shù)據(jù)的排查處理實(shí)戰(zhàn)記錄

    一次現(xiàn)場(chǎng)mysql重復(fù)記錄數(shù)據(jù)的排查處理實(shí)戰(zhàn)記錄

    這篇文章主要給大家介紹了一次現(xiàn)場(chǎng)mysql重復(fù)記錄數(shù)據(jù)的排查處理記錄,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2021-10-10
  • MySql三種避免重復(fù)插入數(shù)據(jù)的方法

    MySql三種避免重復(fù)插入數(shù)據(jù)的方法

    這篇文章主要介紹了MySql三種避免重復(fù)插入數(shù)據(jù)的方法,幫助大家更好的理解和使用MySQL數(shù)據(jù)庫(kù),感興趣的朋友可以了解下
    2020-09-09
  • 對(duì)比MySQL中int、char以及varchar的性能

    對(duì)比MySQL中int、char以及varchar的性能

    在本篇文章中我們給大家分享了關(guān)于MySQL中int、char以及varchar的性能對(duì)比的相關(guān)內(nèi)容,有興趣的朋友們學(xué)習(xí)下。
    2018-10-10
  • MySQL外鍵關(guān)聯(lián)操作的實(shí)現(xiàn)

    MySQL外鍵關(guān)聯(lián)操作的實(shí)現(xiàn)

    本文主要介紹了MySQL外鍵關(guān)聯(lián)操作的實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2022-07-07
  • mysql無(wú)法啟動(dòng)服務(wù)及其他問(wèn)題總結(jié)

    mysql無(wú)法啟動(dòng)服務(wù)及其他問(wèn)題總結(jié)

    MySQL無(wú)法啟動(dòng),可能有多種原因?qū)е?本文主要介紹了mysql無(wú)法啟動(dòng)服務(wù)及其他問(wèn)題總結(jié),具有一定的參考價(jià)值,感興趣的可以了解一下
    2024-01-01

最新評(píng)論