詳解記錄MySQL中l(wèi)ower_case_table_names的坑
項(xiàng)目遷移數(shù)據(jù)庫(kù), 重新啟動(dòng)后, 報(bào)錯(cuò)'T_AAA表不存在', 但數(shù)據(jù)庫(kù)中可以查看到該表并有數(shù)據(jù)
2 問(wèn)題分析通過(guò)重裝系統(tǒng)與數(shù)據(jù)庫(kù), 確認(rèn)系統(tǒng)與數(shù)據(jù)庫(kù)純凈, 排除系統(tǒng)和數(shù)據(jù)庫(kù)的原因使用同一方式恢復(fù)兩天前和一天前的數(shù)據(jù)備份, 同樣不能啟動(dòng)項(xiàng)目, 排除數(shù)據(jù)內(nèi)容的原因使用mysqldump和導(dǎo)出SQL文件兩種方式, 恢復(fù)一天前的數(shù)據(jù), 同樣不能啟動(dòng)項(xiàng)目, 排除恢復(fù)方式的原因
以上方式基本是運(yùn)維人員參與, 等技術(shù)總監(jiān)參與觀察項(xiàng)目報(bào)錯(cuò)后, 猛然發(fā)現(xiàn)是表名大小寫的問(wèn)題, 通過(guò)測(cè)試最終確定原因:使用rpm包安裝數(shù)據(jù)庫(kù), 自動(dòng)初始化時(shí)將lower_case_table_names設(shè)置為0, 表名大小寫敏感, 數(shù)據(jù)庫(kù)中為小寫, 代碼中為大寫
3 解決方案 刪除已初始化的數(shù)據(jù)庫(kù), 即base_dir, data_dir等 重新初始化數(shù)據(jù)庫(kù), 將lower_case_table_names設(shè)置為1 重新恢復(fù)備份數(shù)據(jù)4 總結(jié)MySQL8.0及以上版本, 只能在初始化的時(shí)候設(shè)置lower-case-table-names參數(shù), 無(wú)法通過(guò)修改my.cnf實(shí)現(xiàn)(在my.cnf中增加配置會(huì)報(bào)錯(cuò))
初始化數(shù)據(jù)庫(kù)不需要卸載整個(gè)MySQL重裝, 只需要使用mysqld命令即可
base_dir等用戶組應(yīng)為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)容請(qǐng)搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!
相關(guān)文章:
1. 影響SQL server性能的關(guān)鍵三個(gè)方面 2. ORACLE回滾段表空間數(shù)據(jù)文件丟失或損壞處理方法3. DB2數(shù)據(jù)庫(kù)更新執(zhí)行計(jì)劃的幾個(gè)常見(jiàn)的方法4. 淺談MySQL之select優(yōu)化方案5. SQL Server 2000之日志傳送功能 - 描述6. Mysql查詢優(yōu)化之IN子查詢優(yōu)化方法詳解7. MySQL 性能、監(jiān)控與災(zāi)難恢復(fù)8. MySQL配置主從服務(wù)器(一主多從)9. 如何在SQL Server中恢復(fù)數(shù)據(jù)10. DB2 9的九大新特性
