MySQL許可權分配

來源:互聯網
上載者:User

 

 

 

 

 

 

 

 

第一招、mysql服務的啟動和停止

net stop mysql

net start mysql

第二招、登陸mysql

文法如下: mysql -u使用者名稱 -p使用者密碼

鍵入命令mysql -uroot -p, 斷行符號後提示你輸入密碼,輸入12345,然後斷行符號即可進入到mysql中了,mysql的提示符是:

mysql>

注意,如果是串連到另外的機器上,則需要加入一個參數-h機器IP

第三招、增加新使用者

格式:grant 許可權 on 資料庫.* to 使用者名稱@登入主機 identified by "密碼"

如,增加一個使用者user1密碼為password1,讓其可以在本機上登入, 並對所有資料庫有查詢、插入、修改、刪除的許可權。首先用以root使用者連入mysql,然後鍵入以下命令:

grant select,insert,update,delete on *.* to user1@localhost Identified by "password1";

如果希望該使用者能夠在任何機器上登陸mysql,則將localhost改為"%"。

如果你不想user1有密碼,可以再打一個命令將密碼去掉。

grant select,insert,update,delete on mydb.* to user1@localhost identified by "";

第四招: 操作資料庫

登入到mysql中,然後在mysql的提示符下運行下列命令,每個命令以分號結束。

1、 顯示資料庫列表。

show databases;

預設有兩個資料庫:mysql和test。 mysql庫存放著mysql的系統和使用者權限資訊,我們改密碼和新增使用者,實際上就是對這個庫進行操作。

2、 顯示庫中的資料表:

use mysql;

show tables;

3、 顯示資料表的結構:

describe 表名;

4、 建庫與刪庫:

create database 庫名;

drop database 庫名;

5、 建表:

use 庫名;

create table 表名(欄位列表);

drop table 表名;

6、 清空表中記錄:

delete from 表名;

7、 顯示表中的記錄:

select * from 表名;

第五招、匯出和匯入資料

1. 匯出資料:

mysqldump --opt test > mysql.test

即將資料庫test資料庫匯出到mysql.test檔案,後者是一個文字檔

如:mysqldump -u root -p123456 --databases dbname > mysql.dbname

就是把資料庫dbname匯出到檔案mysql.dbname中。

2. 匯入資料:

mysqlimport -u root -p123456 < mysql.dbname。

不用解釋了吧。

3. 將文本資料匯入資料庫:

文本資料的欄位資料之間用tab鍵隔開。

use test;

load data local infile "檔案名稱" into table 表名;

1:使用SHOW語句找出在伺服器上當前存在什麼資料庫:

mysql> SHOW DATABASES;

2:2、建立一個資料庫MYSQLDATA

mysql> CREATE DATABASE MYSQLDATA;

3:選擇你所建立的資料庫

mysql> USE MYSQLDATA; (按斷行符號鍵出現Database changed 時說明操作成功!)

4:查看現在的資料庫中存在什麼表

mysql> SHOW TABLES;

5:建立一個資料庫表

mysql> CREATE TABLE MYTABLE (name VARCHAR(20), sex CHAR(1));

6:顯示表的結構:

mysql> DESCRIBE MYTABLE;

7:往表中加入記錄

mysql> insert into MYTABLE values ("hyq","M");

8:用文本方式將資料裝入資料庫表中(例如D:/mysql.txt)

mysql> LOAD DATA LOCAL INFILE "D:/mysql.txt" INTO TABLE MYTABLE;

9:匯入.sql檔案命令(例如D:/mysql.sql)

mysql>use database;

mysql>source d:/mysql.sql;

10:刪除表

mysql>drop TABLE MYTABLE;

11:清空表

mysql>delete from MYTABLE;

12:更新表中資料

mysql>update MYTABLE set sex="f" where name='hyq';

posted on 2006-01-10 16:21 happytian 閱讀(6) 評論(0) 編輯 收藏 收藏至365Key

13:備份資料庫

mysqldump -u root 庫名>xxx.data

14:例2:串連到遠程主機上的MYSQL

假設遠程主機的IP為:110.110.110.110,使用者名稱為root,密碼為abcd123。則鍵入以下命令:

mysql -h110.110.110.110 -uroot -pabcd123

(注:u與root可以不用加空格,其它也一樣)

3、退出MYSQL命令: exit (斷行符號)

===========================================

MySQL的許可權系統圍繞著兩個概念:

1:認證->確定使用者是否允許串連資料庫伺服器

2:授權->確定使用者是否擁有足夠的許可權執行查詢請求等。

顯然從上面可知,如果認證不成功的話,哪麼授權肯定是無法進行的。在這裡我們要關注兩個表,分別是在MySQL資料庫中user表和db表。

user表在某種程度上是獨一無二的,因為它是唯一一個在許可權請求的認證和授權階段都起作用的表,也是唯一一個存數MySQL伺服器相關許可權的許可權表。在認證階段,它只是負責為使用者授權訪問MySQL伺服器,確定使用者每小時的最大串連數和最大並發數;在授權階段,user確定允許訪問伺服器的使用者是否被賦予了操作資料庫的全域許可權,確定使用者每小時的最大查詢數和更新數。

db表用於為每個使用者針對每個資料庫賦予許可權。具體的可以查看db的欄位。

使用者和許可權管理命令:

create user :用於建立新的使用者賬戶(從5.0版本開始有這個命令),在建立這個使用者的時候不分配任何許可權,需要在建立之後通過grant命令來給改使用者指派相應的許可權。

eg:create user guest@localhost identified by '123456';
grant select on mydb.* to guest@localhost;

drop user:刪除一個使用者賬戶(注意在4.1.1版本之前只能刪除沒有任何許可權的賬戶,5.0.2之後可以刪除任何賬戶)

eg:drop user guest;

rename user:可以實現重新命名一個使用者帳號。

grant:用於管理存取權限,也就是給使用者帳號授權。當然它同樣可以建立一個新的使用者賬戶。

eg:grant select, insert, update, delete on new_db.* to guest@'%' identified by '88888888';

grant 許可權 on 資料庫.表 to 使用者 @ 訪問方式 identified by 密碼

grant select on mydb.* to guest@localhost identified by '123456';

BTW:如果需要一個空密碼或者無密碼的賬戶,必須先用Create User命令,然後通過

grant來分配許可權。如果如下操作:

grant all privileges on mydb.* to visitor@'%' ;而在資料庫user表中沒有先建立visitor

使用者,則會發生1133錯誤"Can't find any matching row in the user table"。grant只能創

有密碼的賬戶。

revoke:刪除一個賬戶,具體查看MySQL的文檔。

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.