詳解記錄MySQL中l(wèi)ower_case_table_names的坑
1 起因
項目遷移數(shù)據(jù)庫, 重新啟動后, 報錯"T_AAA表不存在", 但數(shù)據(jù)庫中可以查看到該表并有數(shù)據(jù)
2 問題分析
通過重裝系統(tǒng)與數(shù)據(jù)庫, 確認系統(tǒng)與數(shù)據(jù)庫純凈, 排除系統(tǒng)和數(shù)據(jù)庫的原因
使用同一方式恢復兩天前和一天前的數(shù)據(jù)備份, 同樣不能啟動項目, 排除數(shù)據(jù)內(nèi)容的原因
使用mysqldump和導出SQL文件兩種方式, 恢復一天前的數(shù)據(jù), 同樣不能啟動項目, 排除恢復方式的原因
以上方式基本是運維人員參與, 等技術(shù)總監(jiān)參與觀察項目報錯后, 猛然發(fā)現(xiàn)是表名大小寫的問題, 通過測試最終確定原因:
使用rpm包安裝數(shù)據(jù)庫, 自動初始化時將lower_case_table_names設置為0, 表名大小寫敏感, 數(shù)據(jù)庫中為小寫, 代碼中為大寫
3 解決方案
- 刪除已初始化的數(shù)據(jù)庫, 即base_dir, data_dir等
- 重新初始化數(shù)據(jù)庫, 將lower_case_table_names設置為1
- 重新恢復備份數(shù)據(jù)
4 總結(jié)
MySQL8.0及以上版本, 只能在初始化的時候設置lower-case-table-names參數(shù), 無法通過修改my.cnf實現(xiàn)(在my.cnf中增加配置會報錯)
初始化數(shù)據(jù)庫不需要卸載整個MySQL重裝, 只需要使用mysqld命令即可
base_dir等用戶組應為mysql, linux下命令為:
chown -R mysql.mysql MySQL數(shù)據(jù)路徑(即base_dir)
linux下遞歸創(chuàng)建目錄
mkdir -p mysql/lib/mysql-files
MySQL重新初始化
mysqld -initialize --lower-case-table-names=1
MySQL8.0以上, 需要先創(chuàng)建用戶再賦權(quán)
create user 'test'@'%' identified by 'test'; -- with option 可以把權(quán)限賦予其它用戶 grant all privileges on test.* to 'test'@'%' with option;
到此這篇關(guān)于詳解記錄MySQL中l(wèi)ower_case_table_names的坑的文章就介紹到這了,更多相關(guān)MySQL lower_case_table_names內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
MySQL創(chuàng)建數(shù)據(jù)庫并支持中文字符的操作方法
這篇文章主要介紹了MySQL創(chuàng)建數(shù)據(jù)庫并支持中文字符的操作方法,本文給大家介紹的非常詳細,對大家的學習或工作具體一定的參考借鑒價值,需要的朋友可以參考下2021-01-01解決mysql創(chuàng)建數(shù)據(jù)庫后出現(xiàn):Access denied for user ''root''@''%'' to dat
這篇文章主要給大家介紹了如何解決mysql在創(chuàng)建數(shù)據(jù)庫后出現(xiàn):Access denied for user 'root'@'%' to database 'xxx'的錯誤提示,文中介紹的非常詳細,需要的朋友可以參考借鑒,下面來一起看看吧。2017-05-05MySQL系列之五 視圖、存儲函數(shù)、存儲過程、觸發(fā)器
視圖就是一條select語句執(zhí)行后返回的結(jié)果集;觸發(fā)器是與表有關(guān)的數(shù)據(jù)庫對象,在滿足定義條件時觸發(fā),并執(zhí)行觸發(fā)器中定義的語句集合;函數(shù)存儲著一系列sql語句,調(diào)用函數(shù)就是一次性執(zhí)行這些語句,而存儲過程就是一組可編程的函數(shù),需要的朋友可以參考下2021-07-07MySQL系列之十 MySQL事務隔離實現(xiàn)并發(fā)控制
今天的內(nèi)容就和大家聊一聊MySQL數(shù)據(jù)庫中關(guān)于MySQL事務隔離實現(xiàn)并發(fā)控制的問題,主要是基于鎖實現(xiàn)控制技術(shù)2021-07-07MySQL8.0/8.x忘記密碼更改root密碼的實戰(zhàn)步驟(親測有效!)
忘記root密碼的場景還是比較常見的,特別是自己搭的測試環(huán)境經(jīng)過好久沒用過時,很容易記不得當時設置的密碼,下面這篇文章主要給大家介紹了關(guān)于MySQL8.0/8.x忘記密碼更改root密碼的實戰(zhàn)步驟,親測有效!需要的朋友可以參考下2023-04-04解析mysql數(shù)據(jù)庫還原錯誤:(mysql Error Code: 1005 errno 121)
本篇文章是對mysql數(shù)據(jù)庫還原錯誤:(mysql Error Code: 1005 errno 121)的解決方法進行了詳細的分析介紹,需要的朋友參考下2013-06-06MySQL8.x登陸root用戶突然提示mysql_native_password的實現(xiàn)
本文主要介紹了MySQL 8.x登陸root用戶突然提示mysql_native_password,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2024-08-08