sqlite-net-extensions - InsertWithChildrenAsync
Я пытаюсь создать таблицу с помощью "sqlite-net-extensions". Но проблема всегда возвращается с ошибкой.
Возвращаемая ошибка: "Только чтение".
Я создал две модели для создания таблиц.
Модель -> Войти
[PrimaryKey, AutoIncrement, Column("login_id")]
[Indexed(Name = "LoginId", Order = 2, Unique = true)]
public int Id { get; set; }
[NotNull, Column("login_user")]
[Indexed(Name = "LoginId", Order = 1, Unique = true)]
public string UserName { get; set; }
[NotNull, Column("login_password")] public string Password { get; set; }
[OneToOne("login_id", "Login")]
public User User { get; set; }
Модель -> Пользователь
[PrimaryKey, AutoIncrement, Column("user_id")]
public int Id { get; set; }
[NotNull, Column("user_name")]
[Indexed(Name = "UserId", Order = 3, Unique = true)]
public string Name { get; set; }
[NotNull, Column("user_email")]
[Indexed(Name = "UserId", Order = 2, Unique = true)]
public string Email { get; set; }
[ForeignKey(typeof(Login)), NotNull, Column("login_id")]
[Indexed(Name = "UserId", Order = 1, Unique = true)]
public int LoginId { get; set; }
[OneToOne("login_id", "User", CascadeOperations = CascadeOperation.All, ReadOnly = false)]
public Login Login { get; set; }
Вставить метод
public async Task InsertWithChildren(object o)
{
var connection = _sqliteWrapper.OpenDatabase();
await connection.InsertWithChildrenAsync(o, recursive: true);
}
1 ответ
Следуйте следующим шагам
1.- Создайте соединение SQLite.
2.- Создайте свои таблицы
3.- Вставить в базу данных
var connection = new SQLiteAsyncConnection(YourDBPath);
connection.CreateTableAsync<Login>().Wait();
connection.CreateTableAsync<User>().Wait();
connection.InsertWithChildrenAsync(YourItem);