Skip to content
Snippets Groups Projects
Commit fca3d110 authored by Bartek Wrona's avatar Bartek Wrona
Browse files

Fixed setting children count for each posts (at the end of initial sync)

parent bc0ecee4
No related branches found
No related tags found
4 merge requests!456Release candidate v1 24,!230Setup monitoring with pghero,!135Enable postgres monitoring on CI server,!41Consender api fixes
...@@ -174,6 +174,12 @@ class DbState: ...@@ -174,6 +174,12 @@ class DbState:
index.create(engine) index.create(engine)
# Update count of all child posts (what was hold during initial sync)
sql = """
select update_hive_posts_children_count()
"""
row = DbState.db().query_row(sql)
# TODO: #111 # TODO: #111
#for key in cls._all_foreign_keys(): #for key in cls._all_foreign_keys():
# log.info("Create fk %s", key.name) # log.info("Create fk %s", key.name)
......
...@@ -650,6 +650,44 @@ def setup(db): ...@@ -650,6 +650,44 @@ def setup(db):
""" """
db.query_no_return(sql) db.query_no_return(sql)
sql = """
DROP FUNCTION if exists update_hive_posts_children_count()
;
CREATE OR REPLACE FUNCTION update_hive_posts_children_count()
RETURNS VOID
LANGUAGE plpgsql
AS
$function$
BEGIN
update hive_posts uhp
set children = data_source.childrencount
from
(
WITH RECURSIVE ChildrenCTE AS (
SELECT ID as RootId, ID
FROM hive_posts hp
where hp.parent_id != 0
UNION ALL
SELECT cte.RootID, d.ID
FROM ChildrenCTE cte
INNER JOIN hive_posts d ON d.parent_id = cte.ID
)
SELECT d.ID, d.parent_id, cnt.ChildrenCount
FROM hive_posts d
INNER JOIN (
SELECT RootID as ID, COUNT(*) - 1 as ChildrenCount
FROM ChildrenCTE
GROUP BY RootID
) cnt ON cnt.ID = d.ID
) as data_source
where uhp.id = data_source.id
;
END
$function$
"""
db.query_no_return(sql)
def reset_autovac(db): def reset_autovac(db):
"""Initializes/resets per-table autovacuum/autoanalyze params. """Initializes/resets per-table autovacuum/autoanalyze params.
......
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment