aita
Val Town is a collaborative website to build and scale JavaScript apps.
Deploy APIs, crons, & store data – all from the browser, and deployed in milliseconds.
Viewing readonly version of main branch: v349View latest version
This script extracts the top 100 most popular posts (by score) and all their comments from the AmItheAsshole subreddit database to a new, smaller SQLite database file.
- Deno installed on your system
- Original database file at db/AmItheAsshole.sqlite
Run the script with the following command:
deno run --allow-read --allow-write extract_top_posts.ts
Alternatively, you can make the script executable and run it directly:
chmod +x extract_top_posts.ts ./extract_top_posts.ts
- Opens the source database (db/AmItheAsshole.sqlite)
- Creates a new target database (db/Top100AmItheAsshole.sqlite)
- Extracts the top 100 posts from the source database based on score
- Extracts all comments associated with those posts
- Preserves all original data including IDs, timestamps, and relationships
The script maintains the original schema structure:
CREATE TABLE IF NOT EXISTS "submission" (
  "id" INTEGER NOT NULL PRIMARY KEY,
  "submission_id" VARCHAR(255) NOT NULL,
  "title" TEXT NOT NULL,
  "selftext" TEXT NOT NULL,
  "created_utc" DATE NOT NULL,
  "permalink" TEXT NOT NULL,
  "score" INTEGER NOT NULL
);
CREATE UNIQUE INDEX "submission_submission_id" ON "submission" ("submission_id");
CREATE TABLE IF NOT EXISTS "comment" (
  "id" INTEGER NOT NULL PRIMARY KEY,
  "submission_id" INTEGER NOT NULL,
  "message" TEXT NOT NULL,
  "comment_id" VARCHAR(255) NOT NULL,
  "parent_id" VARCHAR(255) NOT NULL,
  "created_utc" DATE NOT NULL,
  "score" INTEGER NOT NULL,
  FOREIGN KEY ("submission_id") REFERENCES "submission" ("id")
);
CREATE INDEX "comment_submission_id" ON "comment" ("submission_id");
CREATE UNIQUE INDEX "comment_comment_id" ON "comment" ("comment_id");