tab-yoinker/02-ingest-sqlite/01-injest-sqlite.js
2021-09-23 23:15:03 -05:00

127 lines
3.8 KiB
JavaScript

// Injests from ./input/* into ./output/tabs.db
const sqlite3 = require('sqlite3');
const sqlite = require('sqlite');
const fs = require('fs/promises');
(async () => {
const db = await sqlite.open({
driver: sqlite3.Database,
filename: './output/tabs-no-text.db'
});
await db.run(`
CREATE TABLE IF NOT EXISTS artists (
scrape_id INTEGER NOT NULL PRIMARY KEY AUTOINCREMENT
, id INTEGER
, name TEXT
, tabscount INTEGER
, artist_url TEXT
, tabs_last_update_timestamp INTEGER
)
`);
await db.run(`
CREATE TABLE IF NOT EXISTS tabs (
scrape_id INTEGER NOT NULL PRIMARY KEY AUTOINCREMENT
, artist_scrape_id INTEGER NOT NULL
, id INTEGER
, song_id INTEGER
, song_name TEXT
, artist_id INTEGER
, artist_name INTEGER
, type TEXT
, part TEXT
, version INTEGER
, votes INTEGER
, rating NUMERIC
, date TEXT
, status TEXT
, preset_id INTEGER
, tab_access_type TEXT
, tp_version INTEGER
, tonality_name TEXT
, version_description TEXT
, verified INTEGER
, artist_url TEXT
, tab_url TEXT
, tab_text TEXT
, difficulty TEXT
, tuning TEXT
, type_name TEXT
, FOREIGN KEY (artist_scrape_id) REFERENCES artists(scrape_id)
)
`);
// Clear out the database
await db.run('DELETE FROM tabs');
await db.run('DELETE FROM artists');
const files = await fs.readdir('./input/');
const stmtAddArtist = await db.prepare(`
INSERT INTO artists (
id, name, tabscount, artist_url, tabs_last_update_timestamp
) VALUES (
?1, ?2, ?3, ?4, ?5
)
`);
const stmtAddTab = await db.prepare(`
INSERT INTO tabs (
artist_scrape_id
, id, song_id, song_name, artist_id, artist_name, type, part
, version, votes, rating, date, status, preset_id, tab_access_type, tp_version, tonality_name
, version_description, verified, artist_url, tab_url, tab_text, difficulty, tuning, type_name
) VALUES (
?1
, ?2, ?3, ?4, ?5, ?6, ?7, ?8
, ?9, ?10, ?11, ?12, ?13, ?14, ?15, ?16, ?17
, ?18, ?19, ?20, ?21, ?22, ?23, ?24, ?25
)
`);
function addArtist(id, name, tabscount, artist_url, tabs_last_update_timestamp) {
return stmtAddArtist.run([id, name, tabscount, artist_url, tabs_last_update_timestamp]);
}
function addTab(
artist_scrape_id, id, song_id, song_name, artist_id, artist_name, type, part, version, votes,
rating, date, status, preset_id, tab_access_type, tp_version, tonality_name, version_description,
verified, artist_url, tab_url, tab_text, difficulty, tuning, type_name
) {
return stmtAddTab.run([
artist_scrape_id, id, song_id, song_name, artist_id, artist_name, type, part, version, votes,
rating, date, status, preset_id, tab_access_type, tp_version, tonality_name, version_description,
verified, artist_url, tab_url, tab_text, difficulty, tuning, type_name
]);
}
for (let file of files) {
if (!file.endsWith('.json')) continue; // skip the .keep file
console.log('reading ./input/' + file);
let dataJSON = await fs.readFile('./input/' + file);
let data = JSON.parse(dataJSON);
let artistIndex = 0;
for (let artist of data) {
console.log(`adding artist (${artistIndex+1}/${data.length}, ${artist.tabs.length} tabs): ${artist.name}`)
let artistResult = await addArtist(artist.id, artist.name, artist.tabscount, artist.artist_url, artist.tabs_last_update_timestamp);
let artistScrapeId = artistResult.lastID;
for (let tab of artist.tabs) {
addTab(
artistScrapeId,
tab.id, tab.song_id, tab.song_name, tab.artist_id, tab.artist_name, tab.type, tab.part, tab.version, tab.votes,
tab.rating, tab.date, tab.status, tab.preset_id, tab.tab_access_type, tab.tp_version, tab.tonality_name, tab.version_description,
tab.verified, tab.artist_url, tab.tab_url, null, tab.difficulty, tab.tuning, tab.type_name
);
}
artistIndex += 1;
}
}
await stmtAddTab.finalize();
await stmtAddArtist.finalize();
await db.close();
})();