当我使用sqlite时,需要一直重新打开数据酶,andi这太糟糕了。我如何使用SQLite实例创建/设置一个全局变量以在组件之间共享它?
简单示例:
app/app.ts
export class MyApp {
constructor(public platform: Platform) {
this.platform.ready().then(() => {
@SetGlobal();
let databaseInstance = new SQLite();
});
}
}
home/home.ts
export class HomePage {
constructor(public platform: Platform, databaseInstance) {
databaseInstance.then(() => {
databaseInstance.executeSql('create table demo(name VARCHAR(32))', {}).then(() => {
}, (err) => {
console.error('Unable to execute sql: ', err);
});
}, (err) => {
console.error('Unable to open database: ', err);
});
}
}
主要思想就是将连接保持在共享服务中,以确保您只有一个活着的连接。如果您仅在app.module.ts
上提供此服务,则此服务将是单身实例,这就是您想要的。
数据库服务:
@Injectable()
export class DatabaseService {
public instance = null;
constructor(){
this.instance = new SQLite();
}
}
app.module.ts:
@NgModule({
...
providers: [
...
DatabaseService
]
})
export class AppModule {}
home.ts:
export class HomePage {
constructor(public platform: Platform, dbService: DatabaseService) {
dbService.instance.then(() => {
dbService.instance.executeSql('create table demo(name VARCHAR(32))', {}).then(() => {
}, (err) => {
console.error('Unable to execute sql: ', err);
});
}, (err) => {
console.error('Unable to open database: ', err);
});
}
}