2017-11-03 00:09:34 +00:00
|
|
|
const SQLite = require('react-native-sqlite-storage');
|
2017-06-11 22:11:14 +01:00
|
|
|
|
|
|
|
class DatabaseDriverReactNative {
|
2017-11-27 22:50:46 +00:00
|
|
|
constructor() {
|
|
|
|
this.lastInsertId_ = null;
|
|
|
|
}
|
|
|
|
|
2017-06-11 22:11:14 +01:00
|
|
|
open(options) {
|
2019-10-09 21:35:13 +02:00
|
|
|
// SQLite.DEBUG(true);
|
2017-06-11 22:11:14 +01:00
|
|
|
return new Promise((resolve, reject) => {
|
2019-07-29 15:43:53 +02:00
|
|
|
SQLite.openDatabase(
|
|
|
|
{ name: options.name },
|
2020-05-21 09:14:33 +01:00
|
|
|
db => {
|
2019-07-29 15:43:53 +02:00
|
|
|
this.db_ = db;
|
|
|
|
resolve();
|
|
|
|
},
|
2020-05-21 09:14:33 +01:00
|
|
|
error => {
|
2019-07-29 15:43:53 +02:00
|
|
|
reject(error);
|
|
|
|
}
|
|
|
|
);
|
2017-06-11 22:11:14 +01:00
|
|
|
});
|
|
|
|
}
|
|
|
|
|
2019-09-12 22:16:42 +00:00
|
|
|
sqliteErrorToJsError(error) {
|
2017-07-05 22:29:00 +01:00
|
|
|
return error;
|
|
|
|
}
|
|
|
|
|
2017-06-11 22:11:14 +01:00
|
|
|
selectOne(sql, params = null) {
|
|
|
|
return new Promise((resolve, reject) => {
|
2019-07-29 15:43:53 +02:00
|
|
|
this.db_.executeSql(
|
|
|
|
sql,
|
|
|
|
params,
|
2020-05-21 09:14:33 +01:00
|
|
|
r => {
|
2019-07-29 15:43:53 +02:00
|
|
|
resolve(r.rows.length ? r.rows.item(0) : null);
|
|
|
|
},
|
2020-05-21 09:14:33 +01:00
|
|
|
error => {
|
2019-07-29 15:43:53 +02:00
|
|
|
reject(error);
|
|
|
|
}
|
|
|
|
);
|
2017-06-11 22:11:14 +01:00
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
selectAll(sql, params = null) {
|
2020-05-21 09:14:33 +01:00
|
|
|
return this.exec(sql, params).then(r => {
|
2020-03-13 23:46:14 +00:00
|
|
|
const output = [];
|
2017-06-11 22:11:14 +01:00
|
|
|
for (let i = 0; i < r.rows.length; i++) {
|
|
|
|
output.push(r.rows.item(i));
|
|
|
|
}
|
|
|
|
return output;
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
2020-09-06 17:37:00 +05:30
|
|
|
loadExtension(path) {
|
|
|
|
throw new Error(`No extension support for ${path} in react-native-sqlite-storage`);
|
|
|
|
}
|
|
|
|
|
2017-06-11 22:11:14 +01:00
|
|
|
exec(sql, params = null) {
|
|
|
|
return new Promise((resolve, reject) => {
|
2019-07-29 15:43:53 +02:00
|
|
|
this.db_.executeSql(
|
|
|
|
sql,
|
|
|
|
params,
|
2020-05-21 09:14:33 +01:00
|
|
|
r => {
|
2019-07-29 15:43:53 +02:00
|
|
|
if ('insertId' in r) this.lastInsertId_ = r.insertId;
|
|
|
|
resolve(r);
|
|
|
|
},
|
2020-05-21 09:14:33 +01:00
|
|
|
error => {
|
2019-07-29 15:43:53 +02:00
|
|
|
reject(error);
|
|
|
|
}
|
|
|
|
);
|
2017-06-11 22:11:14 +01:00
|
|
|
});
|
|
|
|
}
|
|
|
|
|
2017-11-27 22:50:46 +00:00
|
|
|
lastInsertId() {
|
|
|
|
return this.lastInsertId_;
|
|
|
|
}
|
2017-06-11 22:11:14 +01:00
|
|
|
}
|
|
|
|
|
2019-07-29 15:43:53 +02:00
|
|
|
module.exports = { DatabaseDriverReactNative };
|