gpt4 book ai didi

mysql - 使用 LIMIT 在 MySQL 中查找结果总数的 Doctrine 查询

转载 作者:IT王子 更新时间:2023-10-28 23:49:42 25 4
gpt4 key购买 nike

我正在尝试获取应用 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():

谁能帮我找到解决办法..

Doctrine :

$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);

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

最佳答案

有一个分页功能,内置于 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(*)

关于mysql - 使用 LIMIT 在 MySQL 中查找结果总数的 Doctrine 查询,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/17079748/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com