tp中怎么执行mysql事务_tp中使用事务

是什么

事务是为了防止,多个操作,其中有失败,数据有部分被执行成功的时候使用的。

比如,银行,用户转账。张三钱扣了,结果李四钱还增加!

这个时候需要使用事务,确保张三钱扣了,李四的钱也增加,才真正的成功!

能干嘛

确保数据的一致性!

如何使用呢?

/**

* 启动事务

* @access public

* @return void

*/

public function startTrans() {

$this->commit();

$this->db->startTrans();

return ;

}

/**

* 提交事务

* @access public

* @return boolean

*/

public function commit() {

return $this->db->commit();

}

/**

* 事务回滚

* @access public

* @return boolean

*/

public function rollback() {

return $this->db->rollback();

}

使用任何的model对象都可以开启。

// 开启事务

$mgoodsModel->startTrans();

$errcount = 0;

...

if ($errcount == 0) {

// 提交事务

$mgoodsModel->commit();

$this->outData['code'] = 1;

$this->outData['msg'] = '添加成功';

$this->printOut();

} else {

// 事务回滚

$mgoodsModel->rollback();

$this->outData['code'] = 2;

$this->outData['msg'] = '添加失败';

$this->printOut();

}

小结。人生在于折腾,编程在于折腾,工作在于折腾。折腾过的东西,才属于你。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/327931.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

TRUNCATE vs DELETE命令

TRUNCATE vs DELETE命令 作用:用于完全清空表数据 , 但表结构 , 索引 , 约束等不变 ; 语法: TRUNCATE [TABLE] table_name;-- 清空年级表 TRUNCATE grade注意:区别于DELETE命令 相同 : 都能删除数据 , 不删除表结构 , 但TRUNCATE速度更快 …

mysql 时间 1_(转)mysql日期时间函数1

MySQL 日期跟时间函数(一)作者: Mr.ZhangMySQL 日期跟时间的样式在MySQL 中有很多有用处的日期跟时间函数。我们常常看到许多应用于日期的计算是在代码方面上进行的,但是其实他们完全可以使用MySQL中自带的函数来实现。在我们实际的查看MySQL的时间跟日期…

ASP.NET Core 整合Autofac和Castle实现自动AOP拦截

前言: 除了ASP.NETCore自带的IOC容器外,我们还可以使用其他成熟的DI框架,如Autofac,StructureMap等(笔者只用过Unity,Ninject和Castle)。 1.ASP.NET Core中的Autofac 首先在Project.json的Depen…

hibernate多对多、正向工程创建数据表——访问温馨提示

大家都知道,hibernate可以反向生成实体类以及配置文件,但是正向的可能做的人并不是很多,什么是正向,什么是反向呢,正向指的是先有了实体类(entity),然后在根据你的实体类通过hiberna…

SQL---空字符串不等于null

查询没有写家庭住址的同学 SELECT studentname FROM student WHERE Address IS NULL; 空字符串不等于null,所以输入的是空字符串,仍然可以查到 正确做法 SELECT studentname FROM student WHERE Address’’ OR Address IS NULL;

Redis安装与配置( Windows10 )

Redis安装与配置( Windows10 ) 2018-09-22 17:54:21 gcl_air 阅读数 13357更多 分类专栏: redis 版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。 本文链接…

我为什么选择Angular 2?

没有选择是痛苦的,有太多的选择却更加痛苦。而后者正是目前前端领域的真实写照。新的框架层出不穷:它难吗?它写得快吗?可维护性怎样?运行性能如何?社区如何?前景怎样?好就业吗&#…

java io系列09之 FileDescriptor总结

转载自 java io系列09之 FileDescriptor总结FileDescriptor 介绍 FileDescriptor 是“文件描述符”。FileDescriptor 可以被用来表示开放文件、开放套接字等。以FileDescriptor表示文件来说:当FileDescriptor表示某文件时,我们可以通俗的将FileDescri…

mod auth mysql_Apache使用mysql认证用户

使用MySQL进行认证第1步:下载MySQL认证模块,并更名为mod_auth_mysql.so文件,并保存在apache的modules目录下第2步:apache要加载此功能模块LoadModule 模块名 所在的目录示例:LoadModule mysql_auth_module modules/mod…

count() * ,1,字段 三兄弟

/COUNT:非空的/ SELECT COUNT(studentname) FROM student; SELECT COUNT(*) FROM student; SELECT COUNT(1) FROM student; /推荐/ – 从含义上讲,count(1) 与 count() 都表示对全部数据行的查询。 – count(字段) 会统计该字段在表中出现的次数,忽略字…

拉取git的分支项目

1.空文件夹 git clone xxx 2.进入项目 重新git bash 3.git checkout 1.1(分支名) 分支切换成功

Jdk8一行代码读取文件

转载自 Jdk8一行代码读取文件JDK7中引入了新的文件操作类java.nio.file.File,它包含了很多有用的方法来操作文件,比如检查文件是否为隐藏文件,或者是检查文件是否为只读文件。开发者还可以使用Files.readAllBytes(Path)方法把整个文件读入内…

帅呆了!微软即将发布 Visual Studio for Mac 预览版

编者注:Visual Studio for Mac - Introducing Visual Studio for Mac 这篇英文原文链接现在已无法访问,猜测这篇文章应该是在 Connect (); 2016 宣布这一消息后发布,可能是被提前误发布了。 在即将在 11 月 16 日举行的 Connect (); 2016 线上…

mysql外键引用语法_mysql – 外键语法

我先创建了Teacher表,其描述是mysql> desc teacher;------------------------------------------------------| Field | Type | Null | Key | Default | Extra |------------------------------------------------------| TEACHER_ID | varchar(3) | NO | PRI | NULL | || T…

having vs where

SELECT subjectname,AVG(studentresult) AS 平均分,MAX(StudentResult) AS 最高分,MIN(StudentResult) AS 最低分 FROM result AS r INNER JOIN subject AS s ON r.subjectno s.subjectno GROUP BY r.subjectno HAVING 平均分>80; /* where写在group by前面. 要是放在分组…

.Net Core 之 Ubuntu 14.04 部署过程

No.1 准备应用程序 1. 创建.Net Core Web项目 2. 使用VS2015发布 No.2 安装.Net Core for Ubuntu Ubuntu的安装就不介绍了,百度搜索一大堆。本人用的VMWare,装好Tools很方便。 1. 添加dotnet源 sudo sh -c echo "deb [archamd64] https://apt-mo.tr…

修改Sublime Text3 的侧边栏字体大小

修改Sublime Text3 的侧边栏字体大小 2018-07-19 19:08:30 呐觞 阅读数 291 版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。 本文链接:https://blog.csdn.net/qq_35159647/article…

JAVA 对象序列化(二)——Externalizable

转载自 JAVA 对象序列化(二)——Externalizable在Java对象序列化(一)——Serializable一文中我们可以看到,Java默认的序列化机制非常简单,而且序列化后的对象不需要再次调用构造器重新生成,但…

事务的ACID原则

事务的ACID原则 原子性(Atomic) 整个事务中的所有操作,要么全部完成,要么全部不完成,不可能停滞在中间某个环节。事务在执行过程中发生错误,会被回滚(ROLLBACK)到事务开始前的状态,就像这个事务…