成人性生交大片免费看视频r_亚洲综合极品香蕉久久网_在线视频免费观看一区_亚洲精品亚洲人成人网在线播放_国产精品毛片av_久久久久国产精品www_亚洲国产一区二区三区在线播_日韩一区二区三区四区区区_亚洲精品国产无套在线观_国产免费www

主頁 > 知識庫 > MySQL大小寫敏感導(dǎo)致的問題分析

MySQL大小寫敏感導(dǎo)致的問題分析

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

MYSQL對大小寫敏感

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

之前看過阿里巴巴Java開發(fā)手冊,在MySql建表規(guī)約里有看到:

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

說明: MySQL 在 Windows 下不區(qū)分大小寫,但在 Linux 下默認(rèn)是區(qū)分大小寫。因此,數(shù)據(jù)庫名、 表名、字段名,都不允許出現(xiàn)任何大寫字母,避免節(jié)外生枝。

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

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

01 一個表字母大小故事

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

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

出現(xiàn)了問題,有點郁悶,本地開發(fā)好好的,怎么部署服務(wù)器就不行了。有鬼……不過莫慌??粗e誤提示很明顯,不就是tb_sutyHo 表不存在嗎!

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

②查看代碼發(fā)現(xiàn)代碼中還真把表名寫成tb_sutyHo ,就一個h寫成大寫H了。

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

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

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

于是就利用搜索引擎,發(fā)現(xiàn)Mysql中控制數(shù)據(jù)庫名和表名的大小寫敏感由參數(shù)lower_case_table_names控制。

在本機(jī)Window環(huán)境查看如下:

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

在Linux服務(wù)器查看如下:

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

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

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

lowercasefile_system

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

lowercasetable_names

該參數(shù)為靜態(tài),可設(shè)置為0、1、2。

0 --大小寫敏感。(Unix,Linux默認(rèn)) 創(chuàng)建的庫表將原樣保存在磁盤上。如create database TeSt;將會創(chuàng)建一個TeSt的目錄,create table AbCCC …將會原樣生成AbCCC.frm。 SQL語句也會原樣解析。

1 --大小寫不敏感。(Windows默認(rèn)) 創(chuàng)建的庫表時,MySQL將所有的庫表名轉(zhuǎn)換成小寫存儲在磁盤上。 SQL語句同樣會將庫表名轉(zhuǎn)換成小寫。 如需要查詢以前創(chuàng)建的Testtable(生成Testtable.frm文件),即便執(zhí)行select * from Testtable,也會被轉(zhuǎn)換成select * from testtable,致使報錯表不存在。

2 --大小寫不敏感(OS X默認(rèn)) 創(chuàng)建的庫表將原樣保存在磁盤上。 但SQL語句將庫表名轉(zhuǎn)換成小寫。

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上,默認(rèn)值為1。在macOS上,默認(rèn)值為2。在Linux上不支持值2;服務(wù)器強制該值為0。

并且官網(wǎng)也提示說:如果在數(shù)據(jù)目錄駐留在不區(qū)分大小寫的文件系統(tǒng)(例如Windows或macOS)上的系統(tǒng)上運行MySQL,則不應(yīng)將lowercasetable_names設(shè)置為0。

我自己在我的window10環(huán)境嘗試設(shè)置lower_case_table_names為0的時候,MySQL的服務(wù)怎么也啟動不能,啟動服務(wù)報錯。windows系統(tǒng)對大小寫不敏感,見下圖:

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

02 注意事項

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

首先設(shè)置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   |
+----------------+

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

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

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

解決方法:如果要將默認(rèn)的lower_case_tables_name為0設(shè)置成1,需先將已經(jīng)存在的庫表名轉(zhuǎn)換為小寫。

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

①、lower_case_tables_name=0時,執(zhí)行rename table成小寫。

②、設(shè)置lower_case_tables_name=1,重啟生效。

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

①、lower_case_tables_name=0時,使用mysqldump導(dǎo)出,并刪除老的數(shù)據(jù)庫。

②、設(shè)置lower_case_tables_name=1,重啟生效。

③、導(dǎo)入數(shù)據(jù)至實例,此時包含大寫字母的庫名已轉(zhuǎn)換為小寫。

03 總結(jié)

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

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

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

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《MySQL大小寫敏感導(dǎo)致的問題分析》,本文關(guān)鍵詞  MySQL,大小寫,敏感,導(dǎo)致,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《MySQL大小寫敏感導(dǎo)致的問題分析》相關(guān)的同類信息!
  • 本頁收集關(guān)于MySQL大小寫敏感導(dǎo)致的問題分析的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    在线播放91灌醉迷j高跟美女| 97视频久久久| 综合久久国产九一剧情麻豆| 91精品国自产在线| 在线观看黄色av| 四虎国产精品永久免费观看视频| 91国自产精品中文字幕亚洲| av在线播放天堂| 91免费精品视频| 亚洲高清一区二区三区| 国产黄a三级三级看三级| 成年男人的天堂| 久久久久久精| 91香蕉视频在线播放| 成人在线免费观看一区| 国产精品极品| www.色综合.com| 亚洲大尺度网站| 在线观看私人影院w| 国产主播在线资源| 久久视频在线| 日韩你懂的在线观看| 国产精品免费看久久久无码| 国产又黄又大又爽| 看成年女人免费午夜视频| eeuss影院eeuss最新直达| 手机在线免费看片| 男人添女人下面免费视频| 女生裸体视频网站免费观看| 成人在线app| 成人18精品视频| 高h视频免费观看| 久久久久久久久久久久久久久久av| 欧美日韩国产免费一区二区| 国产精品视频免费在线| 国产又粗又猛又爽视频| 日本在线一区二区三区| 国产精品免费观看在线| 欧美一级二级三级视频| 蜜桃av在线| 久久网这里都是精品| 成人午夜两性视频| 色婷婷中文字幕| 美女露胸一区二区三区| 韩国福利一区| 成人看片网站| 污污网站在线观看| 在线精品国精品国产尤物884a| 最近中文字幕在线mv视频在线| 国产三级国产精品国产专区50| 美女在线观看视频一区二区| 亚洲色图欧美| 成人一二三区| 久久九九精品99国产精品| 日韩免费高清在线观看| 熟女丰满老熟女熟妇| 性色视频在线| 久久一区二区三区超碰国产精品| 久久草在线视频| 色播视频在线观看| 久久久久久亚洲中文字幕无码| 亚洲黄色三级| 图片区小说区区亚洲影院| 久久久久国产精品夜夜夜夜夜| 日韩女优电影在线观看| 日韩在线综合| 欧美日韩一区中文字幕| 亚洲黄色小视频在线观看| 极品白嫩丰满美女无套| 久久久久久久久久久91| 污视频在线播放| av大大超碰在线| 全部孕妇毛片丰满孕妇孕交| 内射中出日韩无国产剧情| 天天干天天插天天操| 天天干天天摸天天操| 日韩精品免费视频一区二区三区| 久久精品无码中文字幕| 国产精品久久久久久久小唯西川| 日韩精品福利网| 国产美女久久久久久| √新版天堂资源在线资源| 国产精品免费在线播放| 国产成人三级| 裸体素人女欧美日韩| 国产一区二区三区视频播放| 欧美精品在线视频观看| 国产精品视频一二三四区| 亚洲精品成人久久久998| 久久青青草综合| av大片在线免费观看| 夜夜揉揉日日人人青青一国产精品| 欧美一区二区三区四区久久| 亚洲欧洲美洲在线综合| 美女毛片在线看| 亚洲精品suv精品一区二区| 国产素人视频在线观看| 久久久久久高清| 欧美精品一区二区三区在线看午夜| 午夜视频一区二区| 色老头在线视频| 夜夜嗨av一区二区三区| 国产大学生校花援交在线播放| 久久不射2019中文字幕| 国产成人高清精品| 久久亚洲国产中v天仙www| 亚洲av无码专区在线| 欧美jiizzhd精品欧美| 99久久精品免费观看国产| 日韩亚洲精品在线观看| 欧美精品99| 性欧美丰满熟妇xxxx性仙踪林| 先锋影音男人| 樱桃视频在线观看一区| 日本三级中文字幕在线观看| 亚洲一区二区三区午夜| 69亚洲精品久久久蜜桃小说| 最近中文字幕在线中文高清版| 精品国产一区二区三区久久狼5月| 1234区中文字幕在线观看| 久久久久久有精品国产| 欧美丝袜一区二区三区| 欧美日韩卡一卡二| 亚洲欧美日韩中文播放| www.超碰在线观看| 国产精品videossex撒尿| 日韩欧美国产wwwww| 国产剧情一区在线| 久久久蜜臀国产一区二区| 一区二区三区四区视频精品免费| 日本成人不卡| 色噜噜狠狠色综合欧洲selulu| 视频在线一区二区三区| 国产午夜视频在线播放| 久久精品一区二区国产| 国产丝袜一区二区| 亚洲7777| 日韩午夜在线观看| 全黄一级裸体片| 国产精品一区二区视频| 欧美激情在线看| 国产精品黄色在线观看| 国产中文字字幕乱码无限| 色先锋最新资源| 午夜黄色一级片| 最近中文字幕在线mv视频在线| 成人免费性视频| 成视频在线观看免费观看| 欧美一级特黄aaaaaa在线看片| 午夜久久久久久久久久一区二区| 欧美精品观看| yy1111111| 6080成人| 黄网在线观看网址入口| 亚洲一区二区三区视频在线播放| 欧美在线首页| 99国产精品私拍| 色婷婷精品大在线视频| 日本视频免费高清一本18| 一区二区三区四区不卡在线| 亚洲曰本av电影| 中文字幕一区二区精品区| 麻豆视频一区二区| 国产日产在线观看| 亚欧洲精品在线视频| 视频在线99re| av不卡高清| 日韩欧美综合在线视频| 日韩激情在线观看| 欧美婷婷久久| 精品国产乱码久久久久久蜜臀网站| 亚洲黄页网站| 日本vs亚洲vs韩国一区三区| 高清毛片在线看| 97久久精品人人做人人爽| 玖玖爱这里只有精品| 色8久久精品久久久久久蜜| 精品国产乱码久久久久久蜜柚| 亚洲午夜电影在线| 成人日韩精品| 红桃视频成人在线观看| 日本福利片在线观看| 6080亚洲理论片在线观看| 中文字幕视频免费在线观看| 精品成人久久久| 欧美日韩国产在线观看网站| 久久久久免费精品国产| 中文在线аv在线| 91精品国产91久久久久游泳池| 精品久久久亚洲| www.黄色一片| 国产一级aa大片毛片| 阿v免费在线观看| www成人啪啪18软件| 欧美日韩性生活视频| 韩国理伦片久久电影网| 国产欧美日韩中文久久| 香蕉视频一区二区| 日本欧美国产在线| 奇米4444一区二区三区| 成人精品一区二区三区校园激情| 久久精品2019中文字幕| 青草国产精品久久久久久| 久久人人97超碰人人澡爱香蕉| 日本欧美中文字幕| 久久久国产精品午夜一区ai换脸| 中文字幕久精品免费视频| 欧美中文字幕一区二区三区| 国产精品成人一区二区艾草| 黄色性视频网站| 欧美一区二区三区粗大| 免费在线观看亚洲视频| 国产精品xxxav免费视频| 成人免费xxxxx在线观看| av免费网站在线| 成人看av片| 26uuu另类欧美亚洲曰本| 精品国产免费人成在线观看| 国产视频中文字幕在线观看| 黄页网址大全在线观看| 欧美福利网站| 亚洲欧美日本另类| 十大黄色软件免费看| 无码专区aaaaaa免费视频| 2019中文字幕免费视频| 久久婷婷综合中文字幕| 欧洲av无码放荡人妇网站| 一级黄色录像毛片| 国产一区二区黑人欧美xxxx| 日韩国产欧美在线观看| 欧美色图另类图片| 99精品国产91久久久久久| 毛片在线看片| 日韩一区二区免费看| 国产91一区二区三区| 亚洲精品写真福利| 欧美精品一区二区三区三州| 久久视频免费在线播放| 国产精品丝袜xxxxxxx| 国产九九精品视频| 欧美精品xxxxbbbb| 韩国成人av| 久久99亚洲热视| 亚洲国产精品99久久久久久久久| 久久精品一偷一偷国产| 欧美天天综合色影久久精品| 日韩视频在线直播| 丁香婷婷综合网| 亚洲精品97久久| 99久久精品日本一区二区免费| 国产精品一区二区a| 午夜在线视频| 尤物在线观看一区| 久久久最新网址| 香蕉视频一区二区三区| 国产欧美精品一区aⅴ影院| www.我爱av| 1024视频在线| 性欧美video另类hd3| 无码人中文字幕| 欧美日韩一区国产| 一色屋色费精品视频在线观看| 亚洲成在人线在线播放| 国产亚洲福利| 精品va天堂亚洲国产| 成人性生交大片免费看网站| 中国人xxxxx69免费视频| 爱情岛论坛亚洲品质自拍视频网站| 欧美精品一二| 91.麻豆视频| 亚洲国产日韩一级| 久久精品一区二区国产| 欧美色图国产精品| 久久久久网址| 99精品美女视频在线观看热舞| 国产理论在线| 五月开心六月丁香综合色啪| 欧美激情综合色综合啪啪五月| 国产伦精品一区二区三区免费迷| 亚洲欧洲精品一区二区| 亚洲成人在线网| 精品视频123区在线观看| 在线能看的av| 亚洲精品日韩激情在线电影| 亚洲影视资源| 在线永久免费观看黄网站| 久久狠狠一本精品综合网| 亚洲精品推荐| 中国女人真人一级毛片| 无码人妻少妇伦在线电影| 精品1卡二卡三卡四卡老狼| 91麻豆精品国产91久久久| 国产日韩一区二区| 国产乱理伦片在线观看夜一区| 丁香花在线电影小说观看| 国产麻豆一精品一av一免费| 国产91精品久| 激情小说一区| 欧美18一19xxx性| 91av免费| 女仆av观看一区| 日本韩国欧美三级| 国产一级片在线播放| 免费人成在线观看视频播放| 先锋影音欧美性受| 午夜精品久久久久久毛片| 欧美精品久久久久久久免费观看| 8x8ⅹ国产精品一区二区二区| 日本中文字幕久久| 欧美一区二区三区四区五区六区| 97视频热人人精品免费| 精品一区二区三区视频| 欧美极品一区| 91久久久久| 成人av在线不卡| 欧美一级黄视频| 成人激情视频免费在线| 国产欧美激情| 在线观看美女网站大全免费| 国产亚洲婷婷免费| 国产亚洲毛片在线| 91sao在线观看国产| 白白色免费视频| 久久亚洲二区| 欧美日韩伦理| 国产麻豆免费视频| 欧美精品一区二区三区国产精品| 国产999精品久久久影片官网|