Windows對用戶進行單個表受權後不顯示大寫表名

模擬生產環境中遇到的問題mysql

1、問題描述:
1.Windows
2.mysql-5.7.18版本
配置mysql參數lowercasetablenames=0重啓後啓動不起來,只能退而求其次,配置 lowercasetablenames=2(存放時依據格式存放,讀取時統一按小寫讀)
3.建庫建表語句:
在一個test數據庫下,我建了一個小寫的表名haha和一個大寫的表名USER,語句以下。
(1)建庫testsql

create databse test;

(2)建表haha數據庫

DROP TABLE IF EXISTS `haha`;
CREATE TABLE `haha` (
    `id` int(11) NOT NULL,  `name` varchar(255) DEFAULT NULL,  PRIMARY KEY (`id`)) ENGINE=InnoDB DEFAULT CHARSET=utf8;

(3)建表USERide

DROP TABLE IF EXISTS `USER`;
CREATE TABLE `USER` (
    `ID` int(11) NOT NULL,  `NAME` varchar(255) DEFAULT NULL,  PRIMARY KEY (`ID`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;

2個表結構建完以後開始建立用戶並對其進行分別受權。工具

create user 'test'@'localhost' IDENTIFIED by 'test@654321';
grant all on test.haha to test@'localhost';
grant all on test.USER to test@'localhost';

而後使用客戶端工具Navicat,用test這個用戶登陸,發現只顯示小寫的這個haha的表,大寫的USER表並未顯示。code

2、嘗試過的解決辦法:
關於表的受權存儲在mysql.tablespriv表中,發現Tablename列存儲的user時小寫的,我手動修改爲大寫的USER後保存,重啓mysql服務,依然不顯示大寫表名。it

3、最後解決
去掉以前的配置lower的參數,直接按照Windows默認的便可。即便從Linux區分大小寫的環境中遷移到Windows中,數據庫的數據也能正常使用。table

相關文章
相關標籤/搜索