首页
学习
活动
专区
圈层
工具
发布

MySQL用户表详解(mysql.user)

MySQL是通过权限表来控制用户对数据库访问的,权限表存放在mysql数据库中,主要的权限表有以下几个:user,db,host,table_priv,columns_priv和procs_priv,先带你了解的是...user表。...用户列(用户连接MySQL数据库需要输入的信息) Host:主机名,双主键之一,值为%时表示匹配所有主机。User:用户名,双主键之一。Password:密码名。...Drop_priv 确定用户是否可以删除现有数据库和表 Reload_priv 确定用户是否可以执行刷新和重新加载MySQL所用各种内部缓存的特定命令,包括日志、权限、主机、查询和表重新加载权限表 Shutdown_priv...Y:说明该用户密码已过期 N:没有过期 plugin 5.5.7开始,mysql引入plugins以进行用户连接时的密码验证,plugin创建外部/代理用户 authentication_string

4.5K21

MySQL user表损坏案例一则

环境信息:centos7.5 + mysql 5.7.30 今天业务反馈某业务数据连接不上,登录看了一下,发现数据库服务已经挂了(由于特殊原因,该库没有监控,并且是单点--成本原因,刺激不?!)。...解决尝试: 1、重启--失败 2、修改参数重启--失败 3、查看系统日志-- 发现有oom的提示,增加主机资源配置重启--失败(oom的时间没有对准) 仔细分析现象,查看日志。...手动重启一下,观察日志,报错如下: 结论:user表损坏。...解决方案: 1、mysql参数my.cnf 中的[mysqld]下添加 skip-grant-tables 2、启动mysql service mysqld start 3、登录mysql客户端 mysql...> repair table mysql.user; 4、注释掉参数中的 skip-grant-tables,重启服务,问题解决。

1.7K30
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    Percona MySQL查看没有访问的表

    要找到实例里面某个表是否有访问,确实是比较难搞。  常用方法就是 开tcpdump或tshark持续抓包过滤怀疑的表名。  但是,如果我们用的是Percona分支的MySQL,这件事就变得简单多了。...Percona MySQL 下,我们可以打开userstat参数,通过查询系统统计表来获取用户、客户端和库表访问情况,注意:该功能只在MySQL的 Percona 发行版有效,社区版不带这个功能。...(none) > status -------------- mysql  Ver 14.14 Distrib 5.6.38-83.0, for Linux (x86_64) using  6.2 Connection... id:1222143 Current database: Current user:root@localhost SSL:Not in use Current pager:stdout Using outfile...                   | | TABLE_STATISTICS                   | | THREAD_STATISTICS                   | | USER_STATISTICS

    4.3K30

    MySQL之delete user和drop user 的区别

    MySQL之delete user和drop user 的区别 Tip:在MySQL中,我们经常需要创建用户和删除用户,创建用户时,我们一般使用create user或者grant语句来创建,create...语法创建的用户没有任何权限,需要再使用grant语法来分配权限,而grant语法创建的用户直接拥有所分配的权限。...表中的这两个用户,在去查看用户表,我们发现: mysql 15:20:43>>delete from mysql.user where user='yeyz'; Query OK, rows affected...drop user方法删除用户的时候,会连通db表和权限表一起清除,也就是说删的比较干净,不会对以后的用户产生任何影响。...这个时候,你需要看看日志,查询自己有没有进行过delete from mysql.user的操作,如果有,这个问题就很好解释了。

    1.8K10

    MYSQL无备份情况下恢复误删除的user权限表

    问题背景 前几天客户反馈,误删除了权限表,导致无法连接到实例中了,但是又没有备份,咨询要怎么去恢复; 针对上述的这种情况,下面给出具体的恢复方法; (备份重于一切!备份重于一切!...重要的事情说三遍) 环境说明: MYSQL 5.7版本 端口:3306和3309 说明:3309是故障的实例,3306是协助在没有备份的情况下做恢复 下面开始故障模拟和恢复: 1、查看一下目前user表中存在的用户...:误删除了user表,进程被杀掉了,mysql服务处理停机状态,那么重启实例,肯定会报错(后面可以看到) 第一种情况:MYSQL服务进程是启动的 恢复方法: 从其他的运行好的数据库或官方文档找到mysql5.7...表的物理文件拷贝到故障实例的数据文件目录下,(5.7版本user表是myisam引擎,会存在三个物理文件) [root@VM_54_118_centos ~]# ll /data/mysql/mysql...=ON 但是可以发现,恢复成功后的user表是您拷贝实例(也就是3306端口实例)的user表哦。。。

    2.5K31

    navicat导入sql文件成功但没有表_mysql读取excel

    mysql_query($sql)) { re_result(“导入数据失败,请稍后再试或与管理员联系”); }*/ } 问题: 1、在页面的输出是全部都输出成功了,但是导入数据库的时候只导入了67...谢谢大家了 ——解决方案——————– 1、乱码问题 PHPExcel 默认以 utf-8 编码读出数据,没有特殊需要不要改动 如果 mysql 被设置成了 gbk 字符集,也不需要在读取后人工转码。...mysql 将自动完成转码工作 减少了代码,也就减少了出问题的概率 2、数据丢失问题 要书写健壮的代码,即含有错误处理的代码。...至少需要这样 mysql_query($sql) or die(mysql_error()); 以便观察到出了什么问题 你在读取数据后,未作任何处理就向数据库插入 那么如果数据中含有特殊字符“’”时,不就要出错了吗...——解决方案——————– 这是因为你的表中数据太多了 你的主键是有符号的长整形(int)改成无符号的 Unsigned int 可使容量增加一倍 2147483647 是 2 的31 次方 – 1 也就是有符号长整形所能表示的最大数

    5.8K10

    Navicat mysql报错 1142 – SELECT command denied to user ‘xxx‘@‘localhost‘ for table ‘user‘

    主机上的MYSQL可以有很多个数据库,这个MYSQL有一个root账户,这个账户可以随意操作其他数据库账户的权限。...这里的问题就在于user1的权限不足,我们就需要用root赋予user1更大的权限。 那么root账号是啥,密码又是啥?...需要说明的是这个账号,它是没有大权限的。而root这个用户名才是有真正大权限的,它的密码是创建数据库时你输入的那个。 对了,那怎么验证你的root账号的密码是否正确呢?...\bin //用root登陆MYSQL,指令:mysql -hlocalhost -uroot -p密码 D:\BtSoft\WebSoft\mysql\MySQL5.5\bin>mysql -hlocalhost...//不清楚这是干啥的(滑稽 mysql> use mysql Database changed //输出用户名为sql_dora的信息 mysql> select * from user where user

    4.1K30

    MYSQL-用户 (User)和权限(Privilege)

    作者介绍:简历上没有一个精通的运维工程师,下面的思维导图也是预计更新的内容和当前进度(不定时更新)。 数据库是一个系统(应用)最重要的资产之一,所以我们的数据库将从以下几个数据库来进行介绍。...当然还有一个部分就是权限范围,有些权限是全局的,有些权限只针特定的库甚至数据表的。...mysql> select * from mysql.user\G; *************************** 1. row ***************************...密码:比较老旧的版本没有强密码要求,较新的版本都有。...这个时候创建的用户是没有任何权限的 2.修改密码 ALTER USER 'username'@'host' IDENTIFIED BY 'new_password'; 3.权限管理 -- 授予所有数据库的所有权限

    28110

    Mysql The user specified as a definer (test@%) does not exist

    我们再用user1进行登陆: mysql> use testdb; Database changed mysql> call user_count(); ERROR 1142 (42000): SELECT...='user_count'; 再次用user1进行登陆: mysql> use testdb; Database changed mysql> call user_count(); +--------...对存储过程user_count有执行的权限,虽然它依旧没有权限直接操作mysql库,由于我们定义的SQL SECURITY为DEFINER,所以在执行时是以root的身份执行的,所以可以正常查询出来。...4.修改trigger的definer 目前还没有具体方便的方法,可以借助工具端如HeidiSQL、sqlyog等来一个个修改。...注意改前有必要锁表,因为如果改的过程中有其它表改变而触发,会造成数据不一致。 Flush tables with readlock Unlock tables

    2.5K10

    mysql报错 1142 – SELECT command denied to user ‘root_ssm’@’localhost’ for table ‘user’「建议收藏」

    错误信息的字面意思是:表“user”拒绝用户“root_ssm”@“localhost”的SELECT命令 ,很明显用户没有查看user表的权限,用管理员账号给他授权就行了 一、使用客户端授权(Navicat...Premium 12) 1、使用root用户登陆mysql 2、新建查询,输入指令: use mysql; select * from user where user=’root_ssm’; SQL...语句where后面的条件写要授权的那个用户名 3、执行语句,查看用户的信息 上图标红的地方的值为‘N’,表示没有权限,将其改为Y就行了。...二、使用Mysql的命令行客户端 1、root用户登陆mysql 2、查看’root_ssm’用户的信息 use mysql; select * from user where user='root_ssm..., 全部改好后再刷新MySQL的系统权限相关表: flush privileges; 4、修改好后查看表信息 之后重启mysql服务,权限就都有了。

    11.6K20
    领券