常用命令

打开CMD命令窗口(记住使用管理员身份运行),我们就可以在命令窗口中做一些MySQL的命令操作了:

服务启动和关闭

这个我们上一个章节使用过了:net start mysql,这是服务命令,不是语句命令,后面不需要加引号

1 net stop mysql --代表停止MySQL服务
2 net start mysq --代表启动MySQL服务

MySQL登录命令

这个我们前面一章我们也了解过,使用过了:mysql -h 主机名 -P 端口 -u 用户名 -p,前面一章有对-h,-u,-p 作过解释,这边 -P 是指Port 端口。

1 mysql -h localhost -P 3306 -u root -p

默认情况下登陆本机,其实端口和主机都可以省略的:

1 mysql -u 用户名 -p

查看数据库版本

1 mysql> select version();
2 +-----------+
3 | version() |
4 +-----------+
5 | 5.7.30 |
6 +-----------+
7 1 row in set (0.00 sec)

显示所有数据库

 1 mysql> show databases;
2 +--------------------+
3 | Database |
4 +--------------------+
5 | information_schema |
6 | mysql |
7 | performance_schema |
8 | sys |
9 +--------------------+
10 4 rows in set (0.00 sec)

使用某个库:use关键字

1 mysql> use mysql;
2 Database changed

显示所选库中的所有表信息

 1 mysql> show tables;
2 +---------------------------+
3 | Tables_in_mysql |
4 +---------------------------+
5 | columns_priv |
6 | db |
7 | engine_cost |
8 | event |
9 | func |
10 | general_log |
11 | gtid_executed |
12 | help_category |
13 | help_keyword |
14 | help_relation |
15 | help_topic |
16 | innodb_index_stats |
17 | innodb_table_stats |
18 | ndb_binlog_index |
19 | plugin |
20 | proc |
21 | procs_priv |
22 | proxies_priv |
23 | server_cost |
24 | servers |
25 | slave_master_info |
26 | slave_relay_log_info |
27 | slave_worker_info |
28 | slow_log |
29 | tables_priv |
30 | time_zone |
31 | time_zone_leap_second |
32 | time_zone_name |
33 | time_zone_transition |
34 | time_zone_transition_type |
35 | user |
36 +---------------------------+
37 31 rows in set (0.00 sec)

从其他数据库中查询表

show tables from databasename

 1 mysql> show tables from mysql;
2 +---------------------------+
3 | Tables_in_mysql |
4 +---------------------------+
5 | columns_priv |
6 | db |
7 | engine_cost |
8 | event |
9 | func |
10 | general_log |
11 | gtid_executed |
12 | help_category |
13 | help_keyword |
14 | help_relation |
15 | help_topic |
16 | innodb_index_stats |
17 | innodb_table_stats |
18 | ndb_binlog_index |
19 | plugin |
20 | proc |
21 | procs_priv |
22 | proxies_priv |
23 | server_cost |
24 | servers |
25 | slave_master_info |
26 | slave_relay_log_info |
27 | slave_worker_info |
28 | slow_log |
29 | tables_priv |
30 | time_zone |
31 | time_zone_leap_second |
32 | time_zone_name |
33 | time_zone_transition |
34 | time_zone_transition_type |
35 | user |
36 +---------------------------+
37 31 rows in set (0.00 sec)

输出表的创建语句脚本

用于获取脚本进行表结构迁移之类的

 1 mysql> show create table columns_priv;
2 +--------------+-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
3 | Table | Create Table |
4 +--------------+-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
5 | columns_priv | CREATE TABLE `columns_priv` (
6 `Host` char(60) COLLATE utf8_bin NOT NULL DEFAULT '',
7 `Db` char(64) COLLATE utf8_bin NOT NULL DEFAULT '',
8 `User` char(32) COLLATE utf8_bin NOT NULL DEFAULT '',
9 `Table_name` char(64) COLLATE utf8_bin NOT NULL DEFAULT '',
10 `Column_name` char(64) COLLATE utf8_bin NOT NULL DEFAULT '',
11 `Timestamp` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,
12 `Column_priv` set('Select','Insert','Update','References') CHARACTER SET utf8 NOT NULL DEFAULT '',
13 PRIMARY KEY (`Host`,`Db`,`User`,`Table_name`,`Column_name`)
14 ) ENGINE=MyISAM DEFAULT CHARSET=utf8 COLLATE=utf8_bin COMMENT='Column privileges' |
15 +--------------+-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
16 1 row in set (0.00 sec)

查看表结构

以表格的信息输出表的结构,一目了然

 1 mysql> desc columns_priv;
2 +-------------+----------------------------------------------+------+-----+-------------------+-----------------------------+
3 | Field | Type | Null | Key | Default | Extra |
4 +-------------+----------------------------------------------+------+-----+-------------------+-----------------------------+
5 | Host | char(60) | NO | PRI | | |
6 | Db | char(64) | NO | PRI | | |
7 | User | char(32) | NO | PRI | | |
8 | Table_name | char(64) | NO | PRI | | |
9 | Column_name | char(64) | NO | PRI | | |
10 | Timestamp | timestamp | NO | | CURRENT_TIMESTAMP | on update CURRENT_TIMESTAMP |
11 | Column_priv | set('Select','Insert','Update','References') | NO | | | |
12 +-------------+----------------------------------------------+------+-----+-------------------+-----------------------------+
13 7 rows in set (0.00 sec)

查看当前所在库

1 mysql> select database();
2 +------------+
3 | database() |
4 +------------+
5 | mysql |
6 +------------+
7 1 row in set (0.00 sec)

查看所有库引擎

 1 mysql> show engines;
2 +--------------------+---------+----------------------------------------------------------------+--------------+------+------------+
3 | Engine | Support | Comment | Transactions | XA | Savepoints |
4 +--------------------+---------+----------------------------------------------------------------+--------------+------+------------+
5 | InnoDB | DEFAULT | Supports transactions, row-level locking, and foreign keys | YES | YES | YES |
6 | MRG_MYISAM | YES | Collection of identical MyISAM tables | NO | NO | NO |
7 | MEMORY | YES | Hash based, stored in memory, useful for temporary tables | NO | NO | NO |
8 | BLACKHOLE | YES | /dev/null storage engine (anything you write to it disappears) | NO | NO | NO |
9 | MyISAM | YES | MyISAM storage engine | NO | NO | NO |
10 | CSV | YES | CSV storage engine | NO | NO | NO |
11 | ARCHIVE | YES | Archive storage engine | NO | NO | NO |
12 | PERFORMANCE_SCHEMA | YES | Performance Schema | NO | NO | NO |
13 | FEDERATED | NO | Federated MySQL storage engine | NULL | NULL | NULL |
14 +--------------------+---------+----------------------------------------------------------------+--------------+------+------------+
15 9 rows in set (0.00 sec)

创建用户

1 create user user[@host] [identified by 'password'];

方括号中的内容是可以省略的,比如设置默认主机%,这样允许用户从其他主机登录,比如不设置密码,这样默认无需密码登录。

我们创建一个用户并登录试试,红色字体是关键语句:

 1 mysql> create user user1@localhost identified by '123456';
2 Query OK, 0 rows affected (0.00 sec)
3
4 D:\Setup\mysql-5.7.30-winx64\bin>mysql -u user1 -p
5 Enter password: ******
6 Welcome to the MySQL monitor. Commands end with ; or \g.
7 Your MySQL connection id is 16
8 Server version: 5.7.30 MySQL Community Server (GPL)
9
10 Copyright (c) 2000, 2020, Oracle and/or its affiliates. All rights reserved.
11
12 Oracle is a registered trademark of Oracle Corporation and/or its
13 affiliates. Other names may be trademarks of their respective
14 owners.
15
16 Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.

修改用户密码:4种方式

登录MySQL并修改

格式如下: set password for 用户名@主机 = password('新密码');

1 mysql> set password for root@localhost = password('Helenlyn');
使用 mysqladmin 操作

格式如下:mysqladmin -u 用户名 -p 旧密码 password 新密码

1 mysqladmin -u root -p Helenlyn password Helenlyn1
使用脚本语句修改 user 表

打开mysql数据库,直接更新user表的authentication_string字段。这边localhost可以用%代替。

需要注意:flush privileges是刷新权限,必须执行,才能对用户生效;

我们用的是5.7.30版本,所以密码字段是authentication_string,5.7之前的版本一般来说是password。

1 mysql> use mysql;
2 mysql> update user set authentication_string=password('1234567') where user='user1' and host='localhost';
3 mysql> flush privileges;
直接设置密码

创建用户的时候同时设置密码,或者登录的用户修改自己的密码,这个在前面部署服务和创建用户的时候都有说明过了:

1 create user user[@host] [identified by 'pwd'];
2 或
3 set password = password('pwd');

删除用户:2种方式

直接drop

格式如下:drop user 'username'[@'host']

1 mysql> drop user user1@localhost;
2 Query OK, 0 rows affected (0.00 sec)

删除完,用户重启就生效了,可以创建个用户试试。

删除user表的用户

同样的,执行完需要执行 flush privileges刷新权限才会对用户生效,格式如下:

delete from user where user='用户名' and host='主机';
flush privileges;

1 mysql> use mysql;
2 Database changed
3
4 mysql> delete from user where user='user1' and host='localhost';
5 Query OK, 0 rows affected (0.00 sec)
6
7 mysql> flush privileges;
8 Query OK, 0 rows affected (0.00 sec)

给用户授权

创建用户之后,需要给不同的用户分别授权,这样才能根据不同用户的角色来界定职责和管理范畴。

1 grant privilegesCate on database.table to 'uname'[@'host'] [with grant option]

说明:

1、grant 是授权的关键字。

2、privilegesCate 代表劝降类型,包含:all privileges:所有权限;select:读权限;delete:删除权限;update:更新权限;create:创建权限;drop:删除数据库、数据表权限。

3、on 用来表实授权的范围具体到那些库和表,看示例中,格式为数据库.表名 ,点号前面指的是数据库名,后面指的是表名,如果想要授权所有库表,可以用 *.* 表示。

4、to 表示权限授予的具体用户, 格式:uname@host,uname即用户名,host指的是主机,可以是IP、域名等,如果不做host限制,我们之前的文章也说过了,使用%表示。

5、with grant option 这个选项表示该用户可以将自己拥有的权限授权给别人。如果不加这一项,用户只有使用权限的权力,而没有使用grant命令创建并给其它用户授权的。

6、权限取并集,如果对用户授权了 select+ update,后面又对用户授予了 select + delete, 那么用户同时拥有 select + update + delete的权限。

1 mysql> create user brand identified by '123456';
2 Query OK, 0 rows affected
3
4 mysql> grant all on *.* to brand@'%';
5 Query OK, 0 rows affected

说明:这边是创建了一个用户并把所有的权限都授予他。如果要做限制,可以把 *.* 改成具体的数据库或者表,也可以吧%改成具体的host。如果要开放授权能力,可以在末尾加上 with grant option ,这样就基本等同于dba的权限了。

查看用户的权限

1 show grants for 'uname'[@'host']

这边需注意,主机可以省略,默认值为%,测试下:

1 mysql> show grants for brand;
2 +---------------------------------------------------------------------------------------------------------------+
3 | Grants for brand@% |
4 +---------------------------------------------------------------------------------------------------------------+
5 | GRANT ALL PRIVILEGES ON *.* TO 'brand'@'%' IDENTIFIED BY PASSWORD '*6BB4837EB74329105EE4568DDA7DC67ED2CA2AD9' |
6 +---------------------------------------------------------------------------------------------------------------+
7 1 row in set

当前登录者的权限,如:

1 mysql> show grants
2 ;
3 +----------------------------------------------------------------------------------------------------------------------------------------+
4 | Grants for root@localhost |
5 +----------------------------------------------------------------------------------------------------------------------------------------+
6 | GRANT ALL PRIVILEGES ON *.* TO 'root'@'localhost' IDENTIFIED BY PASSWORD '*6BB4837EB74329105EE4568DDA7DC67ED2CA2AD9' WITH GRANT OPTION |
7 | GRANT PROXY ON ''@'' TO 'root'@'localhost' WITH GRANT OPTION |
8 +----------------------------------------------------------------------------------------------------------------------------------------+
9 2 rows in set

取消用户的权限

1 revoke privilegesCate on database.table FROM 'uname'[@'host'];

可以先查show grants,再撤销revoke,再查show grants,来理解整个过程,示例:

 1 mysql> show grants for brand;
2 +---------------------------------------------------------------------------------------------------------------+
3 | Grants for brand@% |
4 +---------------------------------------------------------------------------------------------------------------+
5 | GRANT ALL PRIVILEGES ON *.* TO 'brand'@'%' IDENTIFIED BY PASSWORD '*6BB4837EB74329105EE4568DDA7DC67ED2CA2AD9' |
6 +---------------------------------------------------------------------------------------------------------------+
7 1 row in set
8
9 mysql> revoke delete on *.* from brand;
10 Query OK, 0 rows affected
11
12 mysql> show grants for brand;
13 +--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
14 | Grants for brand@% |
15 +--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
16 | GRANT SELECT, INSERT, UPDATE, CREATE, DROP, RELOAD, SHUTDOWN, PROCESS, FILE, REFERENCES, INDEX, ALTER, SHOW DATABASES, SUPER, CREATE TEMPORARY TABLES, LOCK TABLES, EXECUTE, REPLICATION SLAVE, REPLICATION CLIENT, CREATE VIEW, SHOW VIEW, CREATE ROUTINE, ALTER ROUTINE, CREATE USER, EVENT, TRIGGER, CREATE TABLESPACE ON *.* TO 'brand'@'%' IDENTIFIED BY PASSWORD '*6BB4837EB74329105EE4568DDA7DC67ED2CA2AD9' |
17 +--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
18 1 row in set

上面我们先查询用户的权限,是all的权限,然后撤销他的delete的权限,再查询,发现它确实少了delete的选项,这个符合我们的预期,说明授权操作没有问题。

关于授权的一些注意点

1、权限最小化原则,有需要再去开通,如果只有查询,就只开通select权限即可

2、读写用户分离,读用户只需给select权限,不要赋予update、insert、delete甚至drop之类的权限

3、尽量设置复杂密码或者让使用者重置密码

4、没有特定情况,一般不需要授予 WITH GRANT OPTION

5、定期清理垃圾用户,回收权限或者删除用户

总结

还有很多常用的命令操作,后续再融入到他章节 一 一 解读。命令是用户进入正式数据库编程之前应知应会的部分,所以需要熟练掌握。

使用过程中需要注意以下细节:

命令的方式操作用户和权限不需要刷新,下一次登录就会自动生效,在mysql库表进行修改的,需要调用flush privileges; 刷新一下,才会在下次登录生效。

文中所说的host部分可以省略,默认值为%,表示所有机器,这个文中反复说过了。

mysql中用户名、密码和权限的信息存储在库名为mysql的user表中,可以打开看看。

MySQL全面瓦解2:常用命令和系统管理的更多相关文章

  1. Mac下安装MySQL及启动等常用命令

    总结了下mac下的mysql安装步骤:   eclipse JavaEE 下载         JDK -9 macosx下载   一.安装及启动服务 1. MySQL Server 下载.(以mys ...

  2. MySQL 安装 用户管理 常用命令

    MySQL目录 数据库概览   数据库介绍 Why Choose MySQL MySQL的前世今生 MySQL的安装   Windows安装MySQL5.721 installer版 Windows安 ...

  3. MySQL 数据库和一些常用命令的使用

        常用命令总结: 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 3 ...

  4. MySQL快速入门及常用命令

    数据库 笔记内容 SQL语言共分为四大类:数据查询语言DQL,数据操纵语言DML,数据定义语言DDL,数据控制语言DCL. 1. 数据查询语言DQL 数据查询语言DQL基本结构是由SELECT子句,F ...

  5. Mysql 远程登录及常用命令

    第一招.mysql服务的启动和停止 net stop mysql net start mysql 第二招.登陆mysql 语法如下: mysql -u用户名 -p用户密码 键入命令mysql -uro ...

  6. MySql数据库2【常用命令行】

    (一) 连接MYSQL: 格式: mysql -h主机地址 -u用户名 -p用户密码 1.连接到本机上的MYSQL 进入mysql安装目录下的bin目录下,再键入命令mysql -uroot -p,回 ...

  7. linux常用命令与系统管理常用命令

    linux命令:切换用户:开启ftp服务:service vsftpd start 开启ssh服务:service sshd start普通用户切换到超级用户:su rootlogout:(注销)un ...

  8. MySQL基础入门之常用命令介绍

    mysql命令介绍 mysql 是数据库管理命令 通过mysql --help来查看相关参数及使用说明 mysql --help                #mysql数据库管理命令 Usage: ...

  9. MySQL基础知识和常用命令总结

    说明:以下内容是阅读书籍<<MySQL必知必会>>的摘要和总结 检索数据 排序检索数据 过滤数据 使用通配符过滤 使用正则表达式进行搜索 创建计算字段 使用数据处理函数 汇总数 ...

随机推荐

  1. C语言入门经典书目推荐--转

    国内良莠不齐的C语言教程数不胜数,同名如"C程序设计""C语言程序设计""C语言程序设计教程"的都多如牛毛,这些不知名的就不予考虑了,要看就 ...

  2. java实现点击查询数据生成excel文件并下载

    须先导入关键maven包 <dependency> <groupId>org.apache.poi</groupId> <artifactId>poi& ...

  3. 浅析Kubernrtes服务类型(Service Types)

    先上图 在Kubernetes集群中,service通过标签选择器选着对应的pod,然后对请求进行转发,看个动画,能直接了当体会到便签选择器 pod,endpoints,service三者关系 1.举 ...

  4. .NETCore在析构函数(Finalize)在Linux下引起程序异常退出现象

    目       录 1.      现象概述... 1 2.      操作数据库的代码... 2 3.      引起的异常... 2 4.      异常信息分析... 3 5.      分析结 ...

  5. C++实现职工管理系统(上)

    C++实现职工管理系统(上) 大家好呀,时间过得真快,在博客园已经第七天了,博主今天给大家带来的是职工管理系统(C++)(上) 这次的随笔记录的是实现职工管理系统所需要的类 目录 C++实现职工管理系 ...

  6. react 中发布订阅模式使用

    react 中发布订阅模式使用 场景 怎么能将设计模式应用到我们的 React 项目中?以前一直在思考这个问题. 场景一 模块 A 模块 B 需要用到同一个数据 data,A 和 B 都会修改这份数据 ...

  7. jdbc原理与步骤

    jdbc原理 1.加载JDBC驱动,并将其注册到DriverManager 2.建立数据库连接,获取connection对象 3.建立Statement对象或PreparedStatement对象 4 ...

  8. 普利姆算法(prim)

    普利姆算法(prim)求最小生成树(MST)过程详解 (原网址) 1 2 3 4 5 6 7 分步阅读 生活中最小生成树的应用十分广泛,比如:要连通n个城市需要n-1条边线路,那么怎么样建设才能使工程 ...

  9. IOS 数据储存

    IOS 数据存储 ios数据存储包括以下几种存储机制: 属性列表 对象归档 SQLite3 CoreData AppSettings 普通文件存储 1.属性列表 // //  Persistence1 ...

  10. CSP-J 2019复赛分析

    [CSP-J 2019 ]复赛分析 前言(????) 总的来说,这次复赛感觉考的很不满意,至于原因,感慨万分!关键是:期中考试了!偏偏是这个时候! - 由于我是一个初二的蒟蒻,所以考试前先定了一个目标 ...