Warning
This document is for an in-development version of Galaxy. You can alternatively view this page in the latest release if it exists or view the top of the latest release's documentation.
Source code for galaxy.webapps.reports.controllers.query
""" Mixin to help build advanced queries for reports interface.
"""
import sqlalchemy as sa
[docs]class ReportQueryBuilder:
[docs] def group_by_month(self, column):
if self.app.targets_mysql:
return [sa.func.year(column), sa.func.month(sa.func.date(column))]
else:
return [sa.func.date_trunc("month", sa.func.date(column))]
[docs] def select_month(self, column):
if self.app.targets_mysql:
return sa.func.date(column)
else:
return sa.func.date_trunc("month", sa.func.date(column))
[docs] def group_by_day(self, column):
if self.app.targets_mysql:
return [sa.func.day(sa.func.date(column))]
else:
return [sa.func.date_trunc("day", sa.func.date(column))]
[docs] def select_day(self, column):
if self.app.targets_mysql:
return sa.func.date(column)
else:
return sa.func.date_trunc("day", sa.func.date(column))