aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorRoger Braun <rbraun@Bobble.local>2017-10-24 14:16:17 +0200
committerRoger Braun <rbraun@Bobble.local>2017-10-24 14:16:17 +0200
commit9af560083fcc513a7b3c41b06f4ed307c50a7529 (patch)
tree2dcc9e3e845ef55ce1e29d261420aa4970b3d2d0
parent29c261e75ba10eac0cda8ec19d158d84c96f6572 (diff)
downloadpleroma-9af560083fcc513a7b3c41b06f4ed307c50a7529.tar.gz
Use more efficient user note count update query.
-rw-r--r--lib/pleroma/user.ex2
-rw-r--r--priv/repo/migrations/20171024121413_add_object_actor_index.exs9
2 files changed, 10 insertions, 1 deletions
diff --git a/lib/pleroma/user.ex b/lib/pleroma/user.ex
index 938b57d90..bfd3a3ad7 100644
--- a/lib/pleroma/user.ex
+++ b/lib/pleroma/user.ex
@@ -241,7 +241,7 @@ defmodule Pleroma.User do
def update_note_count(%User{} = user) do
note_count_query = from a in Object,
- where: fragment("? @> ?", a.data, ^%{actor: user.ap_id, type: "Note"}),
+ where: fragment("?->>'actor' = ? and ?->>'type' = 'Note'", a.data, ^user.ap_id, a.data),
select: count(a.id)
note_count = Repo.one(note_count_query)
diff --git a/priv/repo/migrations/20171024121413_add_object_actor_index.exs b/priv/repo/migrations/20171024121413_add_object_actor_index.exs
new file mode 100644
index 000000000..344c9c825
--- /dev/null
+++ b/priv/repo/migrations/20171024121413_add_object_actor_index.exs
@@ -0,0 +1,9 @@
+defmodule Pleroma.Repo.Migrations.AddObjectActorIndex do
+ use Ecto.Migration
+
+ @disable_ddl_transaction true
+
+ def change do
+ create index(:objects, ["(data->>'actor')", "(data->>'type')"], concurrently: true, name: :objects_actor_type)
+ end
+end