有条件操作的django聚合函数(即生成sql'case when'语句)

django-conditional-aggregates的Python项目详细描述


Build StatusLatest PyPI version

Python 2.7

Django 1.6Django 1.7

(由于旧的“sqlcompiler”类的限制,django 1.4和1.5不可能)

注:本模块不需要Django 1.8版本,因为支持是内置的: https://docs.djangoproject.com/en/1.8/ref/models/conditional-expressions/#case

有时需要一些条件逻辑来决定要在聚合函数中“聚合”哪些相关行。

在sql中,可以使用CASE子句来完成此操作,例如:

SELECTstats_stat.campaign_id,SUM(CASEWHEN(stats_stat.stat_type=aANDstats_stat.event_type=v)THENstats_stat.countELSE0END)ASimpressionsFROMstats_statGROUPBYstats_stat.campaign_id

注意,这与使用django的普通.filter(...).aggregate(Sum(...))不同……我们所做的实际上是在orm的Sum(...)部分中。

我相信这些“条件聚合”在进行GROUP BY类型的查询时最有用(也许only)-它们允许您精确地控制如何聚合组中的值,例如仅汇总与特定条件匹配的行。

用法:

pip install django-conditional-aggregates

fromdjango.db.modelsimportQfromdjconnaggimportConditionalSum# recreate the SQL example from above in pure Django ORM:report=(Stat.objects.values('campaign_id')# values + annotate => GROUP BY.annotate(impressions=ConditionalSum('count',when=Q(stat_type='a',event_type='v')),))

注意,标准djangoQ对象用于构造CASE WHEN(...)子句。就像在orm的其余部分中一样,您可以将它们与() | & ~运算符组合,以生成复杂的查询。

^提供了{tt9}$和ConditionalCount聚合函数。如果你需要自己的话,还有一个基类。ConditionalSum的实现非常简单,如下所示:

fromdjconnagg.aggregatesimportConditionalAggregate,SQLConditionalAggregateclassConditionalSum(ConditionalAggregate):name='ConditionalSum'classSQLClass(SQLConditionalAggregate):sql_function='SUM'default=0

欢迎加入QQ群-->: 979659372 Python中文网_新手群

推荐PyPI第三方库


热门话题
java Jetty是否有请求缓存?   数组中的java 2值与我的数据帧中的2列对应   对象序列化期间的java DbUtils类型转换问题   java根面板中不显示所有单独的面板   java通过代理或SSH隧道连接Hbase API   java困惑:与经典MVC控制器相比,JSF2中bean的角色   java在我的Triangle类中“找不到符号错误”   java在Android中设置从路径到自定义按钮的图像   java不绕轨道旋转椭圆   AES在socket上搞砸了序列化/反序列化。无效的流标头。JAVA   java在数组中搜索term和if语句   线程“main”java中出现异常。util。正则表达式。PatternSyntaxException:在索引0附近悬挂元字符“*”*   Websphere上的java Google反射无法打开url连接   java为什么inc/dec频道什么都不做?   java KeyListener无法访问keyPressed方法