亚洲精品久久久中文字幕-亚洲精品久久片久久-亚洲精品久久青草-亚洲精品久久婷婷爱久久婷婷-亚洲精品久久午夜香蕉

您的位置:首頁技術文章
文章詳情頁

詳解記錄MySQL中lower_case_table_names的坑

瀏覽:9日期:2023-10-05 10:46:18
1 起因

項目遷移數據庫, 重新啟動后, 報錯'T_AAA表不存在', 但數據庫中可以查看到該表并有數據

2 問題分析

通過重裝系統與數據庫, 確認系統與數據庫純凈, 排除系統和數據庫的原因使用同一方式恢復兩天前和一天前的數據備份, 同樣不能啟動項目, 排除數據內容的原因使用mysqldump和導出SQL文件兩種方式, 恢復一天前的數據, 同樣不能啟動項目, 排除恢復方式的原因

以上方式基本是運維人員參與, 等技術總監參與觀察項目報錯后, 猛然發現是表名大小寫的問題, 通過測試最終確定原因:使用rpm包安裝數據庫, 自動初始化時將lower_case_table_names設置為0, 表名大小寫敏感, 數據庫中為小寫, 代碼中為大寫

3 解決方案 刪除已初始化的數據庫, 即base_dir, data_dir等 重新初始化數據庫, 將lower_case_table_names設置為1 重新恢復備份數據4 總結

MySQL8.0及以上版本, 只能在初始化的時候設置lower-case-table-names參數, 無法通過修改my.cnf實現(在my.cnf中增加配置會報錯)

初始化數據庫不需要卸載整個MySQL重裝, 只需要使用mysqld命令即可

base_dir等用戶組應為mysql, linux下命令為:

chown -R mysql.mysql MySQL數據路徑(即base_dir)

linux下遞歸創建目錄

mkdir -p mysql/lib/mysql-files

MySQL重新初始化

mysqld -initialize --lower-case-table-names=1

MySQL8.0以上, 需要先創建用戶再賦權

create user ’test’@’%’ identified by ’test’;-- with option 可以把權限賦予其它用戶grant all privileges on test.* to ’test’@’%’ with option;

到此這篇關于詳解記錄MySQL中lower_case_table_names的坑的文章就介紹到這了,更多相關MySQL lower_case_table_names內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: MySQL 數據庫
相關文章:
主站蜘蛛池模板: 精品国产免费人成在线观看 | 最新亚洲精品国自产在线观看 | 亚洲欧洲日产国码二区在线 | 99久久精品国产免看国产一区 | 免费在线看黄网址 | 美女被免费网站在线视频九色 | 欧美高清一级 | 精品在线一区二区 | 欧美精品黄页在线观看大全 | 欧美三级成版人版在线观看 | 直接看的毛片 | 亚洲邪恶 | 91天堂一区二区 | 久久久综合视频 | 久久国产精品久久久久久久久久 | 99久久国语露脸精品国产 | 国产亚洲欧美日韩在线观看不卡 | 亚洲高清国产一区二区三区 | 国产精品性视频免费播放 | 麻豆福利视频 | 欧美美女一区二区三区 | 特黄特色大片免费高清视频 | 高清国产一级精品毛片基地 | 成年人免费黄色片 | 亚洲国产欧美日韩一区二区三区 | 国产亚洲精品aaa大片 | 久久精品丝袜 | 九九热精| 欧美激情大尺度做爰叫床声 | 国产毛片视频 | 国产亚洲精品久久 | 欧美午夜激情影院 | 成人一级大片 | 欧美一级毛片免费看 | 国产成人精品本亚洲 | 91新视频| 亚洲综合第一页 | 久草视频2 | 国产高清国产专区国产精品 | 麻豆视传媒短视频网站链接 | 最新国产美女一区二区三区 |