From 5f9bf36d9539bdd3e4bfad87971407f519ddb9f0 Mon Sep 17 00:00:00 2001 From: Frank Baele Date: Sun, 7 Jun 2020 10:32:11 +0200 Subject: [PATCH] add SQLite example --- SQLite_etl/index.js | 57 +++++++++++++++++++++++++++++++++++++++++ avro_container/index.js | 14 +++++----- 2 files changed, 64 insertions(+), 7 deletions(-) create mode 100644 SQLite_etl/index.js diff --git a/SQLite_etl/index.js b/SQLite_etl/index.js new file mode 100644 index 0000000..5e63ada --- /dev/null +++ b/SQLite_etl/index.js @@ -0,0 +1,57 @@ +import Database from 'better-sqlite3'; + +import axios from 'axios'; +import parse from 'csv-parse'; + +import { v4 as uuidv4 } from 'uuid'; + +const openFoodFactsUrl = 'https://static.openfoodfacts.org/data/en.openfoodfacts.org.products.csv'; +const parser = parse({delimiter: '\t', columns: true, relax: true}); + + + +(async () => { + // Create our sqlite database in memory + const db = new Database('openFoodFacts.db'); + db.prepare('DROP TABLE IF EXISTS trade_items_open_food_facts').run(); + db.prepare('CREATE TABLE trade_items_open_food_facts (id TEXT PRIMARY KEY, gtin TEXT, name TEXT, brand text, nutriscore TEXT);').run(); + const insert = db.prepare('INSERT INTO trade_items_open_food_facts (id, gtin, name, brand, nutriscore) VALUES (@id, @gtin, @name, @brand, @nutriscore)'); + + const response = await axios({ + method: 'get', + url: openFoodFactsUrl, + responseType: 'stream' + }); + + const stream = response.data.pipe(parser); + console.log('starting import'); + + function parseItem(item){ + insert.run({ + id: uuidv4(), + gtin: item.code, + name:item.product_name, + brand: item.brands, + nutriscore: item.nutriscore_grade && item.nutriscore_grade.toUpperCase ? item.nutriscore_grade.toUpperCase() : undefined, + }) + } + await new Promise((resolve, reject) => { + stream + .on('data', function(item) { + parseItem(item) + }) + .on('end', () => { + resolve('End of the csv file'); + }) + .on('error', e => { + reject(e) + }); + }) + console.log("import is done") + console.log("Count by nutriscore") + const count = db.prepare("SELECT count(id), nutriscore from trade_items_open_food_facts group by nutriscore").all(); + console.log(count); + console.log("Group by brand") + const grouped = db.prepare("SELECT brand, count(id), group_concat(gtin) as gtin from trade_items_open_food_facts group by brand").all(); + console.log(grouped); +})(); \ No newline at end of file diff --git a/avro_container/index.js b/avro_container/index.js index 768d3bd..4ef27ae 100644 --- a/avro_container/index.js +++ b/avro_container/index.js @@ -74,13 +74,13 @@ encoder.end(); import fs from 'fs'; const src = fs.createReadStream('./users.avro'); -// src.pipe(new avsc.streams.BlockDecoder()) -// .on('data', function (item) { -// console.log(item); -// }) -// .on('end', () => { -// console.log('All records read') -// }); +src.pipe(new avsc.streams.BlockDecoder()) + .on('data', function (item) { + console.log(item); + }) + .on('end', () => { + console.log('All records read') + }); // Snappy example