Я много искал, и я не могу найти ответы на это.
Я пишу приложение Xamarin Forms Mobile, похоже, когда я сворачиваю приложение, а затем снова открываю его или запускаю одно из моих действий, возникает следующее исключение:
SQLiteConnection.CreateCommand (System.String cmdText, System.Object[] ps)
SQLite.SQLiteException: Cannot create commands from unopened database
SQLiteConnection.CreateCommand (System.String cmdText, System.Object[] ps)
TableQuery'1[T].GenerateCommand (System.String selectionList)
TableQuery'1[T].GetEnumerator ()
System.Collections.Generic.List'1[T]..ctor (System.Collections.Generic.IEnumerable'1[T] collection) [0x00062] in :0
Enumerable.ToList[TSource] (System.Collections.Generic.IEnumerable'1[T] source)
AsyncTableQuery'1[T].<ToListAsync>b__9_0 ()
Task'1[TResult].InnerInvoke ()
Task.Execute ()
Вот мой код:
Общий репозиторий (где создается экземпляр Sqlite)
public class Repository<T> : IRepository<T> where T : Entity, new()
{
private readonly SQLiteAsyncConnection _db;
public Repository(string dbPath)
{
_db = new SQLiteAsyncConnection(dbPath);
_db.CreateTableAsync<T>().Wait();
}
}
Регистрация МОК
FreshIOC.Container.Register<IRepository<Settings>>(new Repository<Settings>(dbPath)); // FreshIOC is a wrapper around TinyIOC
В моем App.xaml.cs OnResume
protected override void OnResume()
{
SQLiteAsyncConnection.ResetPool();
}
Вышеупомянутый с ResetPool
я поставил это, чтобы посмотреть, не изменит ли это, но это не так.
Активность URL
protected override void OnCreate(Bundle bundle)
{
base.OnCreate(bundle);
var url = Intent.Data.ToString();
var split = url.Split(new[] { "ombi://", "_" }, StringSplitOptions.RemoveEmptyEntries);
if (split.Length > 1)
{
var dbLocation = new FileHelper().GetLocalFilePath("ombi.db3");
var repo = new Repository<OmbiMobile.Models.Entities.Settings>(dbLocation);
var settings = repo.Get().Result;
foreach (var s in settings)
{
var i = repo.Delete(s).Result;
}
repo.Save(new Settings
{
AccessToken = split[1],
OmbiUrl = split[0]
});
}
Intent startup = new Intent(this, typeof(MainActivity));
StartActivity(startup);
Finish();
}
Я не уверен, что еще нужно делать или искать, я не могу найти никакой информации об этой ошибке.
Обновить:
После большей отладки, похоже, это происходит только после завершения работы Url. Я удалил код DB из Activity, и все еще кажется, что это происходит. После запуска Activity основное App()
запускает этот код:
var repo = FreshIOC.Container.Resolve<IRepository<Settings>>();
try
{
Task.Run(async () =>
{
settings = (await repo.Get()).FirstOrDefault();
}).Wait();
}
catch (Exception e)
{
Debug.WriteLine(e.Message);
throw;
}
Это где ошибка происходит. Это происходит, когда вызывается Get()
который вызывает return _db.Table<T>().ToListAsync();
Я попытался сделать все async (не помогло), создание репозитория, соединение и где мы делаем CreateTableAsync
async и до сих пор не повезло.