久久精品人人爽,华人av在线,亚洲性视频网站,欧美专区一二三

mysql怎么設置大小寫不敏感

168次閱讀
沒有評論

共計 1863 個字符,預計需要花費 5 分鐘才能閱讀完成。

這篇文章將為大家詳細講解有關 mysql 怎么設置大小寫不敏感,文章內容質量較高,因此丸趣 TV 小編分享給大家做個參考,希望大家閱讀完這篇文章后對相關知識有一定的了解。

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 怎么設置大小寫不敏感就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。

正文完
 
丸趣
版權聲明:本站原創文章,由 丸趣 2023-07-15發表,共計1863字。
轉載說明:除特殊說明外本站除技術相關以外文章皆由網絡搜集發布,轉載請注明出處。
評論(沒有評論)
主站蜘蛛池模板: 偃师市| 波密县| 禄丰县| 河津市| 保山市| 青海省| 蒙自县| 安岳县| 马尔康县| 平昌县| 抚远县| 清水河县| 辽中县| 石河子市| 湘潭市| 济南市| 三江| 上蔡县| 油尖旺区| 横峰县| 乐都县| 太原市| 嘉兴市| 上蔡县| 垦利县| 益阳市| 师宗县| 兴海县| 宁海县| 宜兴市| 南宁市| 封开县| 扶沟县| 石楼县| 邳州市| 迁西县| 当雄县| 郸城县| 瓦房店市| 海原县| 海伦市|