Doctrine DBAL可以批量插入吗?

cod*_*boy 5 php doctrine dbal

是否可以使用 Doctrine DBAL 对 SQLite DB 进行批量插入?即使以下内容更加有效:

$twitter = new TwitterAPIExchange($twitterAuth);
    $response = json_decode($twitter->setGetfield($getField)
        ->buildOauth($url, $requestMethod)
        ->performRequest());

    foreach($response->statuses as $r) {
        $statement = $app['db']->executeQuery('SELECT * FROM tweets WHERE twitter_id = ?', array($r->id));
        $tweet = $statement->fetch();

        if(empty($tweet)) {
            $app['db']->insert('tweets', array('twitter_id'=>$r->id, 'contents' => $r->text, 'timestamp' => $r->created_at));
        }
    }
Run Code Online (Sandbox Code Playgroud)

inf*_*iac -7

有了 Doctrine2,是的! http://doctrine-orm.readthedocs.org/en/latest/reference/batch-processing.html

Doctrine2 使用 UnitOfWork 模式,所以基本上你可以“持久化”多个记录,然后在最后运行flush- 它会找出插入/更新/等所有数据的最有效方法。这非常聪明。

  • 最初的问题是关于 Doctrine **DBAL**,而不是 Doctrine 2 **ORM**。这不仅仅是不同的 Doctrine 版本,而且是针对不同需求具有不同抽象级别的不同库。 (7认同)