#1308 update build_page() to permit query with group_by()
Using Repo.aggregate() to count the total of elements is incompatible with group_by(). Changing this to a subquery with a count(*) of results permit to use group_by().
This commit is contained in:
parent
9403a9d60a
commit
41aa81097d
|
@ -602,7 +602,7 @@ defmodule Mobilizon.Events do
|
||||||
|> filter_local_or_from_followed_instances_events()
|
|> filter_local_or_from_followed_instances_events()
|
||||||
|> filter_public_visibility()
|
|> filter_public_visibility()
|
||||||
|> event_order(Map.get(args, :sort_by, :match_desc), search_string)
|
|> event_order(Map.get(args, :sort_by, :match_desc), search_string)
|
||||||
|> Page.build_page(page, limit, :begins_on)
|
|> Page.build_page(page, limit)
|
||||||
end
|
end
|
||||||
|
|
||||||
@doc """
|
@doc """
|
||||||
|
|
|
@ -73,7 +73,7 @@ defmodule Mobilizon.Instances do
|
||||||
query
|
query
|
||||||
end
|
end
|
||||||
|
|
||||||
%Page{elements: elements} = paged_instances = Page.build_page(query, page, limit, :domain)
|
%Page{elements: elements} = paged_instances = Page.build_page(query, page, limit)
|
||||||
|
|
||||||
%Page{
|
%Page{
|
||||||
paged_instances
|
paged_instances
|
||||||
|
|
|
@ -23,11 +23,22 @@ defmodule Mobilizon.Storage.Page do
|
||||||
`field` is use to define the field that will be used for the count aggregate, which should be the same as the field used for order_by
|
`field` is use to define the field that will be used for the count aggregate, which should be the same as the field used for order_by
|
||||||
See https://stackoverflow.com/q/12693089/10204399
|
See https://stackoverflow.com/q/12693089/10204399
|
||||||
"""
|
"""
|
||||||
@spec build_page(Ecto.Queryable.t(), integer | nil, integer | nil, atom()) :: t(any)
|
@spec build_page(Ecto.Queryable.t(), integer | nil, integer) :: t(any)
|
||||||
def build_page(query, page, limit, field \\ :id) do
|
def build_page(query, page, limit) do
|
||||||
|
count_query =
|
||||||
|
query
|
||||||
|
# Exclude select because we add a new one below
|
||||||
|
|> exclude(:select)
|
||||||
|
# Exclude order_by for perf
|
||||||
|
|> exclude(:order_by)
|
||||||
|
# Exclude preloads to avoid error "cannot preload associations in subquery"
|
||||||
|
|> exclude(:preload)
|
||||||
|
|> subquery()
|
||||||
|
|> select([r], count(fragment("*")))
|
||||||
|
|
||||||
[total, elements] =
|
[total, elements] =
|
||||||
[
|
[
|
||||||
fn -> Repo.aggregate(query, :count, field) end,
|
fn -> Repo.one(count_query) end,
|
||||||
fn -> Repo.all(paginate(query, page, limit)) end
|
fn -> Repo.all(paginate(query, page, limit)) end
|
||||||
]
|
]
|
||||||
|> Enum.map(&Task.async/1)
|
|> Enum.map(&Task.async/1)
|
||||||
|
|
Loading…
Reference in a new issue