mysql設定大小寫不敏感的方法:1、開啟並編輯「my.cnf」檔案;2、找出「lower_case_table_names」項,將該項目的值設為「1」;3、重啟mysql即可。
本教學操作環境:linux5.9.8系統、mysql8版本、Dell G3電腦。
一、原理與參數
mysql大小寫敏感配置與兩個參數相關 —— lower_case_file_system 和lower_case_table_names
#檢視目前mysql的大小寫敏感配置
show global variables like '%case%'; +------------------------+-------+ | Variable_name | Value | +------------------------+-------+ | lower_case_file_system | ON | | lower_case_table_names | 0 | +------------------------+-------+
lower_case_file_system:表示目前系統檔案是否大小寫敏感(ON為不敏感,OFF為敏感),唯讀參數,無法修改。
lower_case_table_names:表示表名是否大小寫敏感,可以修改。
lower_case_table_names = 0時,mysql會依照表名直接操作,大小寫敏感。
lower_case_table_names = 1時,mysql會先把表名轉換成小寫,再執行操作。
二、 修改前準備
由於lower_case_table_names = 1
時,mysql會先把表名轉為小寫,如果建表時表名是大寫的,設定完大小寫不敏感後就會查不到。感覺類似Oracle建表寫create table "test" 之後用select * from test就查不到,因為Oracle自動把test換成了大寫。
所以我們需要先把庫裡所有表名改為小寫。 mysql中沒有自備方法,可以寫個預存程序修改。
DELIMITER // DROP PROCEDURE IF EXISTS lowercase // CREATE PROCEDURE lowercase(IN dbname VARCHAR(200)) BEGIN DECLARE done INT DEFAULT 0; DECLARE oldname VARCHAR(200); DECLARE cur CURSOR FOR SELECT table_name FROM information_schema.TABLES WHERE table_schema = dbname; DECLARE CONTINUE HANDLER FOR NOT FOUND SET done = 1; OPEN cur; REPEAT FETCH cur INTO oldname; SET @newname = LOWER(oldname); #IF newname equals to oldname, do nothing; #select 'a' <> 'A'; -> 0 #select 'a' <> BINARY 'A'; -> 1 SET @isNotSame = @newname <> BINARY oldname; IF NOT done && @isNotSame THEN SET @SQL = CONCAT('rename table ',oldname,' to ',@newname); PREPARE tmpstmt FROM @SQL; EXECUTE tmpstmt; DEALLOCATE PREPARE tmpstmt; END IF; UNTIL done END REPEAT; CLOSE cur; END // DELIMITER ; #调用存储过程 #call lowercase('TEST'); #TEST为你想要修改的数据库的名称
三、正式設定
vi my.cnf文件,設定lower_case_table_names = 1 ,重啟mysql後生效
#vi my.cnf #添加 lower_case_table_names = 1
【相關推薦:mysql影片教學】
以上是mysql如何設定大小寫不敏感的詳細內容。更多資訊請關注PHP中文網其他相關文章!