dongxin1999 2013-01-20 19:51
浏览 75
已采纳

使用PDO进行多插入时的基数违规

I am attempting to run the following query which is a multi insert. Everything seems fine but it throws this error:

SQLSTATE[21000]: Cardinality violation: 1241 Operand should contain 1 column(s)

My code is as follows

$report_categories=array(1,2,3);
$report_categories=array_unique($report_categories);    
$rowPlaces = '(' . implode(', ', array_fill(0, 2, '?')) . ')';
$allPlaces = implode(', ', array_fill(0, count($report_categories), $rowPlaces));

$add_report_types=$this->prepare("
    INSERT INTO report_types (
        report_id,
        category
    ) VALUES (
        " . $allPlaces . "
    )");

$i=1;
foreach($report_categories as $category_id){
    $add_report_types->bindValue($i, $report_id, PDO::PARAM_INT);
    $i++;
    $add_report_types->bindValue($i, $category_id, PDO::PARAM_INT);
    $i++;
}
$add_report_types->execute();
  • 写回答

1条回答 默认 最新

  • duanlan7903 2013-01-20 21:42
    关注

    You might want to try it without the parentheses in the values part of your query:

    $add_report_types=$this->prepare("
        INSERT INTO report_types (
            report_id,
            category
        ) VALUES " . $allPlaces);
    

    If I understand it right, $allPlaces should contain a string that looks like this:

    (?, ?), (?, ?), (?, ?)
    

    So you want your query to look like:

    INSERT INTO report_types (
        report_id,
        category
    ) VALUES (?, ?), (?, ?), (?, ?);
    

    http://dev.mysql.com/doc/refman/5.5/en/insert.html

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥35 平滑拟合曲线该如何生成
  • ¥100 c语言,请帮蒟蒻写一个题的范例作参考
  • ¥15 名为“Product”的列已属于此 DataTable
  • ¥15 安卓adb backup备份应用数据失败
  • ¥15 eclipse运行项目时遇到的问题
  • ¥15 关于#c##的问题:最近需要用CAT工具Trados进行一些开发
  • ¥15 南大pa1 小游戏没有界面,并且报了如下错误,尝试过换显卡驱动,但是好像不行
  • ¥15 自己瞎改改,结果现在又运行不了了
  • ¥15 链式存储应该如何解决
  • ¥15 没有证书,nginx怎么反向代理到只能接受https的公网网站