使用 LIMIT 查找 MySQL 中结果总数的教义查询

Posted

技术标签:

【中文标题】使用 LIMIT 查找 MySQL 中结果总数的教义查询【英文标题】:Doctrine Query to find total number of Result in MySQL with LIMIT 【发布时间】:2013-06-09 09:45:23 【问题描述】:

我正在尝试获取应用 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;
?>

我还在 MySQL Query 中尝试了以下操作:

试试 Union:

    SELECT COUNT( * ) FROM  `user` WHERE  `user_country` =  'US' 
UNION SELECT `user_id` FROM `user` WHERE `user_country` = 'US' LIMIT 10;

试试 Select:

    SELECT  *,(SELECT COUNT(*) from `user` where `user_country`='US') as Count 
from `user` where `user_country`='US' LIMIT 10;

上面的两个尝试都需要时间 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);

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

【问题讨论】:

【参考方案1】:

有一个分页功能,这是 2.2 中内置的,它的功能与您正在寻找的类似:

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

但我不相信它使用SQL_CALC_FOUND_ROWS:它会执行两个(或三个,取决于您的配置方式)单独的查询来获取结果,这通常是正确的方法。

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

Count of rows in Doctrine 2


另外,测试SQL_CALC_FOUND_ROWS 是否真的值得用于您的特定查询。 Count 在 MySQL 中针对您正在执行的查询进行了很好的优化。尤其看这个问题:

Which is fastest? SELECT SQL_CALC_FOUND_ROWS FROM `table`, or SELECT COUNT(*)

【讨论】:

【参考方案2】:

您可以通过访问EntityPersister::count(array $criteria)获取计数

例如:

$count = $doctrineEntityManager
        ->getUnitOfWork()
        ->getEntityPersister(Entity::class)
        ->count($criteria);

【讨论】:

【参考方案3】:

也许这对你有帮助

Doctrine::getTable('TableName')->createQuery('t')
->where('Your Condition') ->execute() ->rowCount();

Doctrine::getTable('TableName')->createQuery('t')
->where('Your Condition') ->count();

我更喜欢第二个

你可以这样做,

$q = Doctrine_Query::create()
        ->select('ss.*')
        ->from('SalarySurvey ss')
        ->where('ss.user_id=?', $user_id)
        ->groupBy('created_at')
        ->execute();
$totalData = $q->count();

对于LIMIT

$q = Doctrine_Query::create()
        ->select('u.username, p.phonenumber')
        ->from('User u')
        ->leftJoin('u.Phonenumbers p')
        ->limit(20);

echo $q->getSqlQuery();

这个查询的输出是这样的---

SELECT
    u.id AS u__id,
    u.username AS u__username,
    p.id AS p__id,
    p.phonenumber AS p__phonenumber
FROM user u
    LEFT JOIN phonenumber p
        ON u.id = p.user_id
LIMIT 20

更多详情请看 check here

【讨论】:

查询的限制呢? 我的问题是如何在同一查询中检索总记录数和限制。您的查询要么给我 LIMIT。我想要一个查询总数并限制输出。正如我上面提到的......它可能是两个查询,但它不应该一次又一次地运行相同的查询...... 你想在一个查询中使用 count() 和 limit() 吗? 好吧,现在我没有资源可以测试,但请尝试这样,$q = Doctrine_Query::create() -&gt;select('u.username, p.phonenumber') -&gt;from('User u') -&gt;leftJoin('u.Phonenumbers p') -&gt;limit(20); $totalData = $q-&gt;count(); 致命错误:调用未定义的方法 Doctrine\ORM\QueryBuilder::count() 我收到上述错误。我正在使用 setMaxResults($limit) 而不是 count...

以上是关于使用 LIMIT 查找 MySQL 中结果总数的教义查询的主要内容,如果未能解决你的问题,请参考以下文章

SQL:使用 LIMIT 查询时计算匹配结果的数量

计算总数然后在MySQL中列出一组记录的最快方法

MYSQL SUM() 返回前 10 个值

MySQL必知必会读书笔记-2(去重,limit,结果的排序,通配符,正则表达式)

MySQL高效获取记录总数

MySql 查询从表中找出前 50% 的记录