让新人快速理解ThinkPHP6中的事务操作
事务操作对很多新人来说,可能有点陌生,即使看了ThinkPHP6官方手册中事务操作的部分,也仍然不知所解。
下面就给大家介绍下事务操作。
一、先说说使用场景。
假设我需要给朋友转账1000元钱,正常的业务逻辑是:
1、银行从我的账户中扣除1000元
2、银行给朋友账户加上1000元。
如果一切顺利,则转账成功!
那么问题来了,如果我不小心把银行账户输错,导致银行查找不到我输入的银行账户,但是这个时候钱已经从我的账户扣除了,如何处理呢?
我们生活中经常说“如果钱打不过去,银行会退回来的”,就是这个意思。
2、事务操作定义。
那么通过上面的例子,我们理解下到底什么是事务操作,事务指的是逻辑上的一组操作,组成这组操作的各个单元要么全都成功,要么全都失败。
就如上面的打钱例子,要么打钱成功,如果不成功,需要把我的钱退回来,也就是返回到初始状态,也叫做“回滚”。
3、ThinkPHP6中的事务操作。
我们理解了事务操作的使用场景,那么在ThinkPHP6中如何使用呢?
我们看上面的例子,只有当我们插入记录成功的时候才会做删除操作,如果插入不成功,不会做删除操作。
比如我们故意写错一个字段name1,数据表中没有name1该字段,插入程序不会执行成功,那么下面的删除语句没有问题,但是他依然不会执行。
除此之外,我们还可以手动控制事务。看下面代码:
以上就是ThinkPHP6中的事务操作的内容,通过咱们实际生活中的例子讲解,大家对事务操作就可以很好的理解了。
一个简单的部门案例详解(PHP代码实例)
本文为php中文网认证作者:“易达”投稿,欢迎加入php中文网有偿投稿计划!
案例:
要求:
其中必须要使用的知识点:
1. 类的定义
2. 类的实例化
3. 对象的引用赋值=&
4. 析构函数
5. 构造函数
这个案例要实现的效果其实算很简单,但是重点是,你的思路很清楚吗?你的思路是否具备一定的条理性,或者说做了许多项目,你有没有总结出一套你自己的系统性的思路方案呢?我的总结如下:
3个分析:
1、流程分析
2、具体的实现分析
3、 数据库分析
3个执行:
1.创建数据库,初始化数据库数据( 项目的启动数据 )
2.创建类,实现类
3.写流程
接下来我们一个一个的分析
1、流程分析
1、获取所有部门信息
2、获取单个部门信息
3、写一个对象引用赋值=&的测试
例如$jordon1=&$jordon
4、在所有逻辑最后写一句话:应用程序到此为止
5、执行了一个类的析构函数
2、具体的实现分析
1、第一步:识别对象(找名词)
根据上面的流程我们得出的对象只有一个:
1.部门
2、第二步:识别对象的属性( 数据名词+结合现实世界去分析+结合具体的场景 )
1.部门:属性有:id,名称
3、第三步:识别对象的方法( 动词+结合现实世界去分析+结合具体的场景 )
1.部门 方法有
1.获取所有部门信息
2.获取单个部门信息
因为所有的数据都要保存到数据库,所有的数据都要从数据库获取,所以接下来
数据库分析:
表:(有多少个对象 至少就有多少个表)
1.部门 字段 = 对象的属性
分析完成后,我们接下来做具体的操作
1、创建数据库,初始化数据库数据( 项目的启动数据 )
创建数据库,名字我们就叫做depart
为数据库创建表,表明就做叫部门表
分析是否有初始化数据,(我们可以称之为项目的启动数据,没有这些数据,项目无法启动,)然后将这些初始化数据写入数据库
综上分析,初始化数据就是3个部门
所以接下来我们初始化数据库
2.创建类,实现类
创建部门类:
为了方便管理,我们把所有的类放到model文件夹中,然后这个类文件我们就叫做Depart.class.php,然后我们把上面分析得出来的类的属性和方法,写入部门类中
model/Depart.class.php
<?php
//部门类
class Depart{
//定义属性 id,名称
public $id = \”\”;
public $name = \”\”;
public $conn = \”\”;//数据库连接
public $tableName = \”depart\”;//表名
//构造函数
public function __construct( $id,$name ){
//初始化属性
$this->id = $id;
$this->name = $name;
//初始化行为 初始化方法
$this->initConn();
}
//析构函数 销毁数据库连接
public function __destruct(){
//销毁连接
if( $this->conn ){
mysqli_close( $this->conn );
echo \”销毁了连接<br/>\”;
}
}
//定义方法
//创建公共的方法 获取数据库连接
public function initConn(){
$config = Array(
\”hostname\”=>\”127.0.0.1\”,
\”database\”=>\”depart\”,
\”username\”=>\”root\”,
\”password\”=>\”root\”
);
$this->conn = mysqli_connect( $config[\’hostname\’],$config[\’username\’] ,$config[\’password\’],
$config[\’database\’]);
}
// 1.获取所有部门信息
public function getAll(){
//创建数据库连接
$conn = $this->conn;
//写sql
$sql = \” select * from \”.$this->tableName;
//执行sql
$result = mysqli_query( $conn,$sql );
//获取数据
// mysqli_fetch_all($result)//特点:不会包含字段名
$list = Array();
while( $row = mysqli_fetch_assoc( $result ) ){
$list[] = $row;
}
//返回数据
return $list;
}
// 2.获取单个部门信息
public function getOne( $id ){
//创建数据库连接
$conn = $this->conn;
//写sql
$sql = \” select * from \”.$this->tableName.\” where id= \”.$id;
//执行sql
$result = mysqli_query( $conn,$sql );
//获取数据
// mysqli_fetch_all($result)//特点:不会包含字段名
$list = Array();
while( $row = mysqli_fetch_assoc( $result ) ){
$list[] = $row;
}
//返回数据
return $list;
}
}
?>
3.写流程
接下来,我们根据流程分析的结果来写具体的流程,流程代码如下:
<?php
//引入类文件
require_once \”model/Depart.class.php\”;
//写流程
// 1.获取所有部门信息
//
$humanResourseDepartment = new Depart(2,\”行政部门\”);
//通过对象调用方法
$alllist = $humanResourseDepartment->getAll();
echo \”<b>所有部门信息为:</b><br/>\”;
print_r( $alllist );
echo \”<br/>\”;
// 2.获取单个部门信息 = 开发部门
$devDepartment = $humanResourseDepartment ->getOne( 1 );
echo \”<b>开发部门信息:</b> <br/>\”;
print_r( $devDepartment );
echo \”<br/>\”;
// 3.对象引用赋值=&的测试
// $jordon1=&$jordon
$humanResourseDepartment1 =& $humanResourseDepartment;
echo \”修改前:行政部门的名字为:\”.$humanResourseDepartment->name.\”<br/>\”;
//修改
$humanResourseDepartment1->name = \”人力部门\”;
echo \”修改后:行政部门的名字为:\”.$humanResourseDepartment->name.\”<br/>\”;
// 4.在所有逻辑最后写一句话:应用程序到此为止
echo \”<b>应用程序到此为止</b> <br/>\”;
// 5.执行了一个类的析构函数
?>
运行结果如下:
所有部门信息为:Array ( [0] => Array ( [id] => 1 [name] => 开发部门 ) [1] => Array ( [id] => 2 [name] => 行政部门 ) [2] => Array ( [id] => 3 [name] => 后勤部门 ) )开发部门信息:Array ( [0] => Array ( [id] => 1 [name] => 开发部门 ) )修改前:行政部门的名字为:行政部门修改后:行政部门的名字为:人力部门应用程序到此为止销毁了连接
完美解决PHP中文乱码问题
PHP中文乱码一般是字符集问题,编码主要有下面几个问题。
一.首先是PHP网页的编码
1. php文件本身的编码与网页的编码应匹配
a. 如果欲使用gb2312编码,那么php要输出头:header(“Content-Type: text/html; charset=gb2312\”),静态页面添加<meta http-equiv=\”Content-Type\” content=\”text/html; charset=gb2312\”>,所有文件的编码格式为ANSI,可用记事本打开,另存为选择编码为ANSI,覆盖源文件。
b. 如果欲使用utf-8编码,那么php要输出头:header(“Content-Type: text/html; charset=utf-8\”),静态页面添加<meta http-equiv=\”Content-Type\” content=\”text/html; charset=utf-8\”>,所有文件的编码格式为utf-8。保存为utf-8可能会有点麻烦,一般utf-8文件开头会有BOM,如果使用session就会出问题,可用editplus来保存,在editplus中,工具->参数选择->文件->UTF-8签名,选择总是删除,再保存就可以去掉BOM信息了。
2. php本身不是Unicode的,所有substr之类的函数得改成mb_substr(需要装mbstring扩展);或者用iconv转码。
二.PHP与Mysql的数据交互
PHP与数据库的编码应一致
1. 修改mysql配置文件my.ini或my.cnf,mysql最好用utf8编码
复制代码代码如下:
[mysql]
default-character-set=utf8
[mysqld]
default-character-set=utf8
default-storage-engine=MyISAM
在[mysqld]下加入:
default-collation=utf8_bin
init_connect=\’SET NAMES utf8\’
2. 在需要做数据库操作的php程序前加mysql_query(\”set names \’编码\’\”);,编码和php编码一致,如果php编码是gb2312那mysql编码就是gb2312,如果是utf-8那mysql编码就是utf8,这样插入或检索数据时就不会出现乱码了
三.PHP与操作系统相关
Windows和Linux的编码是不一样的,在Windows环境下,调用PHP的函数时参数如果是utf-8编码会出现错误,比如move_uploaded_file()、filesize()、readfile()等,这些函数在处理上传、下载时经常会用到,调用时可能会出现下面的错误:
Warning: move_uploaded_file()[function.move-uploaded-file]:failed to open stream: Invalid argument in …
Warning: move_uploaded_file()[function.move-uploaded-file]:Unable to move \’\’ to \’\’ in …
Warning: filesize() [function.filesize]: stat failed for … in …
Warning: readfile() [function.readfile]: failed to open stream: Invalid argument in ..
在Linux环境下用gb2312编码虽然不会出现这些错误,但保存后的文件名出现乱码导致无法读取文件,这时可先将参数转换成操作系统识别的编码,编码转换可用mb_convert_encoding(字符串,新编码,原编码)或iconv(原编码,新编码,字符串),这样处理后保存的文件名就不会出现乱码,也可以正常读取文件,实现中文名称文件的上传、下载。
其实还有更好的解决方法,彻底与系统脱离,也就不用考虑系统是何编码。可以生成一个只有字母和数字的序列作为文件名,而将原来带有中文的名字保存在数据库中,这样调用move_uploaded_file()就不会出现问题,下载的时候只需将文件名改为原来带有中文的名字。实现下载的代码如下
复制代码代码如下:
header(\”Pragma: public\”);
header(\”Expires: 0\”);
header(\”Cache-Component: must-revalidate, post-check=0, pre-check=0\”);
header(\”Content-type: $file_type\”);
header(\”Content-Length: $file_size\”);
header(\”Content-Disposition: attachment; filename=\\\”$file_name\\\”\”);
header(\”Content-Transfer-Encoding: binary\”);
readfile($file_path);
$file_type是文件的类型,$file_name是原来的名字,$file_path是保存在服务上文件的地址。
本文作者及来源:Renderbus瑞云渲染农场https://www.renderbus.com
文章为作者独立观点不代本网立场,未经允许不得转载。