首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Kohana DB表达式没有返回正确的结果

Kohana DB表达式没有返回正确的结果
EN

Stack Overflow用户
提问于 2013-09-16 14:00:59
回答 1查看 284关注 0票数 1

有人能解释一下如何让第一个查询返回与第二个查询相同的结果吗?对于计数为0的任何列,第一个查询返回1而不是0。第二个查询工作正常。我很确定这是COUNT()语句的一个问题。

代码语言:javascript
复制
$lists = DB::select('favorites_lists.*', array(DB::expr('COUNT("favorites.list_id")'), 'total_favs'))
    ->from('favorites_lists')
    ->join('favorites', 'LEFT')
    ->on('favorites_lists.id', '=', 'favorites.list_id')
    ->where('favorites_lists.uid', '=', $user->id)
    ->group_by('favorites_lists.id')
    ->execute()
    ->as_array();

$lists = DB::query(
    Database::SELECT,
    'SELECT favorites_lists.*, COUNT(favorites.list_id) as total_favs
    FROM favorites_lists
    LEFT JOIN favorites
    ON favorites_lists.id = favorites.list_id
    WHERE favorites_lists.uid = ' . $user->id . '
    GROUP BY favorites_lists.id'
)
    ->execute()
    ->as_array();
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2013-09-17 12:13:08

代码语言:javascript
复制
DB::select('favorites_lists.*', array(DB::expr('COUNT("favorites.list_id")'), 'total_favs'))

这个数组有什么用?我通常是这样写查询的。

代码语言:javascript
复制
DB::select('favorites_lists.*',DB::expr('COUNT("favorites.list_id") AS total_favs'))
票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/18829950

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档