亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

MySQL大小寫敏感的注意事項

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

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

【強制】表名、字段名必須使用小寫字母或數字 , 禁止出現數字開頭,禁止兩個下劃線中間只 出現數字。數據庫字段名的修改代價很大,因為無法進行預發(fā)布,所以字段名稱需要慎重考慮。

因此,數據庫名、 表名、字段名,都不允許出現任何大寫字母,避免引起不必要的麻煩。

MySQL的大小寫敏感是由參數控制的

mysql大小寫敏感配置相關的兩個參數,lower_case_file_system 和 lower_case_table_names。

查看當前mysql的大小寫敏感配置,可以使用如下語句

show global variables like '%lower_case%';

+------------------------+-------+
| Variable_name          | Value |
+------------------------+-------+
| lower_case_file_system | ON    |
| lower_case_table_names | 0     |
+------------------------+-------+

參數說明如下:

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

  • 此變量描述數據所在的操作系統(tǒng)的文件目錄是否區(qū)分大小寫。 OFF表示文件名區(qū)分大小寫,ON表示它們不區(qū)分大小寫。此變量是只讀的,因為它反映了文件系統(tǒng)的屬性,設置它對文件系統(tǒng)沒有影響。

2.lower_case_table_names,代表表名是否大小寫敏感,可以修改,參數有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將所有的庫表名轉換成小寫存儲在磁盤上。 SQL語句同樣會將庫表名轉換成小寫。 如需要查詢以前創(chuàng)建的Testtable(生成Testtable.frm文件),即便執(zhí)行select * from Testtable,也會被轉換成select * from testtable,致使報錯表不存在。
  • 2 大小寫不敏感(OS X默認) 創(chuàng)建的庫表將原樣保存在磁盤上, 但SQL語句將庫表名轉換成小寫。

MySQL大小寫敏感如何設置

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

lower_case_table_names = 0 或 lower_case_table_names = 1

然后重啟MySQL服務才可以生效。

開發(fā)注意事項

  • 如果要將lower_case_table_names從0(敏感)修改為1(不敏感)時,必須先對舊數據表的表名進行處理,把所有數據庫的表名先改為小寫,最后再設置lower_case_table_names為1,否則依然會出現無法找到表名的問題。
  • 在Windows上lower_case_table_names默認值為1(不敏感),在macOS上默認值為2(不敏感)。在Linux上不支持值2,服務器強制該值為0(敏感)。
  • 并且MySQL官方也提示說:如果在數據目錄駐留在不區(qū)分大小寫的文件系統(tǒng)(例如Windows或macOS)上,則不應將lower_case_table_names設置為0。
  • 否則將出現MySQL服務無法啟動的問題。

總結

由于操作系統(tǒng)不同導致大小寫敏感的默認設置不一致,我們在開發(fā)時一定要注意,應該養(yǎng)成嚴格的意識,SQL語句一律采用小寫字母,避免無意義的踩坑。

以上就是MySQL大小寫敏感的注意事項的詳細內容,更多關于MySQL大小寫敏感的資料請關注腳本之家其它相關文章!

相關文章

  • windows下Mysql多實例部署的操作方法

    windows下Mysql多實例部署的操作方法

    這篇文章主要介紹了windows下Mysql多實例部署,需要部署Mysql多個實例,原理很簡單,多個mysql服務運行使用不同的配置及數據管理,需要的朋友可以參考下
    2022-09-09
  • MySQL高級查詢示例詳細介紹

    MySQL高級查詢示例詳細介紹

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

    Navicat中新建MySQL數據庫與新建、修改、刪除數據表及刪除數據庫詳細操作方法

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

    mysql數據庫忘記管理員密碼的解決方法

    我們在Windows操作系統(tǒng)下編程會使用到MySQL數據庫。但是有時,我們會忘記數據庫的登錄密碼?當我們忘記了登錄密碼,無法進入mysql時,該怎么辦呢?這里我們提供mysql的登錄秘密的修改
    2018-02-02
  • 深入淺出的學習Mysql

    深入淺出的學習Mysql

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

    一次現場mysql重復記錄數據的排查處理實戰(zhàn)記錄

    這篇文章主要給大家介紹了一次現場mysql重復記錄數據的排查處理記錄,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2021-10-10
  • MySql三種避免重復插入數據的方法

    MySql三種避免重復插入數據的方法

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

    對比MySQL中int、char以及varchar的性能

    在本篇文章中我們給大家分享了關于MySQL中int、char以及varchar的性能對比的相關內容,有興趣的朋友們學習下。
    2018-10-10
  • MySQL外鍵關聯操作的實現

    MySQL外鍵關聯操作的實現

    本文主要介紹了MySQL外鍵關聯操作的實現,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2022-07-07
  • mysql無法啟動服務及其他問題總結

    mysql無法啟動服務及其他問題總結

    MySQL無法啟動,可能有多種原因導致,本文主要介紹了mysql無法啟動服務及其他問題總結,具有一定的參考價值,感興趣的可以了解一下
    2024-01-01

最新評論