日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問(wèn) 生活随笔!

生活随笔

當(dāng)前位置: 首頁(yè) > 运维知识 > 数据库 >内容正文

数据库

mysql的存储过程与事务_mysql的存储过程与事务入门

發(fā)布時(shí)間:2025/4/5 数据库 29 豆豆
生活随笔 收集整理的這篇文章主要介紹了 mysql的存储过程与事务_mysql的存储过程与事务入门 小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

存儲(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)題。

如果覺(jué)得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: 国产精品麻豆果冻传媒在线播放 | 污视频免费在线观看网站 | 日本久久中文字幕 | 日韩免费大片 | 欧美一区二区三区在线观看视频 | 国产精品久久久91 | 欧美激情视频一区二区三区在线播放 | 国产精品久久久久久久一区二区 | 日本成人动漫在线观看 | 女同在线观看 | 美女三级黄色片 | 天天色天天插 | 各种含道具高h调教1v1男男 | 国产女人18水真多18精品一级做 | 黄网av | 亚洲品质自拍视频网站 | 国产一级片黄色 | 天堂va欧美va亚洲va老司机 | 91爱爱·com| 日本成人动漫在线观看 | 日本在线视频一区二区三区 | 欧美 日韩 国产 一区 | 麻豆伊甸园| 日美毛片 | 亚洲午夜网 | 动漫美女视频 | 后进极品美女白嫩翘臀 | 96av视频| 三级网站在线免费观看 | 欧美日韩一区二区不卡 | 毛片基地免费 | 夜夜嗨av色一区二区不卡 | 国产黄色电影 | 一区二区三区四区精品视频 | 性欧美lx╳lx╳ | 狠狠躁日日躁夜夜躁av | 一级免费观看视频 | 一本色道无码道dvd在线观看 | 啪啪亚洲 | 伊人久久精品视频 | 免费国产黄色片 | 超碰在线看 | 国产99久一区二区三区a片 | 在线观看一区二区视频 | 成人尤物 | 爆乳熟妇一区二区三区 | 久久久精品一区二区 | 久久99精品久久久久久园产越南 | 欧美日韩xxx | 色香蕉影院 | 日韩电影第一页 | 精品国产乱码久久久久久牛牛 | 五月婷婷深深爱 | 国产一级大片 | 亚洲AV无码国产精品午夜字幕 | 六月激情综合网 | 瑟瑟在线观看 | 深爱开心激情 | 午夜福利电影一区二区 | 银杏av| 日韩成人黄色 | 爆操巨乳 | 午夜激情av | 国产午夜无码精品免费看奶水 | 亚洲自拍图片 | 91精品黄色 | av免费看在线 | 婷婷av在线 | 成人av高清 | 国产女人18毛片水真多18 | 欧美一级xxx| 成人福利网址 | 俄罗斯厕所偷拍 | 中文字幕久久熟女蜜桃 | 麻豆av一区二区三区在线观看 | 欧美另类色图 | 黄页网站在线播放 | xxx色| 午夜免费在线 | 泰剧19禁啪啪无遮挡 | 国产第四页 | 亚洲精品视频免费看 | 老司机一区二区三区 | 日皮毛片 | 夫妻啪啪呻吟x一88av | 91黄色免费 | 手机在线免费看av | 欧美日韩在线免费观看 | 欧美一区二区人人喊爽 | zzjj国产精品一区二区 | 精品人成 | 日本午夜三级 | 午夜影院在线观看视频 | 国产一级爱 | 中字幕视频在线永久在线观看免费 | 激情av在线播放 | 美女裸体跪姿扒开屁股无内裤 | 国产精品99久久久久久人 | 久久亚洲欧洲 |