在事务中使用闭包函数简化开发

2019年5月14日 · 80 字 · 1 分钟

闭包函数

PHP官方文档对于闭包函数的定义:

匿名函数(Anonymous functions),也叫闭包函数(closures),允许 临时创建一个没有指定名称的函数。最经常用作回调函数(callback)参数的值。当然,也有其它应用的情况。

简单来说,闭包函数也是一种数据类型,可以直接使用变量来存储、传参、调用等等。

事务

事务简单来说就是一个核心:

事务处理可以用来维护数据库的完整性,保证成批的 SQL 语句要么全部执行,要么全部不执行。

一般情况下,每一条SQL的执行情况都需要进行判断,如果执行成功则继续,否则回滚事务。以下是PDO事务代码:

$pdo = new PDO('mysql:host=localhost;dbname=demo', 'root', 'root');
try {
    $pdo->beginTransaction();
    //todo 业务代码
    $pdo->commit();
} catch (\Exception $e) {
    $pdo->rollBack();
    throw $e;
}

PHP实现

几乎所有事务都需要如此处理,但是这样重复代码太多,实际上只需要关心的部分是 业务代码 部分,使用闭包函数可以很好的解决这个问题。

闭包函数可以理解为具体的业务逻辑,不带任何事务相关操作,如果出现异常,会自动回滚事务。

PHP的简单实现代码如下:

function transaction(PDO $pdo, callable $callable)
{
    try {
        $pdo->beginTransaction();
        $result = call_user_func($callable, $pdo);
        $pdo->commit();
        return $result;
    } catch (\Exception $e) {
        $pdo->rollBack();
        throw $e;
    }
}

PHP调用方法代码如下:

transaction($pdo, function (PDO $pdo) {
    return $pdo->query('INSERT INTO `test` VALUES (1)');
});

结语

使用闭包函数去简化样板代码在生产中是很常见的,具体的设计模式应该是类似“模板方法模式”。