Linux環(huán)境下設(shè)置MySQL表名忽略大小寫的方法小結(jié)
說明
本文檔適用于docker容器運(yùn)行的MySQL,修改MySQL表名忽略大小寫。
一、摘要
在MySQL中,表名的大小寫敏感性取決于操作系統(tǒng)和MySQL的配置。在Unix/Linux系統(tǒng)上,表名通常是區(qū)分大小寫的,而在Windows系統(tǒng)上則通常是不區(qū)分大小寫的。由于之前MySQL未設(shè)置忽略表名大小寫導(dǎo)致數(shù)據(jù)查詢失敗等問題。
二、查看服務(wù)器上MySQL情況
方式一:通過Linux方式
查看MySQL是否忽略了表名大小寫,先登錄MySQL(mysql -uroot -p),再通過命令查看目前MySQL忽略表名的情況(SHOW VARIABLES like "lower_case_table_names";)
方式二:借助可視化工具(Navicat)
連上服務(wù)器上對(duì)應(yīng)的MySQL服務(wù),新建查詢,如下圖所示:
三、MySQL設(shè)置忽略表名大小寫的參數(shù)(lower_case_table_names)
lower_case_table_names
可以設(shè)置為以下三個(gè)值之一:
0:區(qū)分大小寫。數(shù)據(jù)庫(kù)和表名在存儲(chǔ)和比較時(shí)都區(qū)分大小寫。在 Unix 和 Linux 系統(tǒng)上,這是默認(rèn)值。
1:不區(qū)分大小寫。數(shù)據(jù)庫(kù)和表名在存儲(chǔ)和比較時(shí)都不區(qū)分大小寫。在 Windows 系統(tǒng)上,這是默認(rèn)值。但請(qǐng)注意,即使設(shè)置為 1,在某些情況下(如使用 InnoDB
存儲(chǔ)引擎和 CREATE TABLE
語(yǔ)句中的引號(hào)),MySQL 仍然可能區(qū)分大小寫。
2:表名在存儲(chǔ)時(shí)區(qū)分大小寫,但在比較時(shí)不區(qū)分。這個(gè)設(shè)置很少使用,因?yàn)樗赡軐?dǎo)致混淆和不一致的行為。
注意:在安裝MySQL過程中,只有在初始化的MySQL情況下,更改lower_case_table_names的值。
四、網(wǎng)上解決方案
方法一:只修改my.cnf
1.添加lower_case_table_names=1
在服務(wù)器上找到my.conf文件,由于我是采取docker compose部署的MySQL,因此修改MySQL的配置文件后啟動(dòng)方式因自己安裝的方式而異。
#忽略表名大小寫 lower_case_table_names=1
在 [mysqld] 部分新增
2.保存并退出
3.重啟MySQL
問題:
問題描述:Different lower_case_table_names settings for server ('1') and data dictionary ('0').
出現(xiàn)問題是在重啟MySQL容器的時(shí)候報(bào)錯(cuò)。
方法二:臨時(shí)設(shè)置
注:重啟MySQL會(huì)失效
1.登錄MySQL
2.設(shè)置lower_case_table_names
SET GOLBAL lower_case_table_names = 1;
3.刷新權(quán)限
FLUSH PRIVILEGES;
問題:
1238 - Variable 'lower_case_table_names' is a read only variable
lower_case_table_names
是一個(gè)只讀的系統(tǒng)變量,這意味著你不能在 MySQL 服務(wù)器運(yùn)行時(shí)動(dòng)態(tài)地更改它的值。這個(gè)變量必須在 MySQL 服務(wù)器啟動(dòng)時(shí)從配置文件(通常是 my.cnf
或 my.ini
,取決于你的操作系統(tǒng)和安裝方式)中讀取,或者在首次初始化數(shù)據(jù)目錄時(shí)設(shè)置。因此這個(gè)方案行不通。
五、解決方案(docker方式)
1.先備份MySQL數(shù)據(jù)庫(kù)數(shù)據(jù)
(1)通過命令去備份
mysqldump -uroot -p[密碼] [數(shù)據(jù)庫(kù)] > [備份的sql]
(2)采用工具備份,如Navicat
2.停止MySQL
3.找到MySQL數(shù)據(jù)存放路徑
4.備份數(shù)據(jù)目錄
cp -ar datadir datadir_old
5.清空之前的數(shù)據(jù)目錄
rm -rf datadir/*
6.配置docker compose的MySQL
注:如果之前存在先刪除之前舊的運(yùn)行MySQL容器。
在docker-compose.yml中配置MySQL。
mysql: restart: always image: mysql:8.0.35 volumes: - ./mysql/datadir:/var/lib/mysql - ./mysql/conf/my.cnf:/etc/my.cnf environment: - "MYSQL_ROOT_PASSWORD=xxx" - "MYSQL_DATABASE=xxx" - "MYSQL_USER=xxx" - "MYSQL_PASSWORD=xxx" - "TZ=Asia/Shanghai" command: --lower_case_table_names=1 # 添加這一行來設(shè)置lower_case_table_names ports: - "3306:3306"
配置如下:
7.重新用docker compose命令運(yùn)行一個(gè)MySQL容器
docker compose up -d mysql
8.查看啟動(dòng)日志
docker logs 容器名/容器id
若沒出現(xiàn)錯(cuò)誤即為,設(shè)置MySQL忽略表名大小寫成功。
9.將數(shù)據(jù)恢復(fù)
(1)將導(dǎo)出的數(shù)據(jù)原封導(dǎo)入到MySQL中
(2)將備份的數(shù)據(jù)目錄全部復(fù)制到現(xiàn)在MySQL目錄
10.驗(yàn)證
到此,MySQL更新lower_case_table_names=1,忽略表名大小寫完成。
以上就是Linux環(huán)境下設(shè)置MySQL表名忽略大小寫的方法小結(jié)的詳細(xì)內(nèi)容,更多關(guān)于 Linux MySQL表名忽略大小寫的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
MySQL創(chuàng)建新用戶、增加賬戶的2種方法及使用實(shí)例
這篇文章主要介紹了MySQL創(chuàng)建新用戶、增加賬戶的2種方法及使用實(shí)例,本文同時(shí)也介紹了更新和修改密碼的方法,需要的朋友可以參考下2014-12-12mysql優(yōu)化之慢查詢分析+explain命令分析+優(yōu)化技巧總結(jié)
這篇文章主要介紹了mysql優(yōu)化之慢查詢分析,explain命令分析,優(yōu)化技巧總結(jié),需要的朋友可以參考下2023-02-02Mysql update多表聯(lián)合更新的方法小結(jié)
這篇文章主要介紹了Mysql update多表聯(lián)合更新的方法小結(jié),通過實(shí)例代碼給大家介紹了mysql多表關(guān)聯(lián)update的語(yǔ)句,感興趣的朋友跟隨小編一起看看吧2020-02-02mysql在項(xiàng)目中怎么選事務(wù)隔離級(jí)別
Mysql默認(rèn)的事務(wù)隔離級(jí)別是可重復(fù)讀,那互聯(lián)網(wǎng)項(xiàng)目中Mysql也是用默認(rèn)隔離級(jí)別,但在項(xiàng)目中呢,下面我們就一起來了解一下2021-05-05利用Xtrabackup工具備份及恢復(fù)(MySQL DBA的必備工具)
Xtrabackup 是percona的一個(gè)開源項(xiàng)目,可以熱備份innodb ,XtraDB,和MyISAM(會(huì)鎖表),可以看做是InnoDB Hotbackup的免費(fèi)替代品2013-04-04Mysql中報(bào)錯(cuò)函數(shù)floor()函數(shù)和rand()函數(shù)的配合使用及原理詳解
在項(xiàng)目中的SQL語(yǔ)句中遇到幾個(gè)數(shù)值處理函數(shù),看著有些懵,就小小的總結(jié)一下,這篇文章主要給大家介紹了關(guān)于Mysql中報(bào)錯(cuò)函數(shù)floor()函數(shù)和rand()函數(shù)的配合使用及原理的相關(guān)資料,需要的朋友可以參考下2022-07-07