繁体   English   中英

原则查询以LIMIT查找MySQL中的结果总数

[英]Doctrine Query to find total number of Result in MySQL with LIMIT

我正在尝试应用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查询中尝试了以下命令:

尝试使用Union:

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

尝试选择:

    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结果查询? 可能吗?

有一个分页功能,该功能内置于2.2中,其功能类似于您要查找的功能:

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

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

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

教义2中的行数


在另一个完全不同的注释上,测试SQL_CALC_FOUND_ROWS是否真的值得用于您的特定查询。 在MySQL中,Count可以很好地优化您正在执行的查询。 尤其是请参阅以下问题:

哪个最快? 从“表”中选择SQL_CALC_FOUND_ROWS,或选择COUNT(*)

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

例如:

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

可能这可以帮助您

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

有关更多详细信息, 请在此处查看

暂无
暂无

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

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