58 lines
2.1 KiB
MySQL
58 lines
2.1 KiB
MySQL
|
DROP MATERIALIZED VIEW IF EXISTS "cards";
|
||
|
CREATE MATERIALIZED VIEW "cards" AS
|
||
|
SELECT "oracle"."oracle_id"
|
||
|
, "oracle"."name"
|
||
|
, "oracle"."color_identity"
|
||
|
, "oracle"."cmc"
|
||
|
, "oracle"."mana_cost"
|
||
|
, "oracle"."type_line"
|
||
|
, "oracle"."edhrec_rank"
|
||
|
, "oracle"."oracle_text"
|
||
|
, "scryfall"."scryfall_id"
|
||
|
, "scryfall"."set_code"
|
||
|
, "scryfall"."collector_number"
|
||
|
, "scryfall"."release_date"
|
||
|
, "scryfall"."rarity"
|
||
|
, "sets"."name" AS "set_name"
|
||
|
, "card_prices"."usd" AS "price_usd"
|
||
|
, "card_prices"."usd_foil" AS "price_usd_foil"
|
||
|
, "card_prices"."eur" AS "price_eur"
|
||
|
, "card_prices"."eur_foil" AS "price_eur_foil"
|
||
|
, "card_prices"."tix" AS "price_tix"
|
||
|
FROM "oracle"
|
||
|
JOIN "scryfall" USING ("oracle_id")
|
||
|
LEFT JOIN "card_prices" ON ("scryfall"."scryfall_id" = "card_prices"."scryfall_id"
|
||
|
AND "card_prices"."date" = (SELECT VALUE FROM "vars" WHERE "key" = 'last_update'))
|
||
|
JOIN "sets" USING ("set_code");
|
||
|
|
||
|
DROP MATERIALIZED VIEW IF EXISTS "oracle_latest";
|
||
|
CREATE MATERIALIZED VIEW "oracle_latest" AS
|
||
|
SELECT "oracle"."oracle_id"
|
||
|
, "oracle"."name"
|
||
|
, "oracle"."color_identity"
|
||
|
, "oracle"."cmc"
|
||
|
, "oracle"."mana_cost"
|
||
|
, "oracle"."type_line"
|
||
|
, "oracle"."edhrec_rank"
|
||
|
, "oracle"."oracle_text"
|
||
|
, "scryfall"."scryfall_id"
|
||
|
, "scryfall"."set_code"
|
||
|
, "scryfall"."collector_number"
|
||
|
, "scryfall"."release_date"
|
||
|
, "scryfall"."rarity"
|
||
|
, "sets"."name" AS "set_name"
|
||
|
, "card_prices"."usd" AS "price_usd"
|
||
|
, "card_prices"."usd_foil" AS "price_usd_foil"
|
||
|
, "card_prices"."eur" AS "price_eur"
|
||
|
, "card_prices"."eur_foil" AS "price_eur_foil"
|
||
|
, "card_prices"."tix" AS "price_tix"
|
||
|
FROM "oracle"
|
||
|
JOIN (
|
||
|
SELECT DISTINCT ON ("oracle_id") *
|
||
|
FROM "scryfall"
|
||
|
ORDER BY "oracle_id", "release_date" DESC
|
||
|
) "scryfall" USING ("oracle_id")
|
||
|
LEFT JOIN "card_prices" ON ("scryfall"."scryfall_id" = "card_prices"."scryfall_id"
|
||
|
AND "card_prices"."date" = (SELECT VALUE FROM "vars" WHERE "key" = 'last_update'))
|
||
|
JOIN "sets" USING ("set_code");
|