Doctrine查询使用LIMIT查找MySQL中的Result总数

Don*_*Den 10 mysql sql doctrine doctrine-query doctrine-orm

我正在尝试获取应用LIMIT时为特定查询找到的总行数.我在PHP/MySQL中成功找到了答案,但我无法在Zend/Doctrine中转换逻辑.我正在使用Doctrine 2.3/Zend 1.12.

我不想使用两个不同的查询来查找结果:

PHP代码:

<?php
$con = mysql_connect('localhost', 'root', '');
if (!$con)
  {
  die('Could not connect: ' . mysql_error());
  }
mysql_select_db("myproject", $con);

$sql = "SELECT SQL_CALC_FOUND_ROWS * FROM `user` WHERE `user_country`='us' LIMIT 10";
$result = mysql_query($sql);
$sql = "SELECT FOUND_ROWS() AS `found_rows`;";
$rows = mysql_query($sql);
$rows = mysql_fetch_assoc($rows);
$total_rows = $rows['found_rows'];
echo $total_rows;
?>
Run Code Online (Sandbox Code Playgroud)

我也在MySQL查询中尝试了以下内容:

试试Union:

    SELECT COUNT( * ) FROM  `user` WHERE  `user_country` =  'US' 
UNION SELECT `user_id` FROM `user` WHERE `user_country` = 'US' LIMIT 10;
Run Code Online (Sandbox Code Playgroud)

尝试选择:

    SELECT  *,(SELECT COUNT(*) from `user` where `user_country`='US') as Count 
from `user` where `user_country`='US' LIMIT 10;
Run Code Online (Sandbox Code Playgroud)

以上尝试都需要时间Count():

有人可以帮我找到解决方案..

教义:

$qry = $this->manager()->createQueryBuilder()
                    ->from($this->entity, 'e')
                    ->select('e');
$qry->where('e.user_country = :country');
$qry->setParameter('country', 'us');
$limit='10';
$qry->setMaxResults($limit);
Run Code Online (Sandbox Code Playgroud)

我怎样才能将上面的学说代码转换成上面的PHP结果查询?可能吗?

Den*_*rdy 7

有一个分页功能,它内置于2.2中,并且与您正在寻找的内容类似:

https://www.doctrine-project.org/projects/doctrine-orm/en/latest/tutorials/pagination.html#pagination

但我不相信它使用SQL_CALC_FOUND_ROWS:它会做两个(或三个,取决于你如何配置它)单独的查询来获得结果,这通常是正确的方法.

如果你真的坚持使用MySQL功能,我认为你需要使用原始SQL和结果集映射.这是一个例子:

Doctrine 2中的行数


在完全独立的注释中,测试是否SQL_CALC_FOUND_ROWS真的值得使用您的特定查询.Count在MySQL中针对您正在进行的查询进行了很好的优化.特别是看到这个问题:

哪个最快?SELECT SQL_CALC_FOUND_ROWS FROM`table`或SELECT COUNT(*)