首页 > 后端开发 > php教程 > 一条SQL语句更新多条记录

一条SQL语句更新多条记录

WBOY
发布: 2016-07-25 09:02:21
原创
1428 人浏览过
从表单获取两个数组, 一是要更新字段数据 , 另一个是条件数组, 我这里用id

来源:http://www.liuhai.org/sql-set-key-case-when-then

  1. function save_category_district($parame,$id){
  2. if(!is_array($parame) || !is_array($id)) return false;
  3. $sql="UPDATE ".table.'category_district'.' SET ';
  4. foreach($parame as $key=>$val){
  5. $csql.=$key.'=CASE id';
  6. foreach($parame[$key] as $key=>$val){
  7. $csql.=" WHEN {$id[$key]} THEN '{$val}'"; //注意这里id的key必须和要更新数据的key相同,就是表单里出来的数字键
  8. }
  9. $csql.=' END,';
  10. }
  11. $sql.=rtrim($csql,','); //这一步就是为了去除最后一个END后的逗号
  12. $id=implode(',',$id); //id在这里变为字符串
  13. $sql.=" WHERE id IN ({$id})";
  14. if(!$this->mydb->query($sql)) return false;
  15. return true;
  16. }
复制代码


来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板