婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > MySQL大小寫敏感的注意事項

MySQL大小寫敏感的注意事項

熱門標簽:400電話變更申請 武漢電銷機器人電話 大豐地圖標注app 呂梁外呼系統 南太平洋地圖標注 html地圖標注并導航 400電話辦理服務價格最實惠 催天下外呼系統 北京金倫外呼系統

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

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

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

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,代表當前系統文件是否大小寫敏感,只讀參數,無法修改。ON 大小寫不敏感,OFF 大小寫敏感。

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

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

  • 0 大小寫敏感。(Unix,Linux默認) 創建的庫表將原樣保存在磁盤上。如create database TeSt;將會創建一個TeSt的目錄,create table AbCCC …將會原樣生成AbCCC.frm文件,SQL語句也會原樣解析。
  • 1 大小寫不敏感。(Windows默認) 創建的庫表時,MySQL將所有的庫表名轉換成小寫存儲在磁盤上。 SQL語句同樣會將庫表名轉換成小寫。 如需要查詢以前創建的Testtable(生成Testtable.frm文件),即便執行select * from Testtable,也會被轉換成select * from testtable,致使報錯表不存在。
  • 2 大小寫不敏感(OS X默認) 創建的庫表將原樣保存在磁盤上, 但SQL語句將庫表名轉換成小寫。

MySQL大小寫敏感如何設置

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

lower_case_table_names = 0 或 lower_case_table_names = 1

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

開發注意事項

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

總結

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

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

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

標簽:龍巖 南充 無錫 徐州 迪慶 自貢 麗水 西寧

巨人網絡通訊聲明:本文標題《MySQL大小寫敏感的注意事項》,本文關鍵詞  MySQL,大小寫,敏感,的,注意事項,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《MySQL大小寫敏感的注意事項》相關的同類信息!
  • 本頁收集關于MySQL大小寫敏感的注意事項的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 舟山市| 吉首市| 灵石县| 安福县| 璧山县| 阜平县| 襄城县| 鸡东县| 赞皇县| 南华县| 深水埗区| 库尔勒市| 达日县| 博罗县| 北辰区| 筠连县| 西城区| 田东县| 南安市| 安仁县| 金华市| 长阳| 诸城市| 武穴市| 离岛区| 昌吉市| 图木舒克市| 富平县| 驻马店市| 民勤县| 武功县| 桂林市| 辉南县| 南昌县| 富源县| 敦煌市| 保山市| 资阳市| 洞头县| 婺源县| 娄烦县|