하나의 SQL 문이 여러 레코드를 업데이트합니다.
풀어 주다: 2016-07-25 09:02:21
从表单获取两个数组, 一是要更新字段数据 , 另一个是条件数组, 我这里用id
来源:http://www.liuhai.org/sql-set-key-case-when-then
- function save_category_district($parame,$id){
- if(!is_array($parame) || !is_array($id)) return false;
- $sql="UPDATE ".table.'category_district'.' SET ';
- foreach($parame as $key=>$val){
- $csql.=$key.'=CASE id';
- foreach($parame[$key] as $key=>$val){
- $csql.=" WHEN {$id[$key]} THEN '{$val}'"; //注意这里id的key必须和要更新数据的key相同,就是表单里出来的数字键
- }
- $csql.=' END,';
- }
- $sql.=rtrim($csql,','); //这一步就是为了去除最后一个END后的逗号
- $id=implode(',',$id); //id在这里变为字符串
- $sql.=" WHERE id IN ({$id})";
- if(!$this->mydb->query($sql)) return false;
- return true;
- }
复制代码
|
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
-
2024-10-22 09:46:29
-
2024-10-13 13:53:41
-
2024-10-12 12:15:51
-
2024-10-11 22:47:31
-
2024-10-11 19:36:51
-
2024-10-11 15:50:41
-
2024-10-11 15:07:41
-
2024-10-11 14:21:21
-
2024-10-11 12:59:11
-
2024-10-11 12:17:31