亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

mysql怎么設置大小寫不敏感

發布時間:2022-01-06 12:45:59 來源:億速云 閱讀:672 作者:柒染 欄目:MySQL數據庫

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

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

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

平潭县| 鄄城县| 县级市| 普兰县| 巴彦淖尔市| 舞钢市| 阳原县| 潮州市| 宜城市| 岳西县| 新晃| 屯昌县| 东阳市| 英山县| 咸丰县| 滦平县| 噶尔县| 涿鹿县| 南皮县| 洛隆县| 通河县| 七台河市| 曲松县| 靖州| 鄯善县| 曲麻莱县| 横峰县| 北碚区| 胶南市| 扬中市| 宝应县| 井冈山市| 泰顺县| 宁陕县| 襄城县| 衡水市| 水城县| 峡江县| 黔南| 政和县| 临夏县|