设为首页 收藏本站
查看: 1223|回复: 0

[经验分享] PHP中批量更新数据表中多条记录

[复制链接]

尚未签到

发表于 2017-4-10 12:05:15 | 显示全部楼层 |阅读模式
  以下代码是PHP代码,由于出现错乱,所以借用java显示

class test {
/**
* 创建像这样的查询: "IN('a','b')";
*
* @author   wengxianhu
* @created to 2013-05-27
* @param    mix      $item_list      列表数组或字符串,如果为字符串时,字符串只接受数字串
* @param    string   $field_name     字段名称
* @return   void
*/
public function db_create_in($item_list, $field_name = '')
{
if (empty($item_list))
{
return " ".$field_name . " IN ('') ";
}
else
{
if (!is_array($item_list))
{
$item_list = explode(',', $item_list);
foreach ($item_list as $k=>$v)
{
$item_list[$k] = intval($v);
}
}
$item_list = array_unique($item_list);
$item_list_tmp = '';
foreach ($item_list AS $item)
{
if ($item !== '')
{
$item_list_tmp .= $item_list_tmp ? ",'$item'" : "'$item'";
}
}
if (empty($item_list_tmp))
{
return " ".$field_name . " IN ('') ";
}
else
{
return " ".$field_name . ' IN (' . $item_list_tmp . ') ';
}
}
}
/**
* 拼接更新字段
*
* @author wengxianhu
* @created to 2013-05-27
* @param unknown $data 批量更新的数组
* @param string $index_key 主键值的字段名
* @return string
*/
public function _concatFields($data, $index_key)
{
if (empty($data)) {
return '';
}
$array_tmp = array();
$index_key_array = array();
if (!is_array(current($data))) {
$data = array($data);
}
$tmp1 = "";
foreach (current($data) as $_v => $_k) {
$tmp1 = $_v . '_temp';
${$tmp1} = "";
if ($_v != $index_key) {
${$tmp1} .= " {$_v} = CASE {$index_key} ";
}
}
reset($data);
$tmp2 = "";
foreach ($data as $_k => $_v) {
foreach ($_v as $_f => $_fv) {
$tmp2 = $_f . '_temp';
${$tmp2} .= "WHEN '{$_v[$index_key]}' THEN '" . addslashes(stripslashes($_fv)) . "' ";
array_push($index_key_array, $_v[$index_key]);
}
}
reset($data);
$tmp3 = "";
foreach (current($data) as $_v => $_k) {
$tmp3 = $_v . '_temp';
${$tmp3} .= " END ";
if ($_v != $index_key) {
$array_tmp[$tmp3] = ${$tmp3};
}
}
$array_tmp[$index_key] = $this->db_create_in($index_key_array, $index_key);
return $array_tmp;
}
/**
* 拼接更新字段
*
* @author wengxianhu
* @created to 2013-05-27
* @param unknown $data 批量更新的数组
* @param string $index_key 主键值的字段名
* @return string
*/
public function _concatFields_old($data, $index_key)
{
if(empty($data))
{
return '';
}
$array_tmp = array();
$index_key_array = array();
if(!is_array(current($data)))
{
$data = array($data);
}
foreach (current($data) as $_v => $_k)
{
if($_v != $index_key)
{
${$_v.'_temp'} .= " {$_v} = CASE {$index_key} ";
}
}
reset($data);
foreach ($data as $_k => $_v)
{
foreach ($_v as $_f => $_fv)
{
${$_f.'_temp'} .= "WHEN '{$_v[$index_key]}' THEN '".addslashes(stripslashes($_fv))."' ";
array_push($index_key_array, $_v[$index_key]);
}
}
reset($data);
foreach (current($data) as $_v => $_k)
{
if($_v != $index_key)
{
${$_v.'_temp'} .= " END ";
$array_tmp[$_v.'_temp'] = ${$_v.'_temp'};
}
}
$array_tmp[$index_key] = $this->db_create_in($index_key_array, $index_key);
return $array_tmp;
}
/**
* 获取更新的数据SQL
*
* @author wengxianhu
* @created to 2013-05-27
* @param unknown $data 批量更新的数组
* @param string $index_key 主键值的字段名
* @return multitype:
*/
public function _getUpdateInfo($data, $index_key)
{
reset($data);
$fields = array();
$conditions = array();
$fields_info = $this->_concatFields($data, $index_key);
$conditions = $fields_info[$index_key];
unset($fields_info[$index_key]);
$fields = implode(',', $fields_info);
return compact('fields', 'conditions');
}
/**
* 批量更新数据
*
* @author wengxianhu
* @created to 2013-05-27
* @param unknown $set 批量更新的数组
* @param string $table 数据表名
* @param string $index_key 主键值的字段名
* @return void
*/
public function updateAll($set, $table, $index_key)
{
if(empty($set))
{
return '';
}
$update_info = $this->_getUpdateInfo($set, $index_key);
$sql = "UPDATE {$table} SET {$update_info['fields']} WHERE {$update_info['conditions']}";
$this->query($sql,'execute'); //这里根据当前使用的系统修改
}
}
$goods = array(
array('goods_id'=>2000,'cate_id'=>100,'name'=>'godos1'),
array('goods_id'=>2001,'cate_id'=>101,'name'=>'godos2'),
array('goods_id'=>2002,'cate_id'=>102,'name'=>'godos3'),
);
// $goods = array('goods_id'=>2000,'cate_id'=>100,'name'=>'godos1');
$a = new test();
$a->updateAll($goods, 'ecm_goods', 'goods_id');

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-362919-1-1.html 上篇帖子: 用xampp设置php运行环境经验总结 下篇帖子: php工具类之【zip压缩文件处理类】
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表