简体   繁体   English

当表存在于 xamarin 中时,SQLite 没有此类表错误

[英]SQLite no such table error when table exists in xamarin

This is How I define my table as what this link: SQLite no such table error when table exists said这就是我如何将我的表定义为这个链接: SQLite no such table error when table exists said

[Table("RegUserTable")]
[Serializable]
[DataContract]
public class RegUserTable
{
    [PrimaryKey]
    [DataMember]
    public Guid UserId { get; set; }

    [DataMember]
    public string Username { get; set; }

    [DataMember]
    public string Password { get; set; }

    [DataMember]
    public string Email { get; set; }

    [DataMember]
    public string Gender { get; set; }
}

This is my Login code:这是我的登录代码:

public void Button_Clicked_1(object sender, EventArgs e)//LOGIN!
{
    var dbpath = Path.Combine(Environment.GetFolderPath(Environment.SpecialFolder.MyDocuments), "Userdatabase.db");
    var db = new SQLiteConnection(dbpath);
    var loginquery = db.Table<RegUserTable>().Where(u => u.Username.Equals(EntryLoginUsername.Text) && u.Password.Equals(EntryLoginPassword.Text)).FirstOrDefault();

    if (string.IsNullOrWhiteSpace(EntryLoginUsername.Text) && string.IsNullOrWhiteSpace(EntryLoginPassword.Text))
    {
        DisplayAlert("Blank Fields", "Please Input Your Username and Password!", "OK");
    }
    else if (loginquery != null)
    {
        App.Current.MainPage = new NavigationPage(new MainPage(EntryLoginUsername.Text, GenderIdentifier.Text));
    }
}

If I run this in my emulator it works 100%, but when I run it on my device it throws this error:如果我在模拟器中运行它,它可以 100% 运行,但是当我在我的设备上运行它时,它会引发此错误: 在此处输入图片说明

What am I doing wrong here?我在这里做错了什么?

Creating the table something like below solves the issue创建类似于下面的表格解决了这个问题

public async void Button_Clicked_1(object sender, EventArgs e)//LOGIN!
{
    var dbpath = Path.Combine(Environment.GetFolderPath(Environment.SpecialFolder.MyDocuments), "Userdatabase.db");
    var db = new SQLiteConnection(dbpath);

    var connection = new SQLiteAsyncConnection(dbpath); 
    await connection.CreateTableAsync<RegUserTable>();

    var loginquery = db.Table<RegUserTable>().Where(u => u.Username.Equals(EntryLoginUsername.Text) && u.Password.Equals(EntryLoginPassword.Text)).FirstOrDefault();

    if (string.IsNullOrWhiteSpace(EntryLoginUsername.Text) && string.IsNullOrWhiteSpace(EntryLoginPassword.Text))
    {
        DisplayAlert("Blank Fields", "Please Input Your Username and Password!", "OK");
    }
    else if (loginquery != null)
    {
        App.Current.MainPage = new NavigationPage(new MainPage(EntryLoginUsername.Text, GenderIdentifier.Text));
    }
}

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM