V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
推荐学习书目
Learn Python the Hard Way
Python Sites
PyPI - Python Package Index
http://diveintopython.org/toc/index.html
Pocoo
值得关注的项目
PyPy
Celery
Jinja2
Read the Docs
gevent
pyenv
virtualenv
Stackless Python
Beautiful Soup
结巴中文分词
Green Unicorn
Sentry
Shovel
Pyflakes
pytest
Python 编程
pep8 Checker
Styles
PEP 8
Google Python Style Guide
Code Style from The Hitchhiker's Guide
iwillhappy1314
V2EX  ›  Python

Django 怎么查询消费记录,查询出来的记录需求排除重复的用户,包含每个用户的消费次数和消费金额总和

  •  
  •   iwillhappy1314 ·
    iwillhappy1314 · 2015-09-09 20:17:11 +08:00 · 3734 次点击
    这是一个创建于 3366 天前的主题,其中的信息可能已经有所发展或是发生改变。
    第一次使用 Django ,有个问题请教各位大神。

    Django 里面有一个 model ,记录的是用户的消费记录。

    现在要查询用户的消费记录。

    查询出来的记录需要排除重复的用户,包含每个用户的消费次数和消费金额总和。

    Django 有直接查询这样的数据的方法吗?还是要写 raw SQL 查询?

    谢谢各位!
    7 条回复    2015-09-10 13:02:01 +08:00
    phx13ye
        1
    phx13ye  
       2015-09-10 00:44:59 +08:00 via Android   ❤️ 1
    自己遍历统计一下 消费记录.objects.all
    cxbig
        3
    cxbig  
       2015-09-10 05:11:28 +08:00   ❤️ 1
    Django 只是空框架啊,你开发的应用是啥?
    在消费记录的 model 里写一个统计 function 就好啦,
    都 oop 框架了,不追求极限效率不需要用 raw sql
    adexbn
        4
    adexbn  
       2015-09-10 06:43:42 +08:00 via iPhone
    model 名.object.raw (SQL 语句)
    huangyan92
        5
    huangyan92  
       2015-09-10 09:31:47 +08:00   ❤️ 1
    all_user = **.objects.all ().query.group_by = ['u']
    for one_user in all_user:
    **.objects.filter (u=one_user.u ).aggregate (total_amount=Sum ('order_amount')).get ('total_amount') or 0
    这样好像是可以算出来,但是数据多了应该会很慢
    winkidney
        6
    winkidney  
       2015-09-10 10:15:29 +08:00
    google :
    django orm group by
    django orm sum
    iwillhappy1314
        7
    iwillhappy1314  
    OP
       2015-09-10 13:02:01 +08:00
    非常感谢各位的热心回答,问题已解决, model 中使用了外键,而 Django 的模板支持直接使用外键查询关联数据,先查询出来用户,然后通过:{{ customer.record_set.all|length }}查询出来消费次数。
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   2489 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 25ms · UTC 00:02 · PVG 08:02 · LAX 16:02 · JFK 19:02
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.