mysqldump
只導(dǎo)出數(shù)據(jù)庫表結(jié)構(gòu)
mysqldump --opt -h 主機(jī)名或地址 -d 數(shù)據(jù)庫名 -u root -p密碼 > xxx.sql只導(dǎo)出數(shù)據(jù)
mysqldump -t 數(shù)據(jù)庫名 -uroot -p密碼 > xxx.sql導(dǎo)出數(shù)據(jù)和表結(jié)構(gòu)
mysqldump 數(shù)據(jù)庫名 -uroot -p密碼 > xxx.sql導(dǎo)出指定表結(jié)構(gòu)
mysqldump -uroot -p密碼 -B 數(shù)據(jù)庫名 --table 表名 > xxx.sql導(dǎo)出單表數(shù)據(jù)
mysqldump -h 主機(jī)地址 -u用戶名 -p密碼 數(shù)據(jù)庫名 表名 > xxx.sql導(dǎo)入數(shù)據(jù)
進(jìn)入mysql
use 數(shù)據(jù)庫
source xxx.sql
dev 上mysql 相關(guān)命令:
sudo service mysql start/stop/restart
mysql 5.6版本慢查詢配置參數(shù)
slow_query_log = 1
slow_query_log_file = XXX
long_query_time = 1
MySQL 事件調(diào)度器
介紹
事件調(diào)度器是在 MySQL 5.1 中新增的另一個(gè)特色功能,可以作為定時(shí)任務(wù)調(diào)度器,取代部分原先只能用操作系統(tǒng)任務(wù)調(diào)度器才能完成的定時(shí)功能。事件調(diào)度器是定時(shí)觸發(fā)執(zhí)行的,在這個(gè)角度上也可以稱作是”臨時(shí)的觸發(fā)器”。觸發(fā)器只是針對某個(gè)表產(chǎn)生的事件執(zhí)行一些語句,而事件調(diào)度器則是在某一個(gè)(間隔)時(shí)間執(zhí)行一些語句。事件是由一個(gè)特定的線程來管理的,也就是所謂的”事件調(diào)度器”。啟用事件調(diào)度器后,擁有 SUPER 權(quán)限的賬戶執(zhí)行 SHOW PROCESSLIST 就可以看到這個(gè)線程了。通過設(shè)定全局變量event_scheduler 的值即可動(dòng)態(tài)的控制事件調(diào)度器是否啟用。開啟事件調(diào)度器
SELECT @@event_scheduler; # 查看事件調(diào)度器是否開啟
SET GLOBAL event_scheduler = ON; # 開啟事件調(diào)度器,mysql重啟后會(huì)失效修改配置文件,開啟事件調(diào)度器
在 my.cnf 的 [mysqld] 下添加:
event_scheduler=ON
管理事件的相關(guān)命令
查看所有事件
show events查看事件創(chuàng)建信息
show create event <event_name>查看事件詳細(xì)信息
SELECT * FROM INFORMATION_SCHEMA.EVENTS WHERE EVENT_NAME = <event_name> AND EVENT_SCHEMA = <schema_name>關(guān)閉事件
ALTER EVENT <event_name> DISABLE開啟事件
ALTER EVENT <event_name> ENABLE刪除事件
DROP EVENT IF EXISTS <event_name>-
創(chuàng)建事件
CREATE EVENT [IF NOT EXISTS] <event_name>
ON SCHEDULE <schedule>
[ON COMPLETION [NOT] PRESERVE]
[ENABLE | DISABLE]
[COMMENT 'comment']
DO <sql_statement>;<schedule>:
AT TIMESTAMP [+ INTERVAL INTERVAL]
| EVERY INTERVAL [STARTS TIMESTAMP] [ENDS TIMESTAMP]INTERVAL:
quantity {YEAR | QUARTER | MONTH | DAY | HOUR | MINUTE |
WEEK | SECOND | YEAR_MONTH | DAY_HOUR | DAY_MINUTE |
DAY_SECOND | HOUR_MINUTE | HOUR_SECOND | MINUTE_SECOND}
ON SCHEDULE 計(jì)劃任務(wù),有兩種設(shè)定計(jì)劃任務(wù)的方式:
- AT 時(shí)間戳,用來完成單次的計(jì)劃任務(wù)。
- EVERY 時(shí)間(單位)的數(shù)量時(shí)間單位[STARTS 時(shí)間戳] [ENDS時(shí)間戳],用來完成重復(fù)的計(jì)劃任務(wù)
在兩種計(jì)劃任務(wù)中,時(shí)間戳可以是任意的TIMESTAMP 和DATETIME 數(shù)據(jù)類型,時(shí)間戳需要大于當(dāng)前時(shí)間。
在重復(fù)的計(jì)劃任務(wù)中,時(shí)間(單位)的數(shù)量可以是任意非空(Not Null)的整數(shù)式,時(shí)間單位是關(guān)鍵詞:YEAR,MONTH,DAY,HOUR,MINUTE 或者SECOND。
提示:
其他的時(shí)間單位也是合法的如:QUARTER, WEEK,YEAR_MONTH,DAY_HOUR,DAY_MINUTE,DAY_SECOND,HOUR_MINUTE,HOUR_SECOND, MINUTE_SECOND,不建議使用這些不標(biāo)準(zhǔn)的時(shí)間單位。
ON COMPLETION參數(shù)表示"當(dāng)這個(gè)事件不會(huì)再發(fā)生的時(shí)候",即當(dāng)單次計(jì)劃任務(wù)執(zhí)行完畢后或當(dāng)重復(fù)性的計(jì)劃任務(wù)執(zhí)行到了ENDS階段。而PRESERVE的作用是使事件在執(zhí)行完畢后不會(huì)被Drop掉,建議使用該參數(shù),以便于查看EVENT具體信息。
若干例子:
每秒插入一條記錄到數(shù)據(jù)表
CREATE EVENT e_test_insert
ON SCHEDULE EVERY 1 SECOND
DO INSERT INTO test.aaa VALUES (CURRENT_TIMESTAMP);5天后清空test表:
CREATE EVENT e_test
ON SCHEDULE AT CURRENT_TIMESTAMP + INTERVAL 5 DAY
DO TRUNCATE TABLE test.aaa;2007年7月20日12點(diǎn)整清空test表:
CREATE EVENT e_test
ON SCHEDULE AT TIMESTAMP '2007-07-20 12:00:00'
DO TRUNCATE TABLE test.aaa;每天定時(shí)清空test表:
CREATE EVENT e_test
ON SCHEDULE EVERY 1 DAY
DO TRUNCATE TABLE test.aaa;5天后開啟每天定時(shí)清空test表:
CREATE EVENT e_test
ON SCHEDULE EVERY 1 DAY
STARTS CURRENT_TIMESTAMP + INTERVAL 5 DAY
DO TRUNCATE TABLE test.aaa;每天定時(shí)清空test表,5天后停止執(zhí)行:
CREATE EVENT e_test
ON SCHEDULE EVERY 1 DAY
ENDS CURRENT_TIMESTAMP + INTERVAL 5 DAY
DO TRUNCATE TABLE test.aaa;5天后開啟每天定時(shí)清空test表,一個(gè)月后停止執(zhí)行:
CREATE EVENT e_test
ON SCHEDULE EVERY 1 DAY
STARTS CURRENT_TIMESTAMP + INTERVAL 5 DAY
ENDS CURRENT_TIMESTAMP + INTERVAL 1 MONTH
DO TRUNCATE TABLE test.aaa;每天凌晨一點(diǎn)執(zhí)行
CREATE EVENTevent_call_inproc
ON SCHEDULE EVERY 1 DAY
STARTS '2013-09-12 01:00:00'
ON COMPLETION PRESERVE ENABLE
DO call ty.inproc();每天凌晨三點(diǎn)執(zhí)行
create event event_call_defer
on schedule every 1 day
starts date_add(date(curdate() + 1),interval 3 hour)
on completion preserve enable
do call test.warn();每個(gè)月的一號凌晨1 點(diǎn)執(zhí)行
CREATE EVENT EVENT2
ON SCHEDULE EVERY 1 MONTH
STARTS DATE_ADD(DATE_ADD(DATE_SUB(CURDATE(),INTERVAL DAY(CURDATE())-1 DAY),INTERVAL 1 MONTH),INTERVAL 1 HOUR)
ON COMPLETION PRESERVE ENABLE
DO CALL STAT();每個(gè)季度一號的凌晨2點(diǎn)執(zhí)行
CREATE EVENT TOTAL_SEASON_EVENT
ON SCHEDULE EVERY 1 QUARTER
STARTS DATE_ADD(DATE_ADD(DATE( CONCAT(YEAR(CURDATE()),'-',ELT(QUARTER(CURDATE()),1,4,7,10),'-',1)),INTERVAL 1 QUARTER),INTERVAL 2 HOUR)
ON COMPLETION PRESERVE ENABLE
DO CALL SEASON_STAT();
- 每年1月1號凌晨四點(diǎn)執(zhí)行
CREATE EVENT TOTAL_YEAR_EVENT
ON SCHEDULE EVERY 1 YEAR
STARTS DATE_ADD(DATE(CONCAT(YEAR(CURDATE()) + 1,'-',1,'-',1)),INTERVAL 4 HOUR)
ON COMPLETION PRESERVE ENABLE
DO CALL YEAR_STAT();
[ON COMPLETION [NOT] PRESERVE]可以設(shè)置這個(gè)事件是執(zhí)行一次還是持久執(zhí)行,默認(rèn)為NOT PRESERVE。
- 每天定時(shí)清空test表(只執(zhí)行一次,任務(wù)完成后就終止該事件):
CREATE EVENT e_test
ON SCHEDULE EVERY 1 DAY
ON COMPLETION NOT PRESERVE
DO TRUNCATE TABLE test.aaa;
[ENABLE | DISABLE]可是設(shè)置該事件創(chuàng)建后狀態(tài)是否開啟或關(guān)閉,默認(rèn)為ENABLE。
[COMMENT 'comment']可以給該事件加上注釋。
修改事件
ALTER EVENT event_name
[ON SCHEDULE schedule]
[RENAME TO new_event_name]
[ON COMPLETION [NOT] PRESERVE]
[COMMENT 'comment']
[ENABLE | DISABLE]
[DO sql_statement]將每天清空test表改為5天清空一次:
ALTER EVENT e_test
ON SCHEDULE EVERY 5 DAY;
MySQL 預(yù)定義語句
介紹
借助預(yù)定義語句可以實(shí)現(xiàn)動(dòng)態(tài)SQL語句語法
定義
PREPARE
<stmt_name>
FROM
<preparable_stmt>
執(zhí)行
EXECUTE <stmt_name>注意
1> 即使 preparable_stmt 語句中的 ? 所代表的是一個(gè)字符串,你也不需要將 ? 用引號包含起來
2> 如果新的 PREPARE 語句使用了一個(gè)已存在的 stmt_name ,那么原有的將被立即釋放!
即使這個(gè)新的 PREPARE 語句因?yàn)殄e(cuò)誤而不能被正確執(zhí)行
3> PREPARE stmt_name 的作用域是當(dāng)前客戶端連接會(huì)話可見
4> 要釋放一個(gè)預(yù)定義語句的資源,可以使用 DEALLOCATE PREPARE 句法
5> 執(zhí)行語句中,如果 stmt_name 不存在,將會(huì)引發(fā)一個(gè)錯(cuò)誤
6> 如果在終止客戶端連接會(huì)話時(shí),沒有顯式地調(diào)用 DEALLOCATE PREPARE 句法釋放資源,服務(wù)器端會(huì)自己動(dòng)釋放它
7> PREPARE 語句不可以用于存儲(chǔ)過程,自定義函數(shù)!但從 MySQL 5.0.13 開始,它可以被用于存儲(chǔ)過程,仍不支持在函數(shù)中使用!
例子:
SET @skip=1; SET @numrows=5;
PREPARE STMT FROM "SELECT * FROM tbl LIMIT ?, ?";
EXECUTE STMT USING @skip, @numrows;
# 根據(jù)當(dāng)前日期創(chuàng)建表
set @tb_name = replace(current_date(), '-', '');
set @sqlcmd = concat("create table if not exists pay.", @tb_name, "(id int primary key);");
prepare stmt from @sqlcmd;
execute stmt;