我正在尝试获取应用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);
如何将上述doctrine代码转换为上述PHP结果查询?有可能吗?
答案 0 :(得分:7)
有一个分页功能,它内置于2.2中,并且与您正在寻找的内容类似:
但我不认为它使用SQL_CALC_FOUND_ROWS
:它会使用两个(或三个,取决于你如何配置)单独的查询来获得结果,这通常是正确的继续进行的方式。
如果您真的坚持使用MySQL功能,我认为您需要使用原始SQL和结果集映射。这是一个例子:
在一个完全独立的注释中,测试SQL_CALC_FOUND_ROWS
是否真的值得用于您的特定查询。 Count在MySQL中针对您正在进行的查询进行了很好的优化。特别是看到这个问题:
Which is fastest? SELECT SQL_CALC_FOUND_ROWS FROM `table`, or SELECT COUNT(*)
答案 1 :(得分:1)
您可以访问EntityPersister::count(array $criteria)
例如:
$count = $doctrineEntityManager
->getUnitOfWork()
->getEntityPersister(Entity::class)
->count($criteria);
答案 2 :(得分:0)
可能这可以帮到你
Doctrine::getTable('TableName')->createQuery('t')
->where('Your Condition') ->execute() ->rowCount();
OR
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