|
現(xiàn)弄些受權(quán)用戶的資料 以備不時(shí)之需
授權(quán)表使用舉例
grant用于給增加用戶和創(chuàng)建權(quán)限,revoke用于刪除用戶權(quán)限。
下面是一些用grant增加用戶和創(chuàng)建權(quán)限的例子:
mysql> grant all privileges on *.* to test@localhost identified by 'test' with grant option;
這句增加一個(gè)本地具有所有權(quán)限的test用戶(超級(jí)用戶),密碼是test。ON子句中的*.*意味著"所有數(shù)據(jù)庫(kù)、所有表"。with grant option表示它具有g(shù)rant權(quán)限。
mysql> grant select,insert,update,delete,create,drop privileges on test.* to test1@'192.168.1.0/255.255.255.0' identified by 'test';
這句是增加了一個(gè)test1用戶,口令是test,但是它只能從C類子網(wǎng)192.168.1連接,對(duì)test庫(kù)有select,insert,update,delete,create,drop操作權(quán)限。
用grant語(yǔ)句創(chuàng)建權(quán)限是不需要再手工刷新授權(quán)表的,因?yàn)樗呀?jīng)自動(dòng)刷新了。
給用戶創(chuàng)建權(quán)限還可以通過(guò)直接修改授權(quán)表:
mysql> insert into user
values("localhost","test",password("test"),"Y","Y","Y","Y","Y","Y","Y","Y","Y","Y","Y","Y","Y","Y");
mysql> flush privileges;
這兩句和上面第一句grant的效果是一樣的,也是增加了一個(gè)本地的test超級(jí)用戶。我們看到用grant方便多了,而且還不需flush privileges。
mysql> insert into user (host,user,password) values("192.168.1.0/255.255.255.0","test1",PASSWORD("test")); mysql> insert into db values("192.168.1.0/255.255.255.0","test","test1","Y","Y","Y","Y","Y","Y","N","N","N","N") mysql> flush privileges;
這三句和上面第二句grant的效果也是一樣的,也是增加了一個(gè)只能從C類子網(wǎng)192.168.1連接,對(duì)test庫(kù)有select,insert,update,delete,create,drop操作權(quán)限的test1用戶,口令是test。要取消一個(gè)用戶的權(quán)限,使用revoke語(yǔ)句。revoke的語(yǔ)法非常類似于grant語(yǔ)句,除了to用from取代并且沒(méi)有identified by和with grant option子句,下面是用revoke刪除用戶權(quán)限的例子:
mysql> revoke all on test.* from test1@'192.168.1.0/255.255.255.0';
這句revoke就撤消了上面第二句grant創(chuàng)建的權(quán)限,但是test1用戶并沒(méi)有被刪除,必須手工從user表刪除:
mysql> delete from user where user='test1';
mysql> flush privileges;
這樣,test1用戶就徹底刪除了。
這些只是MySQL授權(quán)表的簡(jiǎn)單使用,更多詳細(xì)的資料請(qǐng)見(jiàn)MySQL提供的手冊(cè)。
php技術(shù):MySQL授權(quán)問(wèn)題總結(jié),轉(zhuǎn)載需保留來(lái)源!
鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標(biāo)記有誤,請(qǐng)第一時(shí)間聯(lián)系我們修改或刪除,多謝。