启动: mysqld --console 或 net start mysql
关闭: mysqladmin -u root shutdown 或 net stop mysql
linux下:
启动: service mysql start
停止: service mysql stop
重启服务: service mysql restart
三、创建用户分配权限
1. 新建用户: 创建一个名为: buff,密码为: buff的用户
// root 用户登陆 MySQL
mysql -uroot -p
Enter password:
// 新建用户
mysql>insert into mysql.user(Host,User,Password) values("localhost","buff",password("buff"));
// 刷新系统权限表
mysql>flush privileges;
mysql>exit
// 用户 buff 登陆 MySQL
mysql -ubuff -p
Enter password:
mysql>
// 说明新建的用户buff登录成功
用户授权
// root 用户登陆 MySQL
mysql -uroot -p
Enter password:
// 为用户 buff 创建一个数据库 bluebuff
mysql>create database bluebuff;
// 授权用户 buff 拥有数据库 bluebuff 的所有权限
mysql>grant all privileges on bluebuff.* to buff@localhost identified by 'buff';
mysql>flush privileges;
登录测试
// 用户 buff 登陆数据库
mysql -ubuff -p
Enter privileges:
// 显示数据库
mysql>show databases;
// root 用户登陆 MySQL
mysql -uroot -p
Enter password:
// 修改用户 buff 的密码
mysql>update table mysql.user set password=password('buffer') where User='buff' and Host='localhost';
mysql>flush privileges;
6、 删除用户
// root 用户登陆 MySQL
mysql -uroot -p
Enter password:
// 删除用户 buff
mysql>delete from mysql.user where User = 'buff' and Host = 'localhost';
mysql>flush privileges;
全局权限适用于一个给定服务器中的所有数据库 。这些权限存储在mysql.user表中 。GRANT ALL ON *.*和REVOKE ALL ON *.*只授予和撤销全局权限 。
例:a. 创建一个测试账号test,授予全局层级的权限
mysql> grant select,insert on *.* to test@'%' identified by 'test';
mysql> flush privileges;
b. 查询授予test的权限
show grants for test;
select * from mysql.user where user='test'\G;
2 、 数据库层级:
数据库权限适用于一个给定数据库中的所有目标 。这些权限存储在mysql.db和mysql.host表中 。GRANT ALL ON db_name.*和REVOKE ALL ON db_name.*只授予和撤销数据库权限
例:a. 创建一个测试账号test,授予数据库层级的权限
drop user test;
grant select,insert,update,delete on MyDB.* to test@'%' identified by 'test';
b. 查询授予test的权限
select * from mysql.user where user='test'\G; --可以看到无任何授权
select * from mysql.db where user='test'\G;
show grants for test;
表权限适用于一个给定表中的所有列 。这些权限存储在mysql.tables_priv表中 。GRANT ALL ON db_name.tbl_name和REVOKE ALL ON db_name.tbl_name只授予和撤销表权限 。
例:a. 创建一个测试账号test,授予表层级的权限
drop user test;
flush privileges;
grant all on MyDB.kkk to test@'%' identified by 'test';
b. 查询授予test的权限
show grants for test;
select * from mysql.tables_priv\G;
4、 列层级:
列权限适用于一个给定表中的单一列 。这些权限存储在mysql.columns_priv表中 。当使用REVOKE时,您必须指定与被授权列相同的列 。
例:a. 创建一个测试账号test,授予列层级的权限
drop user test;
flush privileges;
grant select (id, col1) on MyDB.TEST1 to test@'%' identified by 'test';
flush privileges;
b. 查询授予test的权限
select * from mysql.columns_priv;
show grants for test;
5、 子程序层级:
CREATE ROUTINE, ALTER ROUTINE, EXECUTE和GRANT权限适用于已存储的子程序 。这些权限可以被授予为全局层级和数据库层级 。而且,除了CREATE ROUTINE外,这些权限可以被授予为子程序层级,并存储在mysql.procs_priv表中 。
例:a. 创建一个测试账号test,授予子程序层级的权限
DROP PROCEDURE IF EXISTS PRC_TEST;
DELIMITER //
CREATE PROCEDURE PRC_TEST()
-> BEGIN
-> SELECT * FROM kkk;
-> END //
DELIMITER ;
grant execute on MyDB.PRC_TEST to test@'%' identified by 'test';
flush privileges;
b. 查询授予test的权限
show grants for test;
select * from mysql.procs_priv where User='test';