欧美阿v视频在线大全_亚洲欧美中文日韩V在线观看_www性欧美日韩欧美91_亚洲欧美日韩久久精品

主頁 > 知識庫 > MySQL大小寫敏感導致的問題分析

MySQL大小寫敏感導致的問題分析

熱門標簽:中國地圖標注公司 電話機器人的價格多少錢一個月 福建外呼電銷機器人加盟 百度地圖標注要什么軟件 400電話申請廠家現貨 徐涇鎮騰訊地圖標注 自己做地圖標注需要些什么 天津公司外呼系統軟件 昌德訊外呼系統

MYSQL對大小寫敏感

見字如面,見標題知內容。你有遇到過因為MYSQL對大小寫敏感而被坑的體驗嗎?

之前看過阿里巴巴Java開發手冊,在MySql建表規約里有看到:

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

說明: MySQL 在 Windows 下不區分大小寫,但在 Linux 下默認是區分大小寫。因此,數據庫名、 表名、字段名,都不允許出現任何大寫字母,避免節外生枝。

正例: aliyun _ admin , rdc _ config , level 3_ name 反例: AliyunAdmin , rdcConfig , level 3 name

如果沒有真正遇到過類似的問題,有時候干巴巴的看這些規約體會不深,理解起來似懂非懂,并且也只是死記硬背而已。

01 一個表字母大小故事

最近自己在鼓搗一個項目玩玩,在自己本機上開發和測試過程中一直沒有問題,但是部署到Linux服務器上后,發現有報錯,日志信息大概是:

MySQLSyntaxErrorException: Table 'kytu.tb_sutyHo' doesn't exist

出現了問題,有點郁悶,本地開發好好的,怎么部署服務器就不行了。有鬼……不過莫慌。看著錯誤提示很明顯,不就是tb_sutyHo 表不存在嗎!

①于是我不慌不忙打開nv(navicat),查看這個表在不在,一看還真在,數據庫中顯示的tb_sutyho ,不過h是小寫;

②查看代碼發現代碼中還真把表名寫成tb_sutyHo ,就一個h寫成大寫H了。

問題找到了,原來是不小心寫SQL的時候沒有寫對表名,改一下表名就搞定了,功能也一切正常了。一般情況下故事到這里也就應該結束了?問題找到了,也修復了,萬事大吉了,稍后就可以吃雞了。

對于不會玩吃雞的我,到這里并沒有結束,找到問題和解決問題的確很重要,但是找到問題出現的根源更重要,這樣就能在下次規避此類問題,作為一個程序員不要兩次掉入一個坑里。

我在想這個問題,本地Window環境怎么就一直沒有出現這個報錯提示呢?非要等我部署服務器才出現,這到底是什么問題?(如果你對Mysql大小敏感很了解,以下內容可以跳過….)

于是就利用搜索引擎,發現Mysql中控制數據庫名和表名的大小寫敏感由參數lower_case_table_names控制。

在本機Window環境查看如下:

mysql> show variables like '%case%';
+------------------------+-------+
| Variable_name   | Value |
+------------------------+-------+
| lower_case_file_system | ON |
| lower_case_table_names | 1  |
+------------------------+-------+

在Linux服務器查看如下:

mysql> show variables like '%case%';
+------------------------+-------+
| Variable_name   | Value |
+------------------------+-------+
| lower_case_file_system | OFF |
| lower_case_table_names | 0  |
+------------------------+-------+

從上面的結果已經可以看出不同了,然而對這兩個參數還沒有感覺,不知道具體是什么意思。

在介紹lower_case_table_names的時候,順便也說一下lower_case_file_system。

lowercasefile_system

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

lowercasetable_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語句將庫表名轉換成小寫。

On Windows the default value is 1. On macOS, the default value is 2. On Linux, a value of 2 is not supported; the server forces the value to 0 instead.

在Windows上,默認值為1。在macOS上,默認值為2。在Linux上不支持值2;服務器強制該值為0。

并且官網也提示說:如果在數據目錄駐留在不區分大小寫的文件系統(例如Windows或macOS)上的系統上運行MySQL,則不應將lowercasetable_names設置為0。

我自己在我的window10環境嘗試設置lower_case_table_names為0的時候,MySQL的服務怎么也啟動不能,啟動服務報錯。windows系統對大小寫不敏感,見下圖:

注: 如果要修改lower_case_table_names這個值,windows下修改my.ini ,Linux下修改my.cnf配置文件,需要重啟服務,具體操作可以自行上網找資料。

02 注意事項

修改lowercasetable_names導致的常見不良隱患: 如果在lower_case_table_names=0時,創建了含有大寫字母的庫表,改為lower_case_table_names=1后,則會無法被查到。

首先設置lower_case_table_names=0

CREATE TABLE `Student` (
 `id` int(11) unsigned NOT NULL AUTO_INCREMENT,
 `name` varchar(25) NOT NULL,
 PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;

show tables;
+----------------+
| Tables_in_aflyun |
+----------------+
| Student   |
+----------------+

再設置lower_case_table_names=1,執行查詢,不管表名是大寫還是小寫,都提示表不存在。

mysql> select * from Student;
1146 - Table 'aflyun.Student' doesn't exist

mysql> select * from student;
1146 - Table 'aflyun.student' doesn't exist

解決方法:如果要將默認的lower_case_tables_name為0設置成1,需先將已經存在的庫表名轉換為小寫。

針對僅表名存在大寫字母的情況:

①、lower_case_tables_name=0時,執行rename table成小寫。

②、設置lower_case_tables_name=1,重啟生效。

針對庫名存在大寫字母的情況:

①、lower_case_tables_name=0時,使用mysqldump導出,并刪除老的數據庫。

②、設置lower_case_tables_name=1,重啟生效。

③、導入數據至實例,此時包含大寫字母的庫名已轉換為小寫。

03 總結

有了踩坑的經驗,對開頭說的阿里Mysql規約理解更加深入了。操作系統不同導致大小寫敏感不一致。我們在開發時,應該按大小寫敏感的原則去開發,這樣可以使開發的程序兼容不同的操作系統。因此,建議在開發測試環境下把lower_case_table_names的值設為0,便于在開發中就嚴格控制代碼大小寫敏感,提高代碼的兼容和嚴謹。

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

標簽:昌都 北京 鄂爾多斯 陜西 駐馬店 黔西 荊門 梅河口

巨人網絡通訊聲明:本文標題《MySQL大小寫敏感導致的問題分析》,本文關鍵詞  MySQL,大小寫,敏感,導致,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《MySQL大小寫敏感導致的問題分析》相關的同類信息!
  • 本頁收集關于MySQL大小寫敏感導致的問題分析的相關信息資訊供網民參考!
  • 推薦文章
    欧美阿v视频在线大全_亚洲欧美中文日韩V在线观看_www性欧美日韩欧美91_亚洲欧美日韩久久精品
  • <rt id="w000q"><acronym id="w000q"></acronym></rt>
  • <abbr id="w000q"></abbr>
    <rt id="w000q"></rt>
    波多野结衣不卡视频| 国产精品久久久久三级| 亚洲国产精品欧美一二99| www.性欧美| www.av成人| 中文字幕精品在线不卡| 国产毛片一区二区| 免费一级黄色录像| 26uuu久久综合| 美女诱惑一区二区| 我和岳m愉情xxxⅹ视频| 日韩精品一区二区三区中文精品| 午夜视频一区在线观看| 欧美久久久久久久久久久| 欧美亚洲一区三区| 夜夜操天天操亚洲| 特种兵之深入敌后| 欧美日韩一区在线| 亚洲动漫第一页| 日韩av无码一区二区三区不卡 | 国产伦精品一区二区三区视频青涩| 免费看污黄网站在线观看| 欧美mv日韩mv国产| 国产一区二区在线视频| www.com.av| 成人免费在线播放视频| 91免费在线看| 在线电影一区二区三区| 日韩精品一二三区| www.中文字幕av| 久久久不卡网国产精品一区| 国产麻豆精品久久一二三| 老熟妇高潮一区二区三区| 最新欧美精品一区二区三区| 99久久精品久久久久久清纯| 欧美午夜视频网站| 五月天久久比比资源色| 亚洲成人网在线播放| 国产网红主播福利一区二区| 国产a久久麻豆| 欧洲日韩一区二区三区| 日日噜噜夜夜狠狠视频欧美人| 波多野结衣 在线| 亚洲国产精品二十页| aaa欧美日韩| 91精品国产一区二区| 九一九一国产精品| 三级影片在线看| 亚洲成人动漫在线观看| 亚洲精品91在线| 亚洲美女在线一区| av在线网站观看| 国产精品美女久久久久久久久久久 | 麻豆一区二区三区| 日本裸体美女视频| 亚洲国产精品综合小说图片区| 99久久久久久久久久| 国产精品欧美久久久久无广告| 男插女视频网站| 2023国产精品| 91在线一区二区| 日韩精品综合一本久道在线视频| 国产成人免费在线视频| 欧美日韩在线三级| 国内精品国产三级国产a久久| 在线观看亚洲a| 麻豆免费精品视频| 91成人在线免费观看| 免费在线观看成人| 色一情一伦一子一伦一区| 日本亚洲一区二区| 成人观看免费视频| 老司机一区二区| 日本久久电影网| 久久99精品久久久久| 在线视频一区二区三| 久久精品国产免费看久久精品| 色94色欧美sute亚洲线路二| 久久精品999| 欧美日韩亚洲国产综合| 国产精品资源在线观看| 91麻豆精品国产无毒不卡在线观看 | 中国xxxx性xxxx产国| 国产精品乱码人人做人人爱| 无码人妻aⅴ一区二区三区| 1000精品久久久久久久久| 国精产品一区二区三区| 亚洲午夜精品一区二区三区他趣| 亚洲人与黑人屁股眼交| 青青草91视频| 欧美日韩高清在线播放| 成人精品在线视频观看| 337p日本欧洲亚洲大胆色噜噜| 国产a级片视频| 综合电影一区二区三区 | 三级精品在线观看| 色哟哟在线观看一区二区三区| 久久99久久99精品免视看婷婷 | v8888av| 亚洲二区在线观看| 在线一区二区三区四区五区| 国产成人亚洲综合色影视| 日韩免费在线观看| www.555国产精品免费| 亚洲色图欧美偷拍| 秋霞欧美一区二区三区视频免费| 麻豆高清免费国产一区| 91精品国产乱| 91av免费观看| 亚洲青青青在线视频| 国内毛片毛片毛片毛片毛片| 另类成人小视频在线| 日韩欧美在线不卡| 艳妇乳肉豪妇荡乳xxx| 亚洲综合清纯丝袜自拍| 色呦呦网站一区| 成人av在线播放网站| 国产偷国产偷精品高清尤物 | 人妻丰满熟妇aⅴ无码| 亚洲成a人片综合在线| 欧美揉bbbbb揉bbbbb| 99re这里只有精品视频首页| 国产精品视频免费| 免费成人美女女在线观看| 国产一区二区美女诱惑| 久久久亚洲精品石原莉奈| 中文字字幕码一二三区| 麻豆91在线看| 欧美成人高清电影在线| 毛茸茸多毛bbb毛多视频| 日产国产高清一区二区三区 | 制服丝袜成人动漫| 美女搡bbb又爽又猛又黄www| 亚洲成av人片在线观看无码| 欧美日韩黄色影视| av av在线| 午夜精品福利久久久| 制服丝袜在线91| 欧美一区二区三区成人精品| 美女尤物国产一区| 久久亚洲免费视频| 免费观看特级毛片| 成人免费视频视频在线观看免费 | 国产成人精品无码免费看夜聊软件| 日本不卡不码高清免费观看| 日韩精品一区国产麻豆| 91麻豆精品国产91久久综合| 国产精品99久久久久久久vr | 国产免费成人在线视频| 国产在线观看免费视频软件| 成人免费黄色在线| 亚洲精品日韩一| 欧美精选一区二区| 极品粉嫩小仙女高潮喷水久久| 久久99热狠狠色一区二区| 国产欧美精品区一区二区三区| 在线免费日韩av| 中文字幕在线国产| 美女www一区二区| 欧美国产精品中文字幕| 色婷婷精品大视频在线蜜桃视频| 日本50路肥熟bbw| 麻豆国产精品一区二区三区| 中文字幕av一区 二区| 欧美性猛片aaaaaaa做受| 日韩综合第一页| 国内精品第一页| 亚洲裸体在线观看| 日韩欧美亚洲另类制服综合在线 | 日韩二区在线观看| 久久久精品黄色| 色诱视频网站一区| 屁屁影院国产第一页| 国产一区二区三区黄视频| 亚洲精品亚洲人成人网在线播放| 欧美日韩精品综合在线| 亚洲а∨天堂久久精品2021| 成人免费看黄yyy456| 天堂精品中文字幕在线| 国产亚洲欧美激情| 欧美午夜片在线观看| 亚洲综合欧美综合| 91在线观看下载| 免费成人你懂的| ●精品国产综合乱码久久久久| 日韩一区二区在线播放| 国精产品一区一区二区三区mba| 少妇献身老头系列| 国产一区999| 亚洲成av人影院| 国产精品久久久一区麻豆最新章节| 精品视频1区2区3区| 中文字幕第69页| 秘密基地免费观看完整版中文 | 中文字幕一区二区三区在线播放 | 偷偷色噜狠狠狠狠的777米奇| 国产另类ts人妖一区二区| 亚洲美女淫视频| 国产亚洲短视频| 制服丝袜在线91|