Windows对用户进行单个表授权后不显示大写表名

模拟生产环境中遇到的问题

一、问题描述:
1.Windows操作系统
2.mysql-5.7.18版本
3.建库建表语句:
在一个test数据库下,我建了一个小写的表名haha和一个大写的表名USER,语句如下。
create databse test;
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;

-- ----------------------------

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;

表结构建完之后开始创建用户并对其进行分别授权。
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表并未显示。
二、尝试过的解决办法:
关于表的授权存储在mysql.tables_priv表中,发现Table_name列存储的user时小写的,我手动修改成大写的USER后保存,重启mysql服务,依然不起作用,请问怎么显示大写的表名?
已邀请:

tplinux

赞同来自: Chrisu

应该是有个参数控制
lower_case_table_names
大小写敏感
0.区分大小写
1.不分区大小写
2.创建的表和DB依据语句上格式存放,凡是查找都是转换为小写进行

Chrisu - 爱生活爱工作

赞同来自:

感谢,跟这个参数是有关系,但是之前我测试了我本地windows10、和windows server2008 环境下,对mysql设置lower_case_table_names=0后,mysql启动不起来了。所以我配置了lower的值是2,但是不满足要求,Windows环境下MySQL不区分大小写,真是无奈。

要回复问题请先登录注册