国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 數據庫 > MySQL > 正文

mysql怎么設定大小寫不敏感

2024-07-24 12:33:47
字體:
來源:轉載
供稿:網友
  這篇文章將為大家詳細講解有關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怎么設置大小寫不敏感就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。

(編輯:武林網)

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 和平区| 曲水县| 中方县| 民县| 清涧县| 自贡市| 宁夏| 旬邑县| 基隆市| 武汉市| 广宗县| 运城市| 东乌| 郎溪县| 曲阜市| 合山市| 宝清县| 娱乐| 丽江市| 东乌珠穆沁旗| 九寨沟县| 定远县| 青川县| 满城县| 广水市| 威海市| 连州市| 丹阳市| 赫章县| 祁东县| 辰溪县| 东平县| 伊金霍洛旗| 昌邑市| 鄂托克前旗| 子洲县| 米泉市| 静海县| 米泉市| 田林县| 高州市|