chore: 🚧 remove cinemagoer and fiber and add new techinque for scraping

This commit is contained in:
2024-11-06 01:59:13 +01:00
parent 6d88e96864
commit cba9dd3ffc
46 changed files with 1179 additions and 1764 deletions
@@ -0,0 +1,32 @@
create table if not exists tv_show (
id integer primary key,
"name" varchar not null,
tt_imdb varchar not null,
popularity int not null default 0,
created_at timestamp not null default (now()),
updated_at timestamp not null default (now())
);
create index if not exists idx_tv_show_title on "tv_show" ("title");
create index if not exists idx_tv_show_updated_at on "tv_show" ("updated_at");
create table if not exists episodes (
id integer primary key,
tv_show_id integer not null,
season integer not null,
episode integer not null,
released date,
"name" varchar not null,
plot text not null default '',
avg_rating numeric(1,1) not null default 0,
vote_count int not null default 0,
foreign key (tv_show_id) references tv_show (id)
);
+37
View File
@@ -0,0 +1,37 @@
-- name: CreateTVShow :one
insert into "tv_show" (name, tt_imdb)
values ($1, $2)
returning *;
-- name: CreateEpisodes :one
insert into "episodes" (tv_show_id, season, episode, released, name, plot, avg_rating, vote_count)
values ($1, $2, $3, $4, $5, $6, $7, $8)
returning *;
-- name: CheckTVShowExists :one
select * from "tv_show"
where tt_imdb = $1;
-- name: GetEpisodes :many
select * from "episodes"
where tv_show_id = $1;
-- name: IncreasePopularity :exec
update "tv_show" set popularity = popularity + 1
where id = $1;
-- name: TvShowAverageRating :one
select avg(avg_rating) from "episodes"
where tv_show_id = $1;
-- name: TvShowMedianRating :one
select percentile_cont(0.5) within group (order by avg_rating) from "episodes"
where tv_show_id = $1;
-- name: SeasonAverageRating :one
select avg(avg_rating) from "episodes"
where tv_show_id = $1 and season = $2;
-- name: SeasonMedianRating :one
-- select percentile_cont(0.5) within group (order by avg_rating) from "episodes"
-- where tv_show_id = $1 and season = $2;