mirror of
https://github.com/2dust/v2rayN.git
synced 2025-07-01 04:22:10 +00:00
123 lines
No EOL
3 KiB
C#
123 lines
No EOL
3 KiB
C#
using SQLite;
|
|
using System.Collections;
|
|
|
|
namespace ServiceLib.Common
|
|
{
|
|
public sealed class SQLiteHelper
|
|
{
|
|
private static readonly Lazy<SQLiteHelper> _instance = new(() => new());
|
|
public static SQLiteHelper Instance => _instance.Value;
|
|
private string _connstr;
|
|
private SQLiteConnection _db;
|
|
private SQLiteAsyncConnection _dbAsync;
|
|
private static readonly object objLock = new();
|
|
public readonly string _configDB = "guiNDB.db";
|
|
|
|
public SQLiteHelper()
|
|
{
|
|
_connstr = Utils.GetConfigPath(_configDB);
|
|
_db = new SQLiteConnection(_connstr, false);
|
|
_dbAsync = new SQLiteAsyncConnection(_connstr, false);
|
|
}
|
|
|
|
public CreateTableResult CreateTable<T>()
|
|
{
|
|
return _db.CreateTable<T>();
|
|
}
|
|
|
|
public int Insert(object model)
|
|
{
|
|
return _db.Insert(model);
|
|
}
|
|
|
|
public int InsertAll(IEnumerable models)
|
|
{
|
|
lock (objLock)
|
|
{
|
|
return _db.InsertAll(models);
|
|
}
|
|
}
|
|
|
|
public async Task<int> InsertAsync(object model)
|
|
{
|
|
return await _dbAsync.InsertAsync(model);
|
|
}
|
|
|
|
public int Replace(object model)
|
|
{
|
|
lock (objLock)
|
|
{
|
|
return _db.InsertOrReplace(model);
|
|
}
|
|
}
|
|
|
|
public async Task<int> ReplaceAsync(object model)
|
|
{
|
|
return await _dbAsync.InsertOrReplaceAsync(model);
|
|
}
|
|
|
|
public int Update(object model)
|
|
{
|
|
lock (objLock)
|
|
{
|
|
return _db.Update(model);
|
|
}
|
|
}
|
|
|
|
public async Task<int> UpdateAsync(object model)
|
|
{
|
|
return await _dbAsync.UpdateAsync(model);
|
|
}
|
|
|
|
public int UpdateAll(IEnumerable models)
|
|
{
|
|
lock (objLock)
|
|
{
|
|
return _db.UpdateAll(models);
|
|
}
|
|
}
|
|
|
|
public int Delete(object model)
|
|
{
|
|
lock (objLock)
|
|
{
|
|
return _db.Delete(model);
|
|
}
|
|
}
|
|
|
|
public async Task<int> DeleteAsync(object model)
|
|
{
|
|
return await _dbAsync.DeleteAsync(model);
|
|
}
|
|
|
|
public List<T> Query<T>(string sql) where T : new()
|
|
{
|
|
return _db.Query<T>(sql);
|
|
}
|
|
|
|
public async Task<List<T>> QueryAsync<T>(string sql) where T : new()
|
|
{
|
|
return await _dbAsync.QueryAsync<T>(sql);
|
|
}
|
|
|
|
public int Execute(string sql)
|
|
{
|
|
return _db.Execute(sql);
|
|
}
|
|
|
|
public async Task<int> ExecuteAsync(string sql)
|
|
{
|
|
return await _dbAsync.ExecuteAsync(sql);
|
|
}
|
|
|
|
public TableQuery<T> Table<T>() where T : new()
|
|
{
|
|
return _db.Table<T>();
|
|
}
|
|
|
|
public AsyncTableQuery<T> TableAsync<T>() where T : new()
|
|
{
|
|
return _dbAsync.Table<T>();
|
|
}
|
|
}
|
|
} |