ZF2插入多行

时间:2013-06-26 14:02:56

标签: sql zend-framework2

我想知道是否有一种方法只使用一个$ sql对象(而不是使用查询(SQL COMMAND)方法)在ZF2中插入多行。

我尝试过类似的东西,但它不起作用:

public function setAgentProjectLink( $IDProject , $IDsAgents )
{
    $values = array () ;
    foreach ( $IDsAgents as $IDAgent):
    {
        $values[] = array ( 'id_agent' => $IDAgent , 'id_projet' => $IDProject) ;
    } endforeach ;

    $sql = new Sql( $this->tableGateway->adapter ) ;
    $insert = $sql->insert() ;

    $insert -> into ( $this->tableGateway->getTable() )
            -> values ( $values ) ;

    $statement = $sql->prepareStatementForSqlObject($insert);
    $result = $statement->execute();
}

尝试在具有两列(id_agent, id_projet

的数据库中插入值

1 个答案:

答案 0 :(得分:5)

如果您使用的是mysql并且没有计划更改为其他数据库,那么ZF2中没有通用的multyinsert方式,但我已经为自己编写了一个multiInsert函数:

$data是一组键值对的数组。

protected function multiInsert($table, array $data)
    {
        if (count($data)) {
            $columns = (array)current($data);
            $columns = array_keys($columns);
            $columnsCount = count($columns);
            $platform = $this->db->platform;
            array_filter($columns, function ($index, &$item) use ($platform) {
                $item = $platform->quoteIdentifier($item);
            });
            $columns = "(" . implode(',', $columns) . ")";

            $placeholder = array_fill(0, $columnsCount, '?');
            $placeholder = "(" . implode(',', $placeholder) . ")";
            $placeholder = implode(',', array_fill(0, count($data), $placeholder));

            $values = array();
            foreach ($data as $row) {
                foreach ($row as $key => $value) {
                    $values[] = $value;
                }
            }


            $table = $this->db->platform->quoteIdentifier($table);
            $q = "INSERT INTO $table $columns VALUES $placeholder";
            $this->db->query($q)->execute($values);
        }
    }