ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

【TP3.2.3】addAll方法的坑

2019-07-29 13:02:53  阅读:378  来源: 互联网

标签:addAll name val title value TP3.2 array 方法


问题:做一个导入Excel到数据库的功能中需要用到addAll功能,但是每次执行到addAll()时都会报错,如下

Insert value list does not match column list: 1136 Column count doesn't match value count at row 1

 问题原因:mysql.class.php文件的insertAll方法存在缺陷

foreach ($data as $key=>$val){
                if(is_array($val) && 'exp' == $val[0]){
                    $value[]   =  $val[1];
                }elseif(is_scalar($val)){
                    if(0===strpos($val,':') && in_array($val,array_keys($this->bind))){
                        $value[]   =   $this->parseValue($val);
                    }else{
                        $name       =   count($this->bind);
                        $value[]   =   ':'.$name;
                        $this->bindParam($name,$val);
                    }
                }
            }
}

'title'=>$v->title? $v->title: ' '这种形式的数组赋值,跟'title'=>$v->title形式的数组赋值,结果是不一样的。

1.当$v->title的值不存在的时候,数组就相当于array('title'=>)这样了

2.'title'=>$v->title? $v->title: ' '在$v->title的值不存在时,数组相当于array('title'=>' ')

前者相当于没赋值,后者相当于赋值为空

 

解决方法:在数据录入时要判断值是否存在,代码如下

foreach($list as $k => $v){
    $dataList[] = [
      'title'        =>  $v['title'] ? $v['title'] : '',
    'name'      =>  $v['name'] ? $v['name'] : ''
    ]
}
M('sql') -> addAll($dataList);

标签:addAll,name,val,title,value,TP3.2,array,方法
来源: https://www.cnblogs.com/BearLee/p/11263235.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有