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

  

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

  

<强>一、问题描述:
1. windows
2. mysql-5.7.18版本
配置mysql参数lowercasetablenames=0重启后启动不起来,只能退而求其次,配置lowercasetablenames=2(存放时依据格式存放,读取时统一按小写读)
3。建库建表语句:
在一个测试数据库下,我建了一个小写的表名哈哈和一个大写的表名用户,语句如下。
(1)建库测试

  
 <代码>创建数据库测试; 
  

(2)建表哈哈

  
 <代码>删除表如果存在“哈哈”;
  创建表“哈哈”(
  “id”int(11)不是零,“名字”varchar(255)默认为空,主键(id))引擎=InnoDB默认字符集=use utf8;  
  

(3)建表用户

  
 <代码>删除表如果存在“用户”;
  创建表“用户”(
  “ID”int(11)不是零,“名字”varchar(255)默认为空,主键(“ID”)
  )引擎=InnoDB默认字符集=utf8;  
  

2个表结构建完之后开始创建用户并对其进行分别授权。

  
 <代码>创建用户“测试”@“localhost”被“test@654321”;
  格兰特在所有测试。哈哈,test@ ' localhost ';
  格兰特在所有测试。用户test@“localhost”;  
  

然后使用客户端工具Navicat,用测试这个用户登录,发现只显示小写的这个哈哈的表,大写的用户表并未显示。

  

<强>二,尝试过的解决办法:
关于表的授权存储在mysql.tablespriv表中,发现表列存储的用户时小写的,我手动修改成大写的用户后保存,重启mysql服务,依然不显示大写表名。

  

<强>三,最后解决
去掉之前的配置低的参数,直接按照Windows默认的即可。即使从Linux区分大小写的环境中迁移到Windows中,数据库的数据也能正常使用。

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