• ADADADADAD

    Windows对用户进行单个表授权后不显示大写表名[ mysql数据库 ]

    mysql数据库 时间:2024-12-25 09:56:30

    作者:文/会员上传

    简介:

    模拟生产环境中遇到的问题一、问题描述:1.Windows2.mysql-5.7.18版本配置mysql参数lowercasetablenames=0重启后启动不起来,只能退而求其次,配置lowercasetablenames=2(存放时

    以下为本文的正文内容,内容仅供参考!本站为公益性网站,复制本文以及下载DOC文档全部免费。

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

    一、问题描述:
    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中,数据库的数据也能正常使用。

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

    将本文的Word文档下载到电脑

    推荐度:

    下载
    热门标签: windowsmysql权限