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: v468View 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");