YII 自封装的批量修改的mysql操作类
<?php
/**
* Created by PhpStorm.
* User: yufen
* Date: 2018/8/31
* Time: 9:54
*/ namespace app\base; use yii\db\ExpressionInterface;
use Yii; trait DB
{
private static function changeFormat($val)
{
$db = Yii::$app->db;
if (is_string($val)) {
$val = $db->quoteValue($val);
} elseif (is_float($val)) {
$val = \yii\helpers\StringHelper::floatToString($val);
} elseif ($val === false) {
$val = 0;
} elseif ($val === null) {
$val = 'NULL';
}
return $val;
} private static function batchUpsertColumns($table, $columns, $rows, $updateColumns)
{
if (empty($rows)) {
return '';
}
$db = Yii::$app->db;
$schema = $db->getSchema();
if (($tableSchema = $schema->getTableSchema($table)) !== null) {
$columnSchemas = $tableSchema->columns;
} else {
$columnSchemas = [];
} $values = [];
foreach ($rows as $row) {
$vs = [];
foreach ($row as $i => $value) {
if (isset($columns[$i], $columnSchemas[$columns[$i]])) {
$value = $columnSchemas[$columns[$i]]->dbTypecast($value);
}
$value = self::changeFormat($value);
$vs[] = $value;
}
$values[] = '(' . implode(', ', $vs) . ')';
} if (empty($values)) {
return '';
}
foreach ($columns as $i => $name) {
$columns[$i] = $schema->quoteColumnName($name);
}
$sql = sprintf('INSERT INTO %s %s VALUES %s', $schema->quoteTableName($table), '(' . implode(',', $columns) . ')', implode(', ', $values));
if (!is_array($updateColumns) || empty($updateColumns)) {
return $sql;
}
$sets = [];
foreach ($updateColumns as $key => $val) {
$val = isset($columnSchemas[$key]) ? $columnSchemas[$key]->dbTypecast($val) : $val;
if ($val instanceof ExpressionInterface) {
$placeholder = $db->getQueryBuilder()->buildExpression($val);
} else if (is_numeric($val)) {
$placeholder = is_float($val) ? \yii\helpers\StringHelper::floatToString($val) : $val;
} else {
$placeholder = $db->quoteValue($val);
}
$sets[] = $db->quoteColumnName($key) . '=' . $placeholder;
}
return $sql . ' ON DUPLICATE KEY UPDATE ' . implode(', ', $sets);
} private static function batchUpdateColumns($table, $columns, $condition, &$params)
{
if (empty($columns)) {
return '';
}
$db = Yii::$app->db;
$schema = $db->getSchema();
if (($tableSchema = $schema->getTableSchema($table)) !== null) {
$columnSchemas = $tableSchema->columns;
} else {
$columnSchemas = [];
}
$value = [];
foreach ($columns as $rows) {
$name = $rows['name'];
$target = $rows['target'];
$vs = [];
foreach ($rows['data'] as $key => $val) {
$val = isset($columnSchemas[$name]) ? $columnSchemas[$name]->dbTypecast($val) : $val;
$key = isset($columnSchemas[$target]) ? $columnSchemas[$target]->dbTypecast($key) : $key;
$key = self::changeFormat($key);
if ($val instanceof ExpressionInterface) {
$val = $db->getQueryBuilder()->buildExpression($val, $params);
} else {
$val = $db->getQueryBuilder()->bindParam($val, $params);
}
$vs[] = ' WHEN ' . $key . ' THEN ' . $val;
}
$value[] = $schema->quoteColumnName($name) . '= CASE ' . $schema->quoteColumnName($target) . implode('', $vs) . ' END ';
}
$sql = sprintf('UPDATE %s SET %s', $schema->quoteTableName($table), implode(',', $value));
$where = $db->getQueryBuilder()->buildWhere($condition, $params);
return $where === '' ? $sql : $sql . ' ' . $where;
} /**upsert的拓展,批量操作
* eg:
* $res = self::batchUpsert('table', ['cid', 'goods', 'created'], [
* [1, 'test1', time()],
* [2, 'test2', time()]
* ], [
* 'goods' => new Expression('VALUES(goods)'),
* 'created'=>time()
* ]);
*
* @param $table
* @param $columns
* @param $rows
* @param $updateColumns
* @return int
*/
public static function batchUpsert($table, $columns, $rows, $updateColumns)
{
$db = Yii::$app->db;
$table = $db->quoteSql($table);
$sql = self::batchUpsertColumns($table, $columns, $rows, $updateColumns);
return $db->createCommand()->setRawSql($sql)->execute();
} /**批量更改
* eg
*self::batchUpdate('shop', [
* ['name'=>'goods','target'=>'tid','data'=>['1'=>'认真的么','2'=>'你是认真的么','3'=>'你确定你是认真的么???']],
* ['name'=>'created','target'=>'tid','data'=>['1'=>$_SERVER['REQUEST_TIME'],'2'=>$_SERVER['REQUEST_TIME'],'3'=>$_SERVER['REQUEST_TIME']]]
* ],['in','tid',[1,2,3]]);
* @param $table
* @param $rows
* @param string $condition
* @param array $params
* @return int
*/
public static function batchUpdate($table, $rows, $condition = '', $params = [])
{
$db = Yii::$app->db;
$table = $db->quoteSql($table);
$sql = self::batchUpdateColumns($table, $rows, $condition, $params);
return $db->createCommand()->setRawSql($sql)->bindValues($params)->execute();
}
}
以上的类通过自封装的batchUpsert,batchUpdate,是在YII环境下封装的
batchUpsert的运用方法如下
$res = self::batchUpsert('shop', ['cid', 'goods', 'created'], [
[1, 'text1', time()],
[2, 'text1', time()],
[3, 'text1', time()]
], [
'goods' => new Expression('VALUES(goods)'),
'created' => $_SERVER['REQUEST_TIME']
]);
batchUpdate的运用方法如下
self::batchUpdate('shop', [
['name'=>'goods','target'=>'tid','data'=>['1'=>'认真的么','2'=>'你是认真的么','3'=>'你确定你是认真的么???']],
['name'=>'created','target'=>'tid','data'=>['1'=>$_SERVER['REQUEST_TIME'],'2'=>$_SERVER['REQUEST_TIME'],'3'=>$_SERVER['REQUEST_TIME']]]
],['in','tid',[1,2,3]]);
YII 自封装的批量修改的mysql操作类的更多相关文章
- ArcGIS模型构建器案例教程-批量修改工作空间所有要素类的空间参考
ArcGIS模型构建器案例教程-批量修改工作空间所有要素类的空间参考 目的:批量修改工作空间所有要素类的空间参考(坐标系) 工具名称:WorkspaceChangeSpatialReference 使 ...
- IDEA批量修改变量名操作
批量修改变量名操作:shift+F6选中变量---->修改变量---->Enter回车
- php--->单例模式封装mysql操作类
php 单例模式封装mysql操作类 单例模式的必要条件(三私一公) 私有的成员属性--防止类外引入这个存放对象的属性 私有的构造方法--为了防止在类外使用new关键字实例化对象 私有的克隆方法--为 ...
- ecshop的Mysql操作类
摘要,这是直接摘抄的ecshop的mysql操作类:不过他这里的缓存是用的文件缓存,我们如果想直接使用,可以替换成memcache的或者redis的! <?php /** * ECSHOP MY ...
- PHP:自己写的mysql操作类
a{ font-weight: bold; display: block; text-align: center; color: #5887bf; font-size: 22px; } .conten ...
- Angular4+NodeJs+MySQL 入门-02 MySql操作类
NodeJs操作MySQL类 此类封装了几个常用的方法:插入,更新,删除,查询,开启事务,事务提交,事务回滚等操作.有一这个类,操作MYSQL就方便多了. 批处理,存储过程等方法还没有添加,因为觉得目 ...
- sqlmap动态sql优化,避免传参失误批量修改和删除操作!
分析以下的sqlmap存在问题: <delete id="deletePartspic" parameterClass="TblSpPartspic"&g ...
- MySQL操作类的封装(PHP)
<?php class mysql{ /** * 报错函数 * * @param string $error */ function err($error){ die("对不起,您的操 ...
- PHP封装的一个单例模式Mysql操作类
掌握满足单例模式的必要条件----三私一公. ①私有的构造方法-为了防止在类外使用new关键字实例化对象. ②私有的成员属性-为了防止在类外引入这个存放对象的属性. ③私有的克隆方法-为了防止在类外通 ...
随机推荐
- Linux 默认连接数
Linux 默认连接数 - 国内版 Binghttps://cn.bing.com/search?FORM=U227DF&PC=U227&q=Linux+%E9%BB%98%E8%AE ...
- jQuery 事件对象的属性
jQuery 在遵循 W3C 规范的情况下,对事件对象的常用属性进行了封装,使得事件处理在各大浏览器下都可以正常运行而不需要进行浏览器类型判断. (1) event.type 该方法的作用是可以获取到 ...
- 其它综合-CentOS7 忘记root密码
CentOS7 忘记root密码 长时间不用的 CentOS 机器再次开机的时候忽然忘记了密码,总不能就重装一台吧,还有好多服务在机器上,于是决定重置root的密码. 如果是已经开启的机器,需要进行关 ...
- 不用Ajax时的传参方法
不用Ajax时的怎么传参 创建一个form表单 function test(){ var params = { "参数名": "参数值" }; postExce ...
- Go语言公开或未公开的标识符
Go语言公开或未公开的标识符的基本概念 Go语言支持从包里公开或者隐藏标志符,通过这个特性,可以让用户按照自己的规则控制标识符的可见性. Go语言中的可见性,是通过声明类型的大小写来进行区别的. 例如 ...
- [BZOJ 4817] [SDOI 2017] 树点涂色
Description Bob有一棵 \(n\) 个点的有根树,其中 \(1\) 号点是根节点.Bob在每个点上涂了颜色,并且每个点上的颜色不同. 定义一条路径的权值是:这条路径上的点(包括起点和终点 ...
- vue2.0实现过滤
vue1.0和vue2.0差别还是挺多的,之前的vue1.0还有过滤器功能,到了2.0过滤器只能通过自己编写.以下是写的一个小demo: HTML <div id="app" ...
- 04Vue.js路由系统
Vue.js路由系统: https://pizzali.github.io/2018/10/28/Vue.js%E8%B7%AF%E7%94%B1%E7%B3%BB%E7%BB%9F/
- 基于Matlab实现多次最佳一致的函数逼近(类似求渐进函数)
%%%做系统识别很重要,方法上完全符合系统识别最基础的理论 function [sun]=main(n) fplot(,],'r'); x=ones(n+,); :n+ x(j+)=cos(pi*(n ...
- [SDOI2011]消耗战(虚树)
洛古题面 题意:给定一棵树,割断每一条边都有代价,每次询问会给定一些点,求用最少的代价使所有给定点都和1号节点不连通 暴力\(DP\) 我们先考虑暴力怎么做 设\(dp[u]\)为以\(u\)为根的子 ...