= EdenMobile Database = [[TOC]] == $emdb Service == EdenMobile provides the '''$emdb''' service to access the database. To use the service, it must be included in the controller dependencies: {{{ #!js EdenMobile.controller("MyController", [ '$scope', '$stateParams', '$emdb', function($scope, $stateParams, $emdb) { // controller code goes here } ]); }}} {{{$emdb}}} automatically bootstraps the database when it is first initialized. == Default Schema == The database schema is stored ''in'' in the database itself, in the {{{em_schema}}} table. For the initial setup of the database, a static {{{emDefaultSchema}}} (in www/js/modules/schema.js) is used: {{{ #!js var emSchemaVersion = '1'; var emDefaultSchema = { /** * Table to store the current schema version */ 'em_version': { 'version': { type: 'string', label: 'Version', notnull: true }, _records: [ {'version': emSchemaVersion} ] }, /** * Table to store table schemas */ 'em_schema': { 'name': { type: 'string', label: 'Name', notnull: true }, 'schema': { type: 'json', label: 'Schema', notnull: true } } }; }}} Once this schema has been written to the new database, it will be ignored. == emSQL == {{{emSQL}}} is a helper module to construct common SQL statements. It can be found in www/js/modules/sql.js. Examples: {{{ #!js // Schema definition var schema = { id: { type: 'id' }, name: { type: 'string', label: 'Name', notnull: true }, number: { type: 'integer', }, }; // Create an emSQL helper for this schema var table = emSQL.Table('testtable', schema); // Produce SQL to create the table // sql == 'CREATE IF NOT EXISTS "testtable" (id INTEGER PRIMARY KEY AUTOINCREMENT,name TEXT NOT NULL,number INTEGER)' var sql = table.create(); // Produce SQL to insert data // => produces a tuple: an SQL string with placeholders and an array with values (for use with db.executeSql) // sql == ['INSERT INTO "testtable" (name,number) VALUES (?,?)', ['testing',4]] sql = table.insert({name: 'testing', number: 4}); // Produce SQL to select data // sql == 'SELECT testtable.id,testtable.name FROM "testtable" WHERE number>2' sql = table.select(['id', 'name'], 'number>2'); // Produce SQL to drop the table // sql == 'DROP TABLE IF EXISTS "testtable"' sql = table.drop(); }}}