Fix view in migration. Add by lang metric to consumer.
This commit is contained in:
parent
600dac7694
commit
db425b1d5f
11 changed files with 101 additions and 33 deletions
|
@ -23,8 +23,22 @@ partition of records for values in ('app.bsky.feed.repost');
|
|||
create table records_profile
|
||||
partition of records for values in ('app.bsky.actor.profile');
|
||||
|
||||
ALTER TABLE records_like
|
||||
ADD CHECK (collection in ('app.bsky.feed.like'));
|
||||
|
||||
-- SLOW, can run overnight, make sure to run in tmux or eternal terminal
|
||||
ALTER TABLE records_post
|
||||
ADD CHECK (collection in ('app.bsky.feed.post'));
|
||||
|
||||
ALTER TABLE records_follow
|
||||
ADD CHECK (collection in ('app.bsky.graph.follow'));
|
||||
|
||||
ALTER TABLE records_repost
|
||||
ADD CHECK (collection in ('app.bsky.feed.repost'));
|
||||
|
||||
ALTER TABLE records_profile
|
||||
ADD CHECK (collection in ('app.bsky.actor.profile'));
|
||||
|
||||
-- SLOW, can run overnight
|
||||
with moved_rows as (
|
||||
delete from records_like r
|
||||
where collection <> 'app.bsky.feed.like'
|
||||
|
@ -32,9 +46,9 @@ with moved_rows as (
|
|||
)
|
||||
insert into records select * from moved_rows;
|
||||
|
||||
-- ULTRA SLOW, DO NOT RUN on large DB
|
||||
alter table records attach partition records_like for values in ('app.bsky.feed.like');
|
||||
|
||||
|
||||
create index idx_like_subject
|
||||
on records_like
|
||||
(split_part(jsonb_extract_path_text(content, 'subject', 'uri'), '/', 3));
|
|
@ -22,7 +22,7 @@ create index post_created_at on records_post (parse_timestamp(jsonb_extract_path
|
|||
|
||||
create view posts as
|
||||
select *, jsonb_extract_path(content, 'langs') as langs,
|
||||
parse_timestamp(jsonb_extract_path_text(content, 'createdAt')) as created_at
|
||||
parse_timestamp(jsonb_extract_path_text(content, 'createdAt')) as content_created_at
|
||||
from records_post;
|
||||
|
||||
explain select count(*) from posts where langs ? 'uk' and content_created_at > now() - interval '1 day';
|
|
@ -7,6 +7,15 @@ partition of records for values in ('app.bsky.graph.listblock');
|
|||
create table records_listitem
|
||||
partition of records for values in ('app.bsky.graph.listitem');
|
||||
|
||||
ALTER TABLE records_list
|
||||
ADD CHECK (collection in ('app.bsky.graph.list'));
|
||||
|
||||
ALTER TABLE records_listblock
|
||||
ADD CHECK (collection in ('app.bsky.graph.listblock'));
|
||||
|
||||
ALTER TABLE records_listitem
|
||||
ADD CHECK (collection in ('app.bsky.graph.listitem'));
|
||||
|
||||
with moved_rows as (
|
||||
delete from records_default r
|
||||
where collection in ('app.bsky.graph.list', 'app.bsky.graph.listblock', 'app.bsky.graph.listitem')
|
Loading…
Add table
Add a link
Reference in a new issue