MySQL5.7数据库的基本操作命令
MySQL5.7中添加用户,新建数据库,用户授权,删除用户,修改密码(注意每行后边都跟个;表示一个命令语句结束):
登录MySQL
mysql -u root -p
Enter password:密码
1.列出所有数据库
show database;
2.切换数据库
use 数据库名;
3.列出某个数据库所有表
use 数据库名;
show tables;
4.查询数据
use 数据库名;
select 字段名(多个字段用“,”隔开,*表示所有字段) from 数据表名;
也可以用 select 字段名(多个字段用“,”隔开,*表示所有字段) from 数据库名.数据表名;
5.显示数据表结构
describe 数据表名; # 也可以简写为 desc 数据表名;
也可以用 describe 数据库名.数据表名;
6.删除数据库和数据表
drop database 数据库名;
drop table 数据表名;
7.新建用户
创建用户:
insert into mysql.user(Host,User,Password) values("localhost","zhangsan",password("123456"));
需要注意的是,如上,用insert方法向MySQL5.7中添加用户出现 ERROR 1364 (HY000): Field 'ssl_cipher' doesn't have a default value 的错误,MySQL5.7为了数据库的安全默认是禁止这种方法来创建用户的,所以应该避免用这种插入的方式来创建用户,正确的创建用户的方式是:
无密码:create user '用户名'@'localhost';
有密码:create user '用户名'@'localhost' identified by '密码';
create user '用户名'@'localhost' identified by '密码'; # 本地登录
create user '用户名'@'%' identified by '密码'; # 远程登录
exit # 退出数据库
mysql -u 用户名 -p # 测试是否创建成功
8.使用GRANT命令为账户授权(需在root账户下操作)
GRANT命令的常见格式以及解释 | |
命令 | 作用 |
GRANT 权限 ON 数据库.表名称 TO 用户名@登录主机 | 对某个特定数据库中的特定表给予授权 |
GRANT 权限 ON 数据库.* TO 用户名@登录主机 | 对某个特定数据库中的所有表给予授权 |
GRANT 权限 ON *.* TO 用户名@登录主机 | 对所有数据库及所有表给予授权 |
GRANT 权限1,权限2 ON 数据库.* TO 用户名@登录主机 | 对某个数据库中的所有表给予多个授权 |
GRANT ALL PRIVILEGES ON *.* TO 用户名@登录主机 | 对所有数据库及所有表给予全部授权(需谨慎操作) |
注意:授权的同时如需创建用户并设置用户密码,用如下的命令
grant 权限 on 数据库.* to '用户名'@'登录主机' identified by '密码';
首先为用户创建一个数据库(testDB):
create database testDB;
如果需要指定数据库的字符编码为utf8,用如下命令:
create database testDB default charset utf8 collate utf8_general_ci;
(1)授权zhangsan用户拥有testDB数据库的所有权限(某个数据库的所有权限):
grant all privileges on testDB.* to 'zhangsan'@'localhost';
flush privileges; # 刷新系统权限表
show grants for 'zhangsan'@'localhost'; # 查看账户 zhangsan 的权限
(2)如果想指定部分权限给zhangsan用户,可以这样来写:
grant select,update on testDB.* to 'zhangsan'@'localhost';
flush privileges; # 刷新系统权限表
(3)授权zhangsan用户拥有所有数据库的某些权限:
grant select,delete,update,create,drop on *.* to 'zhangsan'@'%'; # 注意:需要mysql.user表中zhangsan账户对应的Host的字段值为“%”,才能正确执行此命令
# zhangsan用户对所有数据库都有 select,delete,update,create,drop 权限。
# @'%' 表示对所有非本地主机授权,不包括localhost。
# @'localhost' 表示对所有本地主机授权。
9.使用REVOKE命令取消账户权限
revoke select on *.* from 'zhangsan'@'localhost'; # 取消zhangsan对所有数据库的查询权限
revoke all on testDB.* from 'zhangsan'@'localhost'; # 取消zhangsan对testDB数据库的所有权限
show grants for 'zhangsan'@'localhost'; # 查看账户 zhangsan 的权限
10.删除用户
delete from user where User='zhangsan' and Host='localhost';
flush privileges;
或者也可以使用如下命令,删除账户及权限
drop user '用户名'@'%';
drop user '用户名'@ 'localhost';
11.修改指定用户密码
update mysql.user set authentication_string=password('新密码') where User='zhangsan' and Host='localhost';
flush privileges;
注意:在 MySQL5.7 中 user 表已经不再使用 password 来作为密码的字段了而改成了authentication_string。
MySQL5.7数据库的基本操作命令的更多相关文章
- 烂泥:mysql5.5数据库cmake源码编译安装
本文由秀依林枫提供友情赞助,首发于烂泥行天下. 以前也写过一篇有关mysql5.0源码编译的文章,该文章为<烂泥:mysql5.0数据库源码编译安装>.但是MySQL自5.5版本以后,就开 ...
- centos环境下使用percona-xtrabackup对mysql5.6数据库innodb和myisam进行快速备份及恢复
centos环境下使用percona-xtrabackup对mysql5.6数据库innodb和myisam进行快速备份及恢复 有时候我们会碰到这样的业务场景: 1.将大的数据库恢复到本地进行业务测试 ...
- MySQL数据库的基本操作命令
MySQL数据库的基本操作命令 [mysql]mysql 常用建表语句 一.mysql服务操作 net start mysql //启动mysql服务 net stop mysql //停止mysql ...
- Win10安装Mysql5.7数据库
Win10安装Mysql5.7数据库 最近做个demo在自己本地装了一个mysql5.7,有些小麻烦记录一下. 安装环境:系统是 windows 10 1.官网下载 下载地址:https://dev. ...
- mysql5.6数据库双机热备、主从备份
主题:mysql5.6数据库双机热备.主从备份 缘由: 在Web应用系统中,数据库性能是导致系统性能瓶颈最主要的原因之一.尤其是在大规模系统中,数据库集群已经成为必备的配置之一.集群的好处主要有:查询 ...
- 记录CentOS7.X版本下安装MySQL5.7数据库
记录CentOS7.X版本下安装MySQL5.7数据库 设置rpm下载目录在/opt目录下新建一个目录存放mysql cd /opt sudo mkdir mysql12 下载MySQL的源 wg ...
- mysql5.6数据库同步,单向双向同步问题
windows下MySQL5.6实现主从数据库同步数据 mysql5.6数据库同步,单向双向同步问题 一.单向同步 主数据库(mysql5.6)192.168.1.104 从数据库(mysql5. ...
- mysql5.x数据库文件导入mysql5.7数据库出错解决方法
由于mysql5.7 timestamp 类型不允许timestamp NOT NULL DEFAULT '0000-00-00 00:00:00',创建表的是后会报异常 修改mysql5.7的配置文 ...
- Docker安装并运行mysql5.6数据库
1.在/home目录下新建mysql目录 mysql目录中新建三个目录:conf目录.logs目录.data目录,建这些目录的目的是用来挂载docker中的mysql下的目录的. 结果如下: 1.1. ...
随机推荐
- [LeetCode] 803. Bricks Falling When Hit 打击砖块掉落
We have a grid of 1s and 0s; the 1s in a cell represent bricks. A brick will not drop if and only i ...
- PHPExcel 中文使用手册详解 二
$objPHPExcel = new \PHPExcel(); //定义配置 $topNumber = 2;//表头有几行占用 $xlsTitle = iconv('utf-8', 'gb2312', ...
- (转)深入浅出Redis-redis哨兵集群
背景:对于后台开发,需要了解与集群相关的工作. 深入浅出Redis-redis哨兵集群 Sentinel(哨兵)是Redis 的高可用性解决方案:由一个或多个Sentinel 实例 组成的Sentin ...
- DHCP、DHCP Snooping及DHCP relay工作原理入门及实践(转)
原文https://blog.51cto.com/5167020/2312718 序:DHCP服务相对简单,写本文的目的是为了讲一些DHCP安全方面的技术. 1.DHCP基础 DHCP 全称动态主机配 ...
- Spring Boot 项目中的 parent
前言 我们成功创建Spring Boot之后,pom.xml坐标文件中都会有如下一段引用: <parent> <groupId>org.springframework.boot ...
- Django-03-静态文件配置
一.django静态文件配置原理 静态文件配置就是为了让用户请求时django服务器能找到静态文件返回. 首先要理解几个概念: 媒体文件:用户上传的文件 静态文件:css,js,image等 开发环境 ...
- Django django.core.exceptions.ImproperlyConfigured: WSGI application 'myblog.wsgi.application' could not be loaded; Error importing module.报错
报错内容 django.core.exceptions.ImproperlyConfigured: WSGI application 'myblog.wsgi.application' could n ...
- Django视图扩展类
Django视图扩展类 扩展类必须配合GenericAPIView使用扩展类内部的方法,在调用序列化器时,都是使用get_serializer 需要自定义get.post等请求方法,内部实现调用扩展类 ...
- TiDB基本架构简单总结
TiDB特点 高可用 水平拓展 事务 SQL支持 TiDB架构 和MySql不同,TiDB是一个分布式的数据库而不是单个进程,所以整个TiDB是由以下角色组成: TiKV, PD, TiDB, T ...
- IntelliJ IDEA 2019 激活码 | 全产品 | 跨平台 | Goland | PhpStorm | Rider | CentOS | Windows
>>> 下载地址: https://kenkao.pipipan.com/fs/14896800-375468824 >>> 下载地址2: https://pan. ...