mysql常用命令使用手册

先说一点总结的话。

mysql server所有的用户都储存在mysql.user表中(dabase=mysql,table=user),user表就是一个用户的记录,就像linux把所有的用户都放在/etc/passwd一样。我们可以使用以下命令查询所有的用户:
select host,user from mysql.user;
也可以更新字段
update mysq.user set host = 'localhost' where user = 'cc';
不要在mysql.sql中执行insert命令,如果需要插入一条数据,可以使用create user命令。

但是这个表(mysql.user)并不能显式的查询到每个用户的权限。这就是为什么新建一个用户(create user)的时候,虽然指定了host%,但还是不能远程连接。

要想查询指定用户的权限,需要使用show grants命令,

show grants for cc,
有多个用户都叫cc时,要指定host,
show grants for 'cc'@'localhost'

在mysql.user中,用户名是可以重复的,只要host不同就可以,也就是说,mysql server把用户名相同但host不同的用户看作是不同的用户。

在mysql server的命令中,经常用到几个介词 on,to,for,from,为了方便记忆,提示下,通常情况下,on后面跟数据库和表的名称(当然,也可能是用通配符表示的库和表),to后面跟用户(用户通常指定了host),for后面也是跟用户,这样说来,tofor的用法很相似,如何区分呢,答案是onto通常会成对出现,不出现on但是要指定用户时,就用forfrom在仅在执行revoke操作时才会用到,是to的相反操作。分析语法好像很复杂哈,建议还是敲几遍命令,这样你自己都会总结出规律了。

总结完毕了,总结是为了归纳和方便记忆,下面是详细的命令。


登录:
mysql -u root -p
查看所有的database:
show databases;
查看所有的table:
show tables;
使用一个叫animal的数据库:
use animal
查看当前登录用户(开了好了几个窗口操作mysql时很有用):
select user();
查看自己选择了哪个database:
select database();
查看mysql的版本:
select version();

后三个命令的执行结果:

mysql> select version();
+-----------------------+
| version()             |
+-----------------------+
| 5.7.22-0ubuntu18.04.1 |
+-----------------------+
1 row in set (0.00 sec)

mysql> select user();
+--------------+
| user()       |
+--------------+
| cc@localhost |
+--------------+
1 row in set (0.00 sec)

mysql> select database();
+------------+
| database() |
+------------+
| catalog       |
+------------+
1 row in set (0.00 sec)

以上几个命令是比较基本的,不涉及到具体操作,但是需要的时候几乎都会去baidu(google)的东西。

创建一个新用户:
create user 'cc'@'%' identified by '123456';
如果我们不想设置密码:
create user 'cc'@'%'
修改密码:
set password for 'c'@'%' = password('123456');
授权用户对所有表的select权限:
grant select on *.* to 'c'@'%';
授权用户对库animal所有表的select权限:
grant select on animal.* to 'c'@'%';
授权用户对库animal中cat表的select权限:
grant select on animal.cat to 'c'@'%';
授权用户对所有表的update权限:
grant update on *.* to 'c'@'%';
授权用户对所有表的delete权限:
grant delete on *.* to 'c'@'%';
当然也可以这样:
grant select,update,delete on *.* to 'c'@'%';
授予所有权限:
grant all privileges on *.* to 'c'@'%';
如果你不想写privileges也是可以的:
授权用户对所有表的update权限:
grant all on *.* to 'c'@'%';
修改了权限之后,一定不要忘记:
flush privileges;是授权即时生效
如果cc用户已经连接mysql server,还需要重新连接下才能生效。
现在查看下cc用户的所有权限吧:
show grants for 'cc'@'%';

mysql> show grants for cc; //我确定自己只有一个cc用户,所以就不写成'cc'@'%'了
+-------------------------------------------------+
| Grants for cc@%                                 |
+-------------------------------------------------+
| GRANT SELECT, UPDATE, DELETE ON *.* TO 'cc'@'%' |
| GRANT ALL PRIVILEGES ON `haha`.* TO 'cc'@'%'    |
+-------------------------------------------------+

好像一切都很完美,突然想起来,怎么能让用户有delete权限呢,太危险了,要撤销一下:
revoke delete on *.* from 'cc'@'%';

删除刚才创建的用户:
drop user 'cc'@'%';

mysql的命令在修改和撤销的时候,几乎需要把授权的命令完整的敲一遍,只是关键字不同。非常希望mysql的权限可以有索引,按照id撤销就好了(只是一个希望,这句话请读者略过)。


还有一些高级功能,作为附录:

grant create on  创建
grant alter on  修改表
grant drop on 删除表
grant references on 操作外键
grant create temporary tables on 临时表权限
grant index on 创建索引
grant create view on 创建视图
grant show view on 查看视图
grant create routine on 创建存储过程
grant alter routine on 修改存储过程
grant execute on 函数
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 206,311评论 6 481
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 88,339评论 2 382
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 152,671评论 0 342
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 55,252评论 1 279
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 64,253评论 5 371
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,031评论 1 285
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,340评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,973评论 0 259
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 43,466评论 1 300
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,937评论 2 323
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,039评论 1 333
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,701评论 4 323
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,254评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,259评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,485评论 1 262
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,497评论 2 354
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,786评论 2 345