mirror of
https://github.com/BTMuli/TeyvatGuide.git
synced 2025-12-12 09:18:14 +08:00
🐛 修复数据库初始化异常
This commit is contained in:
14
src/App.vue
14
src/App.vue
@@ -100,6 +100,7 @@ onMounted(async () => {
|
|||||||
function listenOnInit(): void {
|
function listenOnInit(): void {
|
||||||
console.info("[App][listenOnInit] 监听初始化事件!");
|
console.info("[App][listenOnInit] 监听初始化事件!");
|
||||||
event.listen("initApp", async () => {
|
event.listen("initApp", async () => {
|
||||||
|
await checkAppLoad();
|
||||||
await checkDeviceFp();
|
await checkDeviceFp();
|
||||||
try {
|
try {
|
||||||
await checkUserLoad();
|
await checkUserLoad();
|
||||||
@@ -112,6 +113,19 @@ function listenOnInit(): void {
|
|||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
async function checkAppLoad(): Promise<void> {
|
||||||
|
let checkDB = false;
|
||||||
|
try {
|
||||||
|
checkDB = await TGSqlite.check();
|
||||||
|
} catch (error) {
|
||||||
|
if (error instanceof Error) {
|
||||||
|
await TGLogger.Error(`[App][checkAppLoad] ${error.name}: ${error.message}`);
|
||||||
|
} else console.error(error);
|
||||||
|
}
|
||||||
|
if (!checkDB) await TGSqlite.update();
|
||||||
|
else await TGLogger.Info("[App][checkAppLoad] 数据库已成功加载!");
|
||||||
|
}
|
||||||
|
|
||||||
// 检测 deviceFp
|
// 检测 deviceFp
|
||||||
async function checkDeviceFp(): Promise<void> {
|
async function checkDeviceFp(): Promise<void> {
|
||||||
const appData = await TGSqlite.getAppData();
|
const appData = await TGSqlite.getAppData();
|
||||||
|
|||||||
@@ -1,12 +1,14 @@
|
|||||||
/**
|
/**
|
||||||
* @file plugins/Sqlite/index.ts
|
* @file plugins/Sqlite/index.ts
|
||||||
* @description Sqlite 数据库操作类
|
* @description Sqlite 数据库操作类
|
||||||
* @since Beta v0.6.0
|
* @since Beta v0.6.1
|
||||||
*/
|
*/
|
||||||
|
|
||||||
import { app } from "@tauri-apps/api";
|
import { app } from "@tauri-apps/api";
|
||||||
import Database from "@tauri-apps/plugin-sql";
|
import Database from "@tauri-apps/plugin-sql";
|
||||||
|
|
||||||
|
import TGLogger from "../../utils/TGLogger.js";
|
||||||
|
|
||||||
import initDataSql from "./sql/initData.js";
|
import initDataSql from "./sql/initData.js";
|
||||||
import { insertAppData } from "./sql/insertData.js";
|
import { insertAppData } from "./sql/insertData.js";
|
||||||
|
|
||||||
@@ -55,6 +57,27 @@ class Sqlite {
|
|||||||
return this.db;
|
return this.db;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @description 检测是否需要创建数据库
|
||||||
|
* @since Beta v0.6.1
|
||||||
|
* @returns {Promise<boolean>}
|
||||||
|
*/
|
||||||
|
public async check(): Promise<boolean> {
|
||||||
|
try {
|
||||||
|
const db = await this.getDB();
|
||||||
|
let isVerified = false;
|
||||||
|
const sqlT = "SELECT name FROM sqlite_master WHERE type='table' ORDER BY name;";
|
||||||
|
const res: Array<{ name: string }> = await db.select(sqlT);
|
||||||
|
if (this.tables.every((item) => res.map((i) => i.name).includes(item))) {
|
||||||
|
isVerified = true;
|
||||||
|
}
|
||||||
|
return isVerified;
|
||||||
|
} catch (e) {
|
||||||
|
await TGLogger.Error(JSON.stringify(e));
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @description 初始化数据库
|
* @description 初始化数据库
|
||||||
* @since Beta v0.4.5
|
* @since Beta v0.4.5
|
||||||
|
|||||||
Reference in New Issue
Block a user