import 'package:sqflite/sqflite.dart' as sqf; import 'package:flutter/foundation.dart'; import 'package:vital_local_database/index.dart'; import 'package:vitalapp/database/db_patch/v5.dart'; import 'package:vitalapp/database/entities/diagnosis.dart'; import 'package:vitalapp/database/entities/patient.dart'; import 'package:vitalapp/database/repositories/followup.dart'; import 'package:vitalapp/database/repositories/interfaces/followup.dart'; import 'db_patch/v3.dart'; import 'db_patch/v4.dart'; import 'repositories/exam.dart'; import 'repositories/exam_batch.dart'; import 'repositories/interfaces/diagnosis.dart'; import 'repositories/interfaces/exam.dart'; import 'repositories/interfaces/exam_batch.dart'; import 'repositories/interfaces/patient.dart'; import 'repositories/diagnosis.dart'; import 'repositories/patient.dart'; import 'package:fis_common/logger/logger.dart'; import 'db_patch/v1.dart'; import 'db_patch/v2.dart'; /// vital 本地数据库对象 final db = VitalDatabaseAccessor(); /// vital本地数据库访问器 class VitalDatabaseAccessor extends BaseDbAccessor { final _store = VitalDatabaseRepositoryStore(); final _connection = SqliteConnection(path: "vital.db"); late IDatabase _database; @override IDatabase get database => _database; @override VitalDatabaseRepositoryStore get repositories => _store; /// 初始化 Future init() async { if (kDebugMode) { // !!!!危险操作 await sqf.deleteDatabase("vital.db"); } _database = await _connection.open(); if (kDebugMode) { await _debugBatch(); } try { await checkAndUpgradeDatabaseVersion(); } catch (e) { logger.e( "VitalDatabaseAccessor checkAndUpgradeDatabaseVersion error.", e); } _store.regRepository(PatientRepository(database)); _store.regRepository(DiagnosisRepository(database)); _store.regRepository(FollowUpRepository(database)); _store.regRepository(ExamRepository(database)); _store.regRepository(ExamBatchRepository(database)); } Future _debugBatch() async { // TODO: 此处仅限开发调试时临时执行,提交前请清除!!!! // database.execute("DROP TABLE ${PatientEntity().tableName};"); // database.execute("DROP TABLE ${DiagnosisEntity().tableName};"); // database.execute("DROP TABLE ${FollowUpEntity().tableName};"); // database.execute("DROP TABLE ${ExamBatchEntity().tableName};"); // database.execute("DROP TABLE ${ExamEntity().tableName};"); } ///检查本地数据库版本,以判断是否需要升级 Future checkAndUpgradeDatabaseVersion() async { var originalVersion = await database.getVersion(); logger.w( "VitalDatabaseAccessor checkAndUpgradeDatabaseVersion originalVersion:$originalVersion."); if (originalVersion == 0) { // 数据库首次创建,V0 await database.execute(PatientEntity.TABLE_CREATE_SQL); await database.execute(DiagnosisEntity.TABLE_CREATE_SQL); } int version = originalVersion; version = await DatabasePatchV1(database).perform(version); version = await DatabasePatchV2(database).perform(version); version = await DatabasePatchV3(database).perform(version); version = await DatabasePatchV4(database).perform(version); version = await DatabasePatchV5(database).perform(version); if (version != originalVersion) { // 数据库升级 await db.database.setVersion(version); // 重启DB await _connection.close(); _database = await _connection.open(); } logger.w( "VitalDatabaseAccessor checkAndUpgradeDatabaseVersion version:$version."); } void dispose() { _connection.close(); } } class VitalDatabaseRepositoryStore extends BaseDbAccessorRepositoryStore { /// 居民仓储 IPatientRepository get patient => findRepository()!; /// 检测记录仓储 IDiagnosisRepository get diagnosis => findRepository()!; /// 随访仓储 IFollowUpRepository get followUp => findRepository()!; /// 体检仓储 IExamRepository get exam => findRepository()!; /// 体检批次仓储 IExamBatchRepository get examBatch => findRepository()!; }