首頁  >  文章  >  資料庫  >  mysql如何設定大小寫不敏感

mysql如何設定大小寫不敏感

青灯夜游
青灯夜游原創
2022-01-06 12:00:0612334瀏覽

mysql設定大小寫不敏感的方法:1、開啟並編輯「my.cnf」檔案;2、找出「lower_case_table_names」項,將該項目的值設為「1」;3、重啟mysql即可。

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 &#39;a&#39; <> &#39;A&#39;; -> 0  
#select &#39;a&#39; <> BINARY &#39;A&#39;; -> 1  
SET @isNotSame = @newname <> BINARY oldname;  
IF NOT done && @isNotSame THEN 
SET @SQL = CONCAT(&#39;rename table &#39;,oldname,&#39; to &#39;,@newname);
PREPARE tmpstmt FROM @SQL;      
EXECUTE tmpstmt;      
DEALLOCATE PREPARE tmpstmt;      
END IF;      
UNTIL done END REPEAT;      
CLOSE cur;     
END //      
DELIMITER ;
 
#调用存储过程 
#call lowercase(&#39;TEST&#39;);
#TEST为你想要修改的数据库的名称

三、正式設定 

vi my.cnf文件,設定lower_case_table_names = 1 ,重啟mysql後生效

#
vi my.cnf
#添加
lower_case_table_names = 1

【相關推薦:mysql影片教學

以上是mysql如何設定大小寫不敏感的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn