MySQL 事务主要用于处理操作量大,复杂度高的数据。比如说,在人员管理系统中,你删除一个人员,你即需要删除人员的基本资料,也要删除和该人员相关的信息,如信箱,文章等等,这样,这些数据库操作语句就构成一个事务!
一般来说,事务是必须满足4个条件(ACID): Atomicity(原子性或不可分割性)、Consistency(一致性)、Isolation(隔离性或独立性)、Durability(持久性)
1,显式的开始一个事务:
start transaction
或
begin
2, 做保存点,一个事务中可以有多个保存点:
savepoint 保存点名称
3, 提交事务,并使数据库中进行的所有修改成为永久性的:
commit
或
commit work
4,回滚结束用户的事务,并撤销正在进行的所有未提交的修改:
rollback
或
rollback work
5.删除一个事务的保存点,若没有指定保存点,执行该语句操作会抛错。
release savepoint 保存点名称
6.将事务滚回标记点:
rollback to 标记点
7.设置事务的隔离级别。InnoDB 存储引擎提供事务的隔离级别有READ UNCOMMITTED、READ COMMITTED、REPEATABLE READ 和 SERIALIZABLE。
set transaction
1.用 begin , rollback , commit 来实现事务处理。
2.用 set 来改变 MySQL 的自动提交模式。
<?php $handler=mysql_connect("localhost","root","password"); mysql_select_db("task"); mysql_query("SET AUTOCOMMIT=0");//设置为不自动提交,因为MYSQL默认立即执行 mysql_query("BEGIN");//开始事务定义 if(!mysql_query("insert into trans (id) values("2")")) { mysql_query("ROOLBACK");//判断当执行失败时回滚 } if(!mysql_query("insert into trans (id) values("4")")) { mysql_query("ROOLBACK");//判断执行失败回滚 } mysql_query("COMMIT");//执行事务 mysql_close($handler); ?>
1、从左开始截取字符串left(str, length)说明:left(被截取字段,截取长度)例:select left(content,200) as abst...
一个简单示例:package mainimport ("fmt""github.com/gogf/gf/v2/text/gregex")func main() {match, _ := gregex.MatchString(`...
Request对象支持非常完美的请求校验能力,通过给结构体属性绑定v标签即可。需要注意的是,从goframev1.16版本开始,...
GoFrame框架提供了完善的Session管理能力,由gsession组件实现。由于Session机制在HTTP服务中最常用,因此...
有时,我们并不需要在路径操作函数中使用依赖项的返回值。或者说,有些依赖项不返回值。但仍要执行或解析该依赖项。对于这种情况...