事务安全在一些需求中是必须要保证的,比如购买商品后,需要生成订单并减少商品库存,如果一步失败则应回退数据。
在 WordPress 中 wpdb 封装了各种操作 MySQL 的方法,但是唯独缺少对事务的支持。
不过还好,wpdb 有一个 query 方法,可以直接调用 MySQL 命令。
使用举例:
function create_order($goods_id, $stock, $number) {
global $wpdb;
$wpdb->query('START TRANSACTION');
$wpdb->insert(
$wpdb->prefix . 'order',
[
'goods_id' => $goods_id,
'number' => $number,
'status' => 0,
'createtime' => current_time('mysql')
]
);
if ($wpdb->last_error) {
$wpdb->query('ROLLBACK');
return;
}
$wpdb->update(
$wpdb->prefix . 'goods',
[
'stock' => $stock - $number
],
[
'id' => $goods_id
]
);
if ($wpdb->last_error) {
$wpdb->query('ROLLBACK');
return;
}
$wpdb->query('COMMIT');
}
-
Loco Translate 一款专为WordPress设计的翻译插件WordPress Loco Translate是一款专为WordPress用户设计的翻译插件,它简化了主题和插件的多语言翻译过程。
-
WordPress后台待审文章显示气泡提示的方法之前小编分享过一篇《WordPress 后台菜单添加 badge-红点提示(气泡通知)》的文章,今天我简单说说待审文章(为全部文章类型显示待审角标提示)的气泡提示如何操作。
-
FluentSMTP一款功能强大且免费的WordPress SMTP插件FluentSMTP是一款功能强大且免费的SMTP插件,它支持为WordPress配置多个SMTP发送服务器。
-
追格小程序V2.5.8更新发布追格小程序是一款采用积木式理念的微信小程序构建框架,它巧妙融合了Uniapp与WordPress技术,打造出一个开源且无加密限制的开发环境。
-
WordPress必备:使用wp_get_theme()函数获取当前主题详情在WordPress中,wp_get_theme() 函数用于获取当前启用的主题或指定主题的信息。这个函数返回一个 WP_Theme 对象,该对象包含了主题的详细信息,如主题名称、版本、模板目录、样式表目录等。
-
Redis Object Cache WordPress对象缓存插件Redis Object Cache是一款功能强大、易于使用的WordPress对象缓存插件。通过合理配置和优化,可以显著提高网站的访问速度和用户体验。
暂无评论,抢个沙发...