【MySQL 第十四天 数据库用户管理|日志管理|备份和恢复|数据表的导出和导入】

发布于:2022-11-13 ⋅ 阅读:(551) ⋅ 点赞:(0)

在这里插入图片描述


【1】mysql数据库的用户管理

在这里插入图片描述
在这里插入图片描述


在这里插入图片描述
在这里插入图片描述
在这里插入图片描述


在这里插入图片描述

create user 'username@'hostname' indentified by [password] 'password'
indentified :识别

在这里插入图片描述


在这里插入图片描述
明文密码方式创建

mysql> create user 'qq'@'localhostt' identified by 'root123';
Query OK, 0 rows affected (0.01 sec)

mysql> select user,host from mysql.user;
+---------------+------------+
| user          | host       |
+---------------+------------+
| kali          | %          |
| rose          | locaalhost |
| mysql.session | localhost  |
| mysql.sys     | localhost  |
| root          | localhost  |
| qq            | localhostt |
+---------------+------------+
6 rows in set (0.00 sec)

在这里插入图片描述


哈希密码方式创建

mysql> select password('root321');
+-------------------------------------------+
| password('root321')                       |
+-------------------------------------------+
| *A5219B9C114066F880112DA42E78FA40EC4A5781 |
+-------------------------------------------+
1 row in set, 1 warning (0.00 sec)

mysql> create user 'qq11'@'localhostt' identified by password '*A5219B9C114066F880112DA42E78FA40EC4A5781'
    -> ;
Query OK, 0 rows affected, 1 warning (0.00 sec)

mysql>
mysql> select user,host from mysql.user;
+---------------+------------+
| user          | host       |
+---------------+------------+
| kali          | %          |
| rose          | locaalhost |
| mysql.session | localhost  |
| mysql.sys     | localhost  |
| root          | localhost  |
| qq            | localhostt |
| qq11          | localhostt |
+---------------+------------+
7 rows in set (0.00 sec)

在这里插入图片描述


grant -> 准予;授予;同意;承认

在这里插入图片描述

grand privileges ON dbname.tablename TO 'user'@'host' [identified by 'password']

在这里插入图片描述


在这里插入图片描述

mysql> grant select,update ON *.* TO 'rnm'@'localhost' identified by 'kali';
Query OK, 0 rows affected, 1 warning (0.00 sec)

mysql>
mysql>
mysql>
mysql> show tables;
+------------------+
| Tables_in_rb_sql |
+------------------+
| book_bak         |
| bookinfo         |
| bookinfo_bak     |
| bookparent       |
| borrowinfo       |
| myengine         |
| mytest           |
| readerfee        |
| readerinfo       |
+------------------+
9 rows in set (0.00 sec)

mysql> select user,host from mysql.user;
+---------------+------------+
| user          | host       |
+---------------+------------+
| kali          | %          |
| rose          | locaalhost |
| mysql.session | localhost  |
| mysql.sys     | localhost  |
| rnm           | localhost  |
| root          | localhost  |
| qq            | localhostt |
| qq11          | localhostt |
+---------------+------------+
8 rows in set (0.00 sec)


在这里插入图片描述
在这里插入图片描述


在这里插入图片描述

mysql> select user  host from  mysql.user;
+---------------+
| host          |
+---------------+
| kali          |
| rose          |
| mysql.session |
| mysql.sys     |
| rnm           |
| root          |
| qq            |
| qq11          |
+---------------+
8 rows in set (0.00 sec)

mysql> delete from mysql.user where user = 'qq11' and host = 'localhost';
Query OK, 0 rows affected (0.00 sec)


【2】mysql数据库用户的权限管理

刷新权限命令

flush privileges;

在这里插入图片描述

grand priv_type ON dbname.tablename to 'username'@'host' [identified by [password] 'password'];

在这里插入图片描述


在这里插入图片描述

mysql>
mysql> grant insert,select on bookinfo.* to 'root'@'localhost';
Query OK, 0 rows affected (0.00 sec)

mysql> flush privileges;
Query OK, 0 rows affected (0.00 sec)

对某个用户授予全部权限

mysql> grant all privileges on *.* to 'root'@'localhost';
Query OK, 0 rows affected (0.00 sec)
show grants for 'username'@'host';

在这里插入图片描述

mysql>
mysql> show grants for 'root'@'localhost';
+---------------------------------------------------------------------+
| Grants for root@localhost                                           |
+---------------------------------------------------------------------+
| GRANT ALL PRIVILEGES ON *.* TO 'root'@'localhost' WITH GRANT OPTION |
| GRANT SELECT, INSERT ON `bookinfo`.* TO 'root'@'localhost'          |
| GRANT PROXY ON ''@'' TO 'root'@'localhost' WITH GRANT OPTION        |
+---------------------------------------------------------------------+
3 rows in set (0.00 sec)

mysql>
mysql>

revoke privileges ON db.table FROM 'user'@'host';
revoke :v. 撤回;撤销;废除;取消;

在这里插入图片描述
收回插入权限
在这里插入图片描述


【3】mysql数据库的日志管理

在这里插入图片描述
在这里插入图片描述


在这里插入图片描述
在这里插入图片描述在这里插入图片描述


在这里插入图片描述

show variables like 'log_error';
variables : n. 变量;可变因素;易变的东西;(variable的复数)

在这里插入图片描述

mysql> show variables like 'log_error';
+---------------+-----------------------+
| Variable_name | Value                 |
+---------------+-----------------------+
| log_error     | .\DESKTOP-L8ILHS8.err |
+---------------+-----------------------+
1 row in set, 1 warning (0.00 sec)

在这里插入图片描述


在这里插入图片描述
在这里插入图片描述


通过两种方式创建错误日志文件
【1】将存在的文件放在另一个文件夹下,重新创建

mysql> flush logs;
Query OK, 0 rows affected (0.00 sec)

mysql>

在这里插入图片描述


【4】mysql数据库的备份和恢复

在这里插入图片描述
在这里插入图片描述


在这里插入图片描述
备份数据库

C:\Windows\system32>
C:\Windows\system32>mysqldump -uroot -p rb_sql >C:\Users\ll\Desktop\mysql\rb_sql_20221112.sql
Enter password: ****

在这里插入图片描述
备份表

C:\Windows\system32>mysqldump -uroot -p rb_sql bookinfo >C:\Users\ll\Desktop\mysql\bookinfo_20221112.sql
Enter password: ****

C:\Windows\system32>

在这里插入图片描述
同时备份多个数据库

mysqldump -uroot -p databases dbname1 dbname2>path/filename.sql

在这里插入图片描述
在这里插入图片描述

备份所有数据库

mysqldump -uroot -p --all-databases>path/filename.sql

在这里插入图片描述
在这里插入图片描述


在这里插入图片描述

在这里插入图片描述
在这里插入图片描述

mysql -uroot -p dbname<path/filename.sql

在这里插入图片描述


source path/filename.sql

在这里插入图片描述
在这里插入图片描述


【5】mysql数据表的导出

在这里插入图片描述


select columnlist_name from table_name where 条件 into outfile 'filename' [options]
【1】fields terminated by 'value' :以“值”结束的字段
【2】lines terminated by 'value'  :以“值”结束的行

在这里插入图片描述


在这里插入图片描述

必须导入在此文件路径下
在这里插入图片描述

mysql>
mysql> select *from rb_sql.readerinfo into outfile 'C:/ProgramData/MySQL/MySQL Server 5.7/Uploads/readerinfo.txt';
Query OK, 9 rows affected (0.01 sec)

mysql>

在这里插入图片描述


指定分隔符导入

mysql>
mysql> select *from rb_sql.readerinfo into outfile 'C:/ProgramData/MySQL/MySQL Server 5.7/Uploads/readerinfo.txt'
    -> fields terminated by '-'
    -> lines terminated by '\r\n';
Query OK, 9 rows affected, 1 warning (0.00 sec)

在这里插入图片描述


== 限制mysql数据库导入导出==
在my.ini文件这样处理

secure-file-priv=NULL

在这里插入图片描述

修改为可以指定的路径保存文件

secure-file-priv=''

在这里插入图片描述


在这里插入图片描述

mysqldump -T path -uroot -p dbname [tables][options]

在这里插入图片描述


在这里插入图片描述
同时生成两个文件

C:\Windows\system32>
C:\Windows\system32>mysqldump -T "C:/ProgramData/MySQL/MySQL Server 5.7/Uploads" -uroot -p rb_sql bookinfo
Enter password: ****

C:\Windows\system32>

在这里插入图片描述


在这里插入图片描述

查询某些所有或部分列数据导入

mysql -uroot -p --execute = "select 语句" dbname >path/filename.txt

在这里插入图片描述
在这里插入图片描述

C:\Windows\system32>mysql -uroot -p --execute="select *from bookinfo;"  rb_sql> "C:/ProgramData/MySQL/MySQL Server 5.7/Uploads/1.txt"
Enter password: ****

C:\Windows\system32>

在这里插入图片描述


在这里插入图片描述

【6】mysql数据库的导入

load data infile 'filename.txt' into table tablename [options][ignore number lines]

在这里插入图片描述


在这里插入图片描述

load data infile "path/name.txt" into table dbname.tablename;

在这里插入图片描述


mysqlimport -uroot -p dbname path/filename.txt [options]

在这里插入图片描述


mysqlimport -uroot -p dbname "path/filename"

在这里插入图片描述


时隔半个月半,练习时常半个半的我终于结束了,下一期SQLITE3大刑伺候
在这里插入图片描述