模拟生产环境中遇到的问题 一、问题描述:1.windows2.Mysql-5.7.18版本配置mysql参数lowercasetablenames=0重启后启动不起来,只能退而求其次,配置 lower
模拟生产环境中遇到的问题
一、问题描述:
1.windows
2.Mysql-5.7.18版本
配置mysql参数lowercasetablenames=0重启后启动不起来,只能退而求其次,配置 lowercasetablenames=2(存放时依据格式存放,读取时统一按小写读)
3.建库建表语句:
在一个test数据库下,我建了一个小写的表名haha和一个大写的表名USER,语句如下。
(1)建库test
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)建表USER
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表并未显示。
二、尝试过的解决办法:
关于表的授权存储在mysql.tablespriv表中,发现Tablename列存储的user时小写的,我手动修改成大写的USER后保存,重启mysql服务,依然不显示大写表名。
三、最后解决
去掉之前的配置lower的参数,直接按照Windows默认的即可。即使从linux区分大小写的环境中迁移到Windows中,数据库的数据也能正常使用。
--结束END--
本文标题: Windows对用户进行单个表授权后不显示大写表名
本文链接: https://lsjlt.com/news/42239.html(转载时请注明来源链接)
有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341
2024-10-23
2024-10-22
2024-10-22
2024-10-22
2024-10-22
2024-10-22
2024-10-22
2024-10-22
2024-10-22
2024-10-22
回答
回答
回答
回答
回答
回答
回答
回答
回答
回答
0