饿了吗 一道面试题分享和思考~

之前在上海面试后端开发的时候, 面试官问了一个数据库相关的问题:
有这么一张表: 里边存着所有用户的登录信息, 例如用户名和登录时间.
请问如何找出所有用户最近登录的记录呢?


sql:

用sql其实很简单, 就是先按时间排个序, 再按用户id groupby一下就行了.


orm:

在django的orm中也是一个道理, 可以用annotate:


举个栗子:

献个丑, 上周写的公司报表部分的代码:

1
2
3
4
5
6
for register, queryset in queryset_by_register.items():
    # 根据value和次级维度进行groupby, 生成以它们为索引的字典.
    fields_compute = [Sum(x) for x in self.header.index_action]
    queryset = queryset.values(*self.groupby).annotate(*fields_compute)

    result[register] = queryset

Comments(需翻墙)

-->