mirror of
https://github.com/gosticks/DefinitelyTyped.git
synced 2025-10-16 12:05:41 +00:00
# Conflicts: # amcharts/AmCharts.d.ts # angular-gettext/angular-gettext.d.ts # angular-jwt/angular-jwt.d.ts # angular-material/angular-material.d.ts # angularjs/angular.d.ts # auth0-js/auth0-js.d.ts # aws-lambda/aws-lambda.d.ts # aws-sdk/aws-sdk.d.ts # azure-mobile-apps/azure-mobile-apps.d.ts # azure-mobile-services-client/AzureMobileServicesClient.d.ts # blessed/blessed-tests.ts # blessed/blessed.d.ts # bootbox/bootbox.d.ts # bowser/bowser.d.ts # cache-manager/cache-manager.d.ts # chai-things/chai-things.d.ts # colors/colors.d.ts # cordova/cordova-tests.ts # cordova/plugins/Contacts.d.ts # cordova/plugins/FileSystem.d.ts # couchbase/couchbase.d.ts # cucumber/cucumber-tests.ts # cucumber/cucumber.d.ts # d3/d3.d.ts # dojo/dojo.d.ts # dustjs-linkedin/dustjs-linkedin.d.ts # esprima/esprima.d.ts # express-serve-static-core/express-serve-static-core.d.ts # express-session/express-session.d.ts # fetch-mock/fetch-mock.d.ts # fs-extra/fs-extra.d.ts # fullCalendar/fullCalendar.d.ts # github-electron/github-electron.d.ts # gulp-uglify/gulp-uglify.d.ts # gulp/gulp.d.ts # highcharts/highcharts.d.ts # imap/imap.d.ts # incremental-dom/incremental-dom.d.ts # inversify/inversify.d.ts # ionic/ionic.d.ts # ioredis/ioredis.d.ts # isomorphic-fetch/isomorphic-fetch-tests.ts # jake/jake.d.ts # joi/joi.d.ts # jquery-mockjax/jquery-mockjax.d.ts # jquery/jquery.d.ts # js-data-http/js-data-http-tests.ts # js-data-http/js-data-http.d.ts # js-data/js-data.d.ts # jsdom/jsdom.d.ts # jsts/jsts-tests.ts # knex/knex.d.ts # koa-favicon/koa-favicon.d.ts # koa-router/koa-router-tests.ts # koa-router/koa-router.d.ts # lodash/lodash.d.ts # mailparser/mailparser.d.ts # maquette/maquette.d.ts # material-ui/material-ui.d.ts # matter-js/matter-js.d.ts # moment/moment.d.ts # mongoose-promise/mongoose-promise-tests.ts # mongoose/mongoose-tests.ts # mongoose/mongoose.d.ts # multer/multer.d.ts # ncp/ncp.d.ts # nock/nock.d.ts # node/node-tests.ts # node/node.d.ts # nvd3/nvd3.d.ts # object-assign/object-assign.d.ts # openlayers/openlayers.d.ts # parse/parse.d.ts # pdf/pdf.d.ts # pdfkit/pdfkit.d.ts # pg/pg.d.ts # pixi.js/pixi.js.d.ts # progress/progress.d.ts # pusher-js/pusher-js.d.ts # quill/quill-tests.ts # quill/quill.d.ts # radium/radium.d.ts # ravenjs/ravenjs-tests.ts # react-dropzone/react-dropzone.d.ts # react-mdl/react-mdl.d.ts # react-native/react-native.d.ts # react-notification-system/react-notification-system.d.ts # react-router/history-tests.ts # react-router/react-router-tests.tsx # react-router/react-router.d.ts # react-select/react-select-tests.tsx # react-select/react-select.d.ts # react/react.d.ts # redux-form/redux-form.d.ts # request-promise/request-promise.d.ts # resolve-from/resolve-from.d.ts # riot-api-nodejs/riot-api-nodejs.d.ts # sanitize-html/sanitize-html.d.ts # segment-analytics/segment-analytics.d.ts # simple-assign/simple-assign-tests.ts # simple-assign/simple-assign.d.ts # slate-irc/slate-irc.d.ts # soap/soap.d.ts # socket.io/socket.io.d.ts # sql.js/sql.js-tests.ts # sql.js/sql.js.d.ts # steam/steam.d.ts # stylus/stylus.d.ts # swiper/swiper.d.ts # tedious/tedious.d.ts # threejs/three.d.ts # twilio/twilio.d.ts # underscore/underscore.d.ts # ws/ws.d.ts # yeoman-generator/yeoman-generator.d.ts
95 lines
2.5 KiB
TypeScript
95 lines
2.5 KiB
TypeScript
/// <reference types="node" />
|
|
|
|
|
|
import fs = require("fs");
|
|
import * as SQL from "sql.js";
|
|
|
|
var DB_PATH = "data.db";
|
|
|
|
function createFile(path: string): void {
|
|
var fd = fs.openSync(path, "a");
|
|
fs.closeSync(fd);
|
|
}
|
|
|
|
// Open the database file. If it does not exist, create a blank database in memory.
|
|
var databaseData: Buffer;
|
|
databaseData = fs.existsSync(DB_PATH) ? fs.readFileSync(DB_PATH) : null;
|
|
var db = new SQL.Database(databaseData);
|
|
|
|
// Create a new table 'test_table' in the database in memory.
|
|
var createTableStatement =
|
|
"DROP TABLE IF EXISTS test_table;" +
|
|
"CREATE TABLE test_table (id INTEGER PRIMARY KEY, content TEXT);";
|
|
db.run(createTableStatement);
|
|
|
|
// Insert 2 records for testing.
|
|
var insertRecordStatement =
|
|
"INSERT INTO test_table (id, content) VALUES (@id, @content);";
|
|
db.run(insertRecordStatement, {
|
|
"@id": 1,
|
|
"@content": "Content 1"
|
|
});
|
|
db.run(insertRecordStatement, {
|
|
"@id": 2,
|
|
"@content": "Content 2"
|
|
});
|
|
|
|
var n = db.getRowsModified();
|
|
|
|
try {
|
|
// This query will throw exception: primary key constraint failed.
|
|
db.run(insertRecordStatement, {
|
|
"@id": 1,
|
|
"@content": "Content 3"
|
|
});
|
|
} catch (ex) {
|
|
console.warn(ex);
|
|
}
|
|
|
|
// A simple SELECT query.
|
|
var selectRecordStatement =
|
|
"SELECT * FROM test_table WHERE id = @id;"
|
|
var selectStatementObject = db.prepare(selectRecordStatement);
|
|
var results = selectStatementObject.get({
|
|
"@id": 1
|
|
});
|
|
console.log(results);
|
|
selectStatementObject.free();
|
|
|
|
// Access the results one by one, asynchronously.
|
|
var selectRecordsStatement =
|
|
"SELECT * FROM test_table;";
|
|
db.each(
|
|
selectRecordsStatement,
|
|
(obj: { [columnName: string]: number | string | Uint8Array }): void => {
|
|
console.log(obj);
|
|
},
|
|
(): void => {
|
|
console.info("Iteration done.");
|
|
dbAccessDone();
|
|
});
|
|
|
|
|
|
function dbAccessDone(): void {
|
|
// Save the database into SQLite version 3 format.
|
|
if (!fs.existsSync(DB_PATH)) {
|
|
createFile(DB_PATH);
|
|
}
|
|
var exportedData = db.export();
|
|
fs.writeFileSync(DB_PATH, exportedData);
|
|
|
|
// Finally, close the database connection and release the resources in memory.
|
|
db.close();
|
|
}
|
|
|
|
// Create a database
|
|
var db2 = new SQL.Database();
|
|
|
|
// You can also use javascript functions inside your SQL code
|
|
// Create the js function you need
|
|
function add(a: number, b: number): number {return a+b;}
|
|
// Specifies the SQL function's name, the number of it's arguments, and the js function to use
|
|
db2.create_function("add_js", add);
|
|
// Run a query in which the function is used
|
|
db2.run("INSERT INTO hello VALUES (add_js(7, 3), add_js('Hello ', 'world'));"); // Inserts 10 and 'Hello world'
|