繁体   English   中英

对 Laravel 中的 cursor 语句的原始查询

[英]Raw query to cursor statement in Laravel

我有一组原始查询,我想将它们转换为Illuminate\Database\Query\Builder ,然后通过 cursor() 方法获取它们的数据。 例如:

$queries = [];
$queries[] = 'SELECT * from users';
$queries[] = 'SELECT * from toys INNER JOIN users ON toys.owner_id = user.id';
$queries[] = 'SELECT * from toys';

$connection = \DB::connection();

foreach ($queries as $query) {
    $builder = $connection->query();
    // Pass some how the raw query to the builder
    $builder->raw($query);
    // Execute the statement with a cursor function
    foreach($builder->cursor() as $data) {
         // Do something
    }
}

我遇到的问题是如何将原始查询传递给 Builder,然后通过 cursor 方法获取数据。

有任何想法吗?

根据官方 API 文档,您应该能够像select()一样使用cursor() ) 。

$generator = DB::cursor('SELECT * from users'); 

foreach ($generator as $data) { ... }
$queries = [];
$queries[] = 'SELECT * from users';
$queries[] = 'SELECT * from toys INNER JOIN users ON toys.owner_id = user.id';
$queries[] = 'SELECT * from toys';

foreach ($queries as $query) {
    foreach(\DB::cursor($query) as $data) {
         // Do something
    }
}

\DB::connection()->cursor($query)\DB::cursor($query)相同。 通过魔术方法__callDatabaseManagerDB Facade)将 cursor 调用通过管道传递到默认连接。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM