mysql數據庫備份與還原命令


還原一個數據庫:mysql -h localhost -u root -p123456 www


備份一個數據庫:mysqldump -h localhost -u root -p123456 www > d:\www2008-2-26.sql


其中WWW為數據庫名


//以下是在程序中進行測試


//$command = “mysqldump –opt -h $dbhost -u $dbuser -p $dbpass $dbname | gzip > $backupFile”;
$command=”mysqldump -h localhost -u root -p123456 guestbook > guestbook2-29.sql”;
system($command);
echo “success”;


************************************************


備份MySQL數據庫的命令


mysqldump -hhostname -uusername -ppassword databasename > backupfile.sql
備份MySQL數據庫為帶刪除表的格式
備份MySQL數據庫為帶刪除表的格式,能夠讓該備份覆蓋已有數據庫而不需要手動刪除原有數據庫。


mysqldump -–add-drop-table -uusername -ppassword databasename > backupfile.sql
直接將MySQL數據庫壓縮備份


mysqldump -hhostname -uusername -ppassword databasename | gzip > backupfile.sql.gz
備份MySQL數據庫某個(些)表


mysqldump -hhostname -uusername -ppassword databasename specific_table1 specific_table2 > backupfile.sql
同時備份多個MySQL數據庫


mysqldump -hhostname -uusername -ppassword –databases databasename1 databasename2 databasename3 > multibackupfile.sql
僅僅備份數據庫結構


mysqldump –no-data –databases databasename1 databasename2 databasename3 > structurebackupfile.sql
備份服務器上所有數據庫


mysqldump –all-databases > allbackupfile.sql
還原MySQL數據庫的命令


mysql -hhostname -uusername -ppassword databasename < backupfile.sql
還原壓縮的MySQL數據庫


gunzip < backupfile.sql.gz | mysql -uusername -ppassword databasename
將數據庫轉移到新服務器


mysqldump -uusername -ppassword databasename | mysql –host=*.*.*.* -C databasename


幾個常用用例:
1.導出整個數據庫
mysqldump -u 用戶名 -p 數據庫名 > 導出的文件名
mysqldump -u root -p dataname >dataname.sql
這個時候會提示要你輸入root用戶名的密碼,輸入密碼后dataname數據庫就成功備份在mysql/bin/目錄中.


2.導出一個表
mysqldump -u 用戶名 -p 數據庫名 表名> 導出的文件名
mysqldump -u root -p dataname users> dataname_users.sql


3.導出一個數據庫結構
mysqldump -u wcnc -p -d –add-drop-table smgp_apps_wcnc >d:\wcnc_db.sql
-d 沒有數據 –add-drop-table 在每個create語句之前增加一個drop table


4.導入數據庫
常用source 命令
進入mysql數據庫控制台,
如mysql -u root -p


mysql>use 數據庫


然后使用source命令,后面參數為腳本文件(如這里用到的.sql)
mysql>source d:\wcnc_db.sql






mysqldump支持下列選項:
–add-locks
在每個表導出之前增加LOCK TABLES並且之后UNLOCK TABLE。(為了使得更快地插入到MySQL)。






–add-drop-table
在每個create語句之前增加一個drop table。






–allow-keywords
允許創建是關鍵詞的列名字。這由表名前綴於每個列名做到。






-c, –complete-insert
使用完整的insert語句(用列名字)。






-C, –compress
如果客戶和服務器均支持壓縮,壓縮兩者間所有的信息。






–delayed
用INSERT DELAYED命令插入行。






-e, –extended-insert
使用全新多行INSERT語法。(給出更緊縮並且更快的插入語句)






-#, –debug[=option_string]
跟蹤程序的使用(為了調試)。






–help
顯示一條幫助消息並且退出。






–fields-terminated-by=…






–fields-enclosed-by=…






–fields-optionally-enclosed-by=…






–fields-escaped-by=…






–fields-terminated-by=…






這些選擇與-T選擇一起使用,並且有相應的LOAD DATA INFILE子句相同的含義。
LOAD DATA INFILE語法。






-F, –flush-logs
在開始導出前,洗掉在MySQL服務器中的日志文件。






-f, –force,
即使我們在一個表導出期間得到一個SQL錯誤,繼續。






-h, –host=..
從命名的主機上的MySQL服務器導出數據。缺省主機是localhost。






-l, –lock-tables.
為開始導出鎖定所有表。






-t, –no-create-info
不寫入表創建信息(CREATE TABLE語句)






-d, –no-data
不寫入表的任何行信息。如果你只想得到一個表的結構的導出,這是很有用的!






–opt
同–quick –add-drop-table –add-locks –extended-insert –lock-tables。
應該給你為讀入一個MySQL服務器的盡可能最快的導出。






-pyour_pass, –password[=your_pass]
與服務器連接時使用的口令。如果你不指定“=your_pass”部分,mysqldump需要來自終端的口令。






-P port_num, –port=port_num
與一台主機連接時使用的TCP/IP端口號。(這用於連接到localhost以外的主機,因為它使用 Unix套接字。)






-q, –quick
不緩沖查詢,直接導出至stdout;使用mysql_use_result()做它。






-S /path/to/socket, –socket=/path/to/socket
與localhost連接時(它是缺省主機)使用的套接字文件。






-T, –tab=path-to-some-directory
對於每個給定的表,創建一個table_name.sql文件,它包含SQL CREATE 命令,和一個table_name.txt文件,它包含數據。注意:這只有在mysqldump運行在mysqld守護進程運行的同一台機器上的時候才工作。.txt文件的格式根據–fields-xxx和 –lines–xxx選項來定。






-u user_name, –user=user_name
與服務器連接時,MySQL使用的用戶名。缺省值是你的Unix登錄名。






-O var=option, –set-variable var=option
設置一個變量的值。可能的變量被列在下面。






-v, –verbose
冗長模式。打印出程序所做的更多的信息。






-V, –version
打印版本信息並且退出。






-w, –where=’where-condition’
只導出被選擇了的記錄;注意引號是強制的!
“–where=user=’jimf’” “-wuserid>1″ “-wuserid<1″






最常見的mysqldump使用可能制作整個數據庫的一個備份:
mysqldump –opt database > backup-file.sql






但是它對用來自於一個數據庫的信息充實另外一個MySQL數據庫也是有用的:
mysqldump –opt database | mysql –host=remote-host -C database
由於mysqldump導出的是完整的SQL語句,所以用mysql客戶程序很容易就能把數據導入了:
shell> mysqladmin create target_db_name
shell> mysql target_db_name < backup-file.sql
就是shell> mysql 庫名 < 文件名








//mysql權限管理


mysql中可以給你一個用戶授予如select,insert,update,delete等其中的一個或者多個權限,主要使用grant命令,用法格式為: 
grant 權限 on 數據庫對象 to 用戶 
一、grant 普通數據用戶,查詢、插入、更新、刪除 數據庫中所有表數據的權利。 
grant select on testdb.* to common_user@’%’ 
grant insert on testdb.* to common_user@’%’ 
grant update on testdb.* to common_user@’%’ 
grant delete on testdb.* to common_user@’%’ 
或者,用一條 mysql 命令來替代: 
grant select, insert, update, delete on testdb.* to common_user@’%’


二、grant 數據庫開發人員,創建表、索引、視圖、存儲過程、函數。。。等權限。 
grant 創建、修改、刪除 mysql 數據表結構權限。 
grant create on testdb.* to developer@’192.168.0.%’; 
grant alter on testdb.* to developer@’192.168.0.%’; 
grant drop on testdb.* to developer@’192.168.0.%’; 
grant 操作 mysql 外鍵權限。 
grant references on testdb.* to developer@’192.168.0.%’; 
grant 操作 mysql 臨時表權限。 
grant create temporary tables on testdb.* to developer@’192.168.0.%’; 
grant 操作 mysql 索引權限。 
grant index on testdb.* to developer@’192.168.0.%’; 
grant 操作 mysql 視圖、查看視圖源代碼 權限。 
grant create view on testdb.* to developer@’192.168.0.%’; 
grant show view on testdb.* to developer@’192.168.0.%’; 
grant 操作 mysql 存儲過程、函數 權限。 
grant create routine on testdb.* to developer@’192.168.0.%’; - now, can show procedure status 
grant alter routine on testdb.* to developer@’192.168.0.%’; - now, you can drop a procedure 
grant execute on testdb.* to developer@’192.168.0.%’;


三、grant 普通 dba 管理某個 mysql 數據庫的權限。 
grant all privileges on testdb to dba@’localhost’ 
其中,關鍵字 “privileges” 可以省略。


四、grant 高級 dba 管理 mysql 中所有數據庫的權限。 
grant all on *.* to dba@’localhost’


五、mysql grant 權限,分別可以作用在多個層次上。 
1. grant 作用在整個 mysql 服務器上: 
grant select on *.* to dba@localhost; - dba 可以查詢 mysql 中所有數據庫中的表。 
grant all on *.* to dba@localhost; - dba 可以管理 mysql 中的所有數據庫 
2. grant 作用在單個數據庫上: 
grant select on testdb.* to dba@localhost; - dba 可以查詢 testdb 中的表。 
3. grant 作用在單個數據表上: 
grant select, insert, update, delete on testdb.orders to dba@localhost; 
4. grant 作用在表中的列上: 
grant select(id, se, rank) on testdb.apache_log to dba@localhost; 
5. grant 作用在存儲過程、函數上: 
grant execute on procedure testdb.pr_add to ’dba’@’localhost’ 
grant execute on function testdb.fn_add to ’dba’@’localhost’


六、查看 mysql 用戶權限 
查看當前用戶(自己)權限: 
show grants; 
查看其他 mysql 用戶權限: 
show grants for dba@localhost;


七、撤銷已經賦予給 mysql 用戶權限的權限。 
revoke 跟 grant 的語法差不多,只需要把關鍵字 “to” 換成 “from” 即可: 
grant all on *.* to dba@localhost; 
revoke all on *.* from dba@localhost;


八、mysql grant、revoke 用戶權限注意事項 
1. grant, revoke 用戶權限后,該用戶只有重新連接 mysql 數據庫,權限才能生效。 
2. 如果想讓授權的用戶,也可以將這些權限 grant 給其他用戶,需要選項 “grant option“ 
grant select on testdb.* to dba@localhost with grant option; 
這個特性一般用不到。實際中,數據庫權限最好由 dba 來統一管理。


注意:修改完權限以后 一定要刷新服務,或者重啟服務,刷新服務用:flush privileges。




查看用戶權限
show  grants for 你的用戶


比如:
show grants for root@'localhost';


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM