Heim  >  Artikel  >  Backend-Entwicklung  >  一条SQL语句更新多条记录

一条SQL语句更新多条记录

WBOY
WBOYOriginal
2016-07-25 09:02:211335Durchsuche
从表单获取两个数组, 一是要更新字段数据 , 另一个是条件数组, 我这里用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. }
复制代码


Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn