一、常用sql 1.1幫助命令 1.2SQL語言分類 1.3普通常用命令 1.4TRUNCATE與DELTE區別 二、備份與恢復 2.1mysqldump進行資料庫備份 2.2備份表 2.3備份資料庫表結構(不包含數據) 2.4備份資料庫表數據(不包含表結構) 2.5同時將數據和表結構分離導出 2. ...
一、常用sql
1.1幫助命令
mysql help命令相當於linux的man命令;
help contents; #相當於linux man命令
update mysql.user set password= PASSWORD('123123') where user="root" and host="localhost"; #修改root用戶密碼
1.2SQL語言分類
1.數據查詢語言DQL
2.數據操作語言DML
3.事務處理語言TPL
4.數據控制語言DCL
5.數據定義語言DDL
6.指針控制需要CCL
1.3普通常用命令
show create database; #列印創建資料庫的語法
select database(); #列印use的資料庫
CREATE USER '用戶'@'主機' IDENTIFIED BY '密碼'; #授權用戶
rename table 原表名 to 新表名; #重命名錶
select id, name from test where id = 2 and name='mashy'; #select 查詢語句
mysql -e "select * from 庫名.表名" #使用-e參數,可在命令行執行MySQL命令
1.4TRUNCATE與DELTE區別
TRUNCATE:通過釋放存儲表數據所用的數據頁來刪除數據,並且只在事務日誌中記錄頁的釋放,因此使用的系統和事務日誌資源更少。
DELETE語句每刪除一行,並且會在事務日誌中為所刪除的每一行記錄一項。
TRUNCATE與不帶WHERE子句的DELETE語句功能相同:兩者均刪除表中的全部行,到TRUNCATE比DELETE速度更快。
二、備份與恢復
2.1mysqldump進行資料庫備份
mysqldump -u user -p password 參數 資料庫名 > 備份文件名.sql
mysqldump -u user -p password -B 資料庫名 > 備份文件名.sql # -B參數的作用是增加創建資料庫和連接資料庫的語句,並且後面可直接接多個庫名,即同時備份多個庫。
mysqldump -u user -p password -B 資料庫名 | gzip > 備份文件名.sql #指定壓縮命令gzip壓縮備份資料庫
mysqldump -u user -p password -A > 備份文件名.sql #備份所有的資料庫
2.2備份表
mysqldump -u user -p password 資料庫名 表名> 備份文件名.sql
#### 備份單個表
mysqldump -u user -p password 參數 資料庫名 表名1 表名2> 備份文件名.sql
#### 備份多個表
2.3備份資料庫表結構(不包含數據)
mysqldump -u user -p password -d 資料庫名 > 備份文件名.sql #-d參數表示備份資料庫表結構,不包含數據
2.4備份資料庫表數據(不包含表結構)
mysqldump -u user -p password -t 資料庫名 > 備份文件名.sql
2.5同時將數據和表結構分離導出
#需調整配置文件參數並重啟MySQL
#在[mysqld]模塊下增加secure_file_priv=''
mysqldump -u user -p password 資料庫名 表名 -T 備份目錄
2.6mysqldump工作原理
利用mysqldump命令備份數據的過程,實際上就是把數據(包括庫表)從MySQL庫里以SQL語句的形式直接輸出或者生成備份文件的過程,這種備份成SQL語句的方式稱為邏輯備份。
2.7取出mysql庫名
./bin/mysql -uroot -p123 -e "show databases" | egrep -v "_schema| atabase"
2.8binlog是什麼
Binlog是一個二進位格式的文件,用於記錄用戶對資料庫更新的SQL語句信息,例如更改資料庫庫表和更改內容的SQL語句都會記錄到binlog里,但是對錶庫等內容的查詢則不會記錄到日誌中。因為binlog文件里的數據就是寫入資料庫的數據,使用binlog文件恢複數據,稱之為二進位增量數據恢復
#開啟binlog文件
log_bin=mysql-bin
server_id=1
2.9記錄binlog位置的特殊參數(—master-data)
使用--master-data參數備份後,在備份的文件對應的SQL語句里會添加CHANGE
MASTER 語句及binlog文件及位置點信息。
當"--master-data=1"時,備份結果為可執行的"CHANGE MASTER..." 語句;當"--master-data=2"時,備份結果為註釋的"CHANGE MASTER"語句。
2.9.1鎖表備份
mysqldump 加上-x參數
innodb表特有的備份參數(—single-transaction)
mysqldump -u user -p password -B --master-data=2 --single-transaction 資料庫名 > 備份文件名.sql
#當使用mysqldump的“--single-transaction”參數對innodb表進行備份時,會開啟一個事務,並將整個備份過程放到一個事務里,以確保執行本次dump會話時,不會看到其他連接會話已經提交了的數據,即備份開始的時候表是什麼樣,備份出來就是什麼樣子。
2.9.2將表數據導出為純文本
select * from test into outfile "/data/test_1.txt" ; #導出時設置字元集
select * from test into outfile "/data/test_2.txt" character set utf8 ; #以指定的分隔符導出,這裡指定“-”為不同域之間的分隔符
select * from test into outfile "/data/test_3.txt" character set utf8 fields terminated by '-'; #導出時設置對欄位內容進行引用,此處是'"'雙引號
2.9.3導入表
mysql> load data infile '/data/test_1.txt' into table test ; #從/data/test_1.txt讀數據寫入test表中
三、恢複數據庫
1.進入mysql資料庫source 備份.sql
2.mysql 需要恢復的庫名 < 備份.sql
3.1mysql -e 參數查看mysql數據
mysql -u user -p password -e "select * from 庫名.表名;" #查看表數據
mysql -u user -p password -e "show processlist;" #查看SQL線程執行狀態
mysql -u user -p password -e "show full processlist;" #查看完整SQL線程狀態
show variables like "%_timeout%"; #產看超時參數配置
在my.cnf文件mysqld模塊設置timeout值
interactive_timeout=120
wait_timeout=120
#修改完成後重啟mysql資料庫使配置生效
3.2查看資料庫狀態命令
show global status; #查看整個資料庫運行的狀態信息
show processlist ; #查看正在執行的SQL語句,可能無法看全完整的SQL語句
show full processlist ; #查看正在執行的完整SQL語句。
show variables; #查看資料庫的配置參數信息
show variables like "%_timeout%"; #過濾查看
kill ID #殺掉SQL線程的命令,ID為線程號
show session status; #查看當前整個資料庫的運行狀態
show engine innodb status ; #顯示innodb引擎的性能狀態
3.3mysqladmin常用命令參數
mysqladmin password newpasswd #設置密碼
mysqladmin -uroot -ppasswd password newpasswd #修改密碼
mysqladmin -uroot -ppasswd status #查看狀態
mysqladmin -uroot -ppasswd -i 1 status #每秒查看一次狀態
mysqladmin -uroot -ppasswd extended-status #查看當前整個資料庫的運行狀態
mysqladmin -uroot -ppasswd processlist #查看執行的SQL語句信息
mysqladmin -uroot -ppasswd processlist -i 1 #每秒查看一次執行的SQL語句信息
mysqladmin -uroot -ppasswd shutdown #關閉mysql服務
mysqladmin -uroot -ppasswd variables #查看資料庫的配置參數信息
3.4解析指定庫的binlog日誌
mysqlbinlog -d oldboy mysql-bin.000001 -r bin.sql
#mysqlbinlog可以指定-d實現分庫導出binlog,如果使用-d參數,那麼在更新數據時,必須要有use庫名,才能分出指定庫的binlog。必須採用如下寫法:
use 庫名;
insert into test values(1,'huge');
下麵這種寫法就不行
insert into 庫名.test values(2,'oldgirl');
3.5binlog過期清理
在my.cnf中配置
expire_logs_days=7
#只保存7天內的binlog日誌
四、資料庫備份概念
4.1全量備份
全量數據就是資料庫中所有的數據(或某一個庫的全部數據);全量備份就是把資料庫中所有數據進行備份
4.2增量備份
增量數據就是指上一次全量備份數據之後到下一次全量備份數據之前資料庫所更新的數據。