mysql的存储过程与事务_mysql的存储过程与事务入门
存儲(chǔ)過(guò)程是:
通過(guò)一系列的SQL語(yǔ)句, 根據(jù)傳入的參數(shù)(也可以沒(méi)有), 通過(guò)簡(jiǎn)單的調(diào)用,
完成比單個(gè)SQL語(yǔ)句更復(fù)雜的功能, 存儲(chǔ)在數(shù)據(jù)庫(kù)服務(wù)器端,只需要編譯過(guò)一次之后再次使用都不需要再進(jìn)行編譯。主要對(duì)存儲(chǔ)的過(guò)程進(jìn)行控制。
事務(wù)是一系列的數(shù)據(jù)更改操作組成的一個(gè)整體。一旦事務(wù)中包含的某操作失敗或用戶中止,用戶可以控制將事務(wù)體中所有操作撤消,返回事務(wù)開(kāi)始前的狀態(tài)。
事務(wù)中的操作是一個(gè)整體,要么整體完成,要么全部不做。從而保證了數(shù)據(jù)的完整性。
Mysql中,MyISAM存儲(chǔ)引擎不支持事務(wù),InnoDB支持。
兩者都是數(shù)據(jù)庫(kù)中非常重要的知識(shí)。
一、存儲(chǔ)過(guò)程
創(chuàng)建一張test1表的存儲(chǔ)過(guò)程
mysql> delimiter $ -- delimiter $是設(shè)置 $為命令終止符號(hào),代替默認(rèn)的分號(hào),因?yàn)榉痔?hào)有其他用處.
mysql> create procedure sp_test1()
-> begin
-> create table test1(id int,name varchar(100));
->insert into test1 values(1,'lilei');
-> select * from test1;
-> end
-> $
Query OK, 0 rows affected (0.00 sec)
mysql> delimiter ; //恢復(fù)分號(hào)作為分隔終止符號(hào)
調(diào)用存儲(chǔ)過(guò)程
mysql> call sp_test1();
創(chuàng)建帶參數(shù)的存儲(chǔ)過(guò)程
mysql> delimiter $ -- delimiter $是設(shè)置 $為命令終止符號(hào),代替默認(rèn)的分號(hào),因?yàn)榉痔?hào)有其他用處.
mysql> create procedure sp_test(IN pi_id int, OUT po_name varchar(10))
-> begin
-> select * from test.tb_test;
-> select tb_test.name into po_name from test.tb_test where tb_test.id = pi_id;
-> end
-> $
Query OK, 0 rows affected (0.00 sec)
mysql> delimiter ; -- 恢復(fù)分號(hào)作為分隔終止符號(hào)
5.調(diào)用存儲(chǔ)過(guò)程
mysql> set @po_name='';
Query OK, 0 rows affected (0.00 sec)
mysql> call sp_test(1,@po_name);
二、事務(wù)處理
mysql中如果是不支持事務(wù)的引擎,如myisam,則是否commit都沒(méi)有效的。
如果是支持事務(wù)的引擎,如innodb,則有系統(tǒng)參數(shù)設(shè)置是否自動(dòng)commit,查看參數(shù)如下:
mysql> show variables like '%autocommit%';
+---------------+-------+
| Variable_name | Value |
+---------------+-------+
| autocommit | ON |
+---------------+-------+
1 row in set (0.00 sec)
mysql>
顯示結(jié)果為on表示事務(wù)自動(dòng)提交,也即不用手工去commit。
當(dāng)然,你可以設(shè)置其為OFF,然后自己手工去commit。
使用了commit后你不可以回退,它會(huì)永久改變你的數(shù)據(jù),而不使用只是臨時(shí)改變,它把改變后的內(nèi)容備份了一份在日志中,你可以rollback還原回來(lái),看情況而用了。
PHP中使用事務(wù)實(shí)例
$handler=mysql_connect("localhost","root","password");
mysql_select_db("task");
mysql_query("SET AUTOCOMMIT=0");//設(shè)置為不自動(dòng)提交,因?yàn)镸YSQL默認(rèn)立即執(zhí)行
mysql_query("BEGIN");//開(kāi)始事務(wù)定義
if(!mysql_query("insert into trans (id) values('2')"))
{
mysql_query("ROLLBACK");//判斷當(dāng)執(zhí)行失敗時(shí)回滾
}
if(!mysql_query("insert into trans (id) values('4')"))
{
mysql_query("ROLLBACK");//判斷執(zhí)行失敗回滾
}
mysql_query("COMMIT");//執(zhí)行事務(wù)
mysql_close($handler);
?>
Mysql控制臺(tái)事務(wù)處理
mysql> use test;
Database changed
mysql> CREATE TABLE `dbtest`(
-> id int(4)
-> ) TYPE=INNODB;
Query OK, 0 rows affected, 1 warning (0.05 sec)
mysql> select * from dbtest
-> ;
Empty set (0.01 sec)
mysql> begin; //開(kāi)啟事務(wù)
Query OK, 0 rows affected (0.00 sec)
mysql> insert into dbtest value(5);//插入數(shù)據(jù),表中數(shù)據(jù)臨時(shí)改變,可回滾
Query OK, 1 row affected (0.00 sec)
mysql> insert into dbtest value(6);//插入數(shù)據(jù),表中數(shù)據(jù)臨時(shí)改變,可以回滾
Query OK, 1 row affected (0.00 sec)
mysql> commit; //提交,表中臨時(shí)數(shù)據(jù)不可回滾
Query OK, 0 rows affected (0.00 sec)
mysql> select * from dbtest;
+------+
| id |
+------+
| 5 |
| 6 |
+------+
2 rows in set (0.00 sec)
mysql> begin; //開(kāi)啟事務(wù)
Query OK, 0 rows affected (0.00 sec)
mysql> insert into dbtest values(7); //插入數(shù)據(jù),表中數(shù)據(jù)臨時(shí)改變
Query OK, 1 row affected (0.00 sec)
mysql> rollback; //回滾到事務(wù)開(kāi)始前數(shù)據(jù)
Query OK, 0 rows affected (0.00 sec)
mysql> select * from dbtest;
+------+
| id |
+------+
| 5 |
| 6 |
+------+
2 rows in set (0.00 sec)
總結(jié)
以上是生活随笔為你收集整理的mysql的存储过程与事务_mysql的存储过程与事务入门的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: 钉钉订烟怎么看下次能订多少烟?
- 下一篇: win10 配置 maven_home