基于Yii框架如何实现批量更新,方法有几种
Admin 2022-07-11 群英技术资讯 1193 次浏览
这篇文章主要介绍“基于Yii框架如何实现批量更新,方法有几种”的相关知识,下面会通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“基于Yii框架如何实现批量更新,方法有几种”文章能帮助大家解决问题。本文实例讲述了Yii2.0实现的批量更新及批量插入功能。分享给大家供大家参考,具体如下:
批量更新
方法1
/**
* 批量更新循环周期
* @param array $condition
* $condition = ['advertise_id' => '','status' => '', 'weekdays'=>[1,2,3]] 查询条件
* $params = ['status' => '']
* @param $params
* @return bool
*/
public function batchUpdateAdSchedule($condition = [], $params)
{
if (count($condition) == 0 || !is_array($condition) || count($params) == 0) {
return false;
}
$conditions = ' 1 = 1 ';
$bind = [];
if (array_key_exists('advertise_id', $condition) && !empty($condition['advertise_id'])) {
$conditions .= ' AND `advertise_id` = :advertiseId';
$bind['advertiseId'] = $condition['advertise_id'];
}
if (array_key_exists('status', $condition) && !empty($condition['status'])) {
$conditions .= ' AND `status` = :status';
$bind['status'] = $condition['status'];
}
$result = AdvertiseSchedule::updateAll($params, $conditions, $bind);
return $result > 0 ? true : false;
}
方法2
/**
* 批量更新商品销量
* @param $params
* @return bool|int
* @throws \yii\db\Exception
*/
public function batchUpdateSalesNum($params)
{
if (count($params) == 0 || !is_array($params)) {
return false;
}
$sql = '';
foreach ($params as $key => $value) {
$sql .= 'UPDATE `morefun`.`mbb_goods` SET `sale_num` = `sale_num` -' . $value['amount'] . ' WHERE `id` =' . $value['goods_id'] . ';';
}
$result = Yii::$app->db->createCommand($sql)->execute();
return $result == 1 ? true : false;
}
批量插入
/**
* 批量插入
* @param $params
* @return int
* @throws \yii\db\Exception
*/
public function batchAddShopClassConn($params)
{
$connection = Yii::$app->db;
$queryBuilder = $connection->queryBuilder;
/*$sql = $queryBuilder->batchInsert('user', ['name', 'age'], [
['Tom', 30],
['Jane', 20],
['Linda', 25],
]);*/
$sql = $queryBuilder->batchInsert(shopClassConn::tableName(),
['shop_id', 'class_id'], $params);
return $connection->createCommand($sql)->execute();
}
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
1.php的版本:PHP7.3.0-dev(cli)(built:Mar18201800:28:55)(NTS)2.unless语法结构:unless($cond){statement;}语法作用:当$cond为假的时候,执行statement语句。3.代码修改词法分析文件:Zend/zend_langua
swoole为我们提供了平滑重启机制,我们只需要向swoole_server的主进程发送特定的信号,即可完成对server的重启。如:kill -USR1|-10 master_pid 重启所有的Worker进程。
本文主要给大家分享的是基于PHP的swoole 异步文件读写操作,小编觉得是比较实用的,因此分享给大家参考,感兴趣的朋友就跟随小编一起来了解一下吧。
swoole如果想要在开机启动时,自动运行你的swoole Server,可以在/etc/rc.local文件中加入/usr/bin/php /data/webroot/www.swoole.com/server.php。
php中配置Cookie加密:1、Cookie在客户端浏览器的传输的HTTP头也是明文的。通过加密cookie,可以保护您的应用程序对众多的攻击。2、分为Cookie篡改和跨应用程序使用Cookie。
成为群英会员,开启智能安全云计算之旅
立即注册关注或联系群英网络
7x24小时售前:400-678-4567
7x24小时售后:0668-2555666
24小时QQ客服
群英微信公众号
CNNIC域名投诉举报处理平台
服务电话:010-58813000
服务邮箱:service@cnnic.cn
投诉与建议:0668-2555555
Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008