【问题标题】:SQLite Database problem in Xamarin Forms (sqlite-net-pcl) - "DatabasePath must be specified"Xamarin Forms (sqlite-net-pcl) 中的 SQLite 数据库问题 - “必须指定数据库路径”
【发布时间】:2021-08-13 04:59:00
【问题描述】:

我正在编写一个简单的 Xamarin Forms 移动应用程序(Android 和 iOS,但目前专注于 Android)作为一个学校项目。我正在使用 Visual Studio 2019 社区,并且我已经安装了 NuGet 包 sqlite-net-pcl v1.7.335

当应用程序在尝试访问数据库时突然开始抛出错误时,一切都在进行,说“必须指定数据库路径”。

担心我的代码可能出错,我创建了一个空白应用程序并仅尝试了一个简单的数据库连接。发生同样的错误。请在下面查看我的代码。

MainActivity.cs

public class MainActivity : global::Xamarin.Forms.Platform.Android.FormsAppCompatActivity
{
    protected override void OnCreate(Bundle savedInstanceState)
    {
        base.OnCreate(savedInstanceState);

        Xamarin.Essentials.Platform.Init(this, savedInstanceState);
        global::Xamarin.Forms.Forms.Init(this, savedInstanceState);

        string fileName = "datahold.db";
        string folderPath = System.Environment.GetFolderPath(System.Environment.SpecialFolder.Personal);
        string completePath = Path.Combine(folderPath, fileName);

        LoadApplication(new App(completePath));
    }
    public override void OnRequestPermissionsResult(int requestCode, string[] permissions, [GeneratedEnum] Android.Content.PM.Permission[] grantResults)
    {
        Xamarin.Essentials.Platform.OnRequestPermissionsResult(requestCode, permissions, grantResults);

        base.OnRequestPermissionsResult(requestCode, permissions, grantResults);
    }
}

App.xaml.cs

public App(string filePath)
    {
        InitializeComponent();

        MainPage = new MainPage();
        dbPath = filePath;
    }

MainPage.xaml.cs

 public partial class MainPage : ContentPage
{
    public MainPage()
    {
        
        InitializeComponent();
        using (SQLiteConnection myCon = new SQLiteConnection(App.dbPath))
        {
            myCon.CreateTable<term>();
        }
    }
}

在尝试运行程序时,它会突出显示上面的 using 行并给出:

System.InvalidOperationException Message=DatabasePath 必须指定

我只能通过将数据库的定义移动到 MainPage 本身来纠正这个问题。从那里我的程序的其余部分似乎能够通过引用 MainPage.dbPath 来访问该数据库文件;但是,App.xaml 和 MainPage.xaml 之间缺乏通信是非常令人担忧的,并且可能会产生进一步的后果,我经验不足,无法预测。这是我可以用某种补丁解决的问题吗?我应该把 sqlite-net-pcl 换成别的东西吗?

【问题讨论】:

    标签: c# sqlite xamarin.forms sqlite-net-pcl


    【解决方案1】:

    你正在创建MainPage你分配dbPath,所以当MainPage构造函数执行dbPathnull

    MainPage = new MainPage();
    dbPath = filePath;
    

    分配dbPath first

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 2017-06-24
      • 2018-07-06
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      相关资源
      最近更新 更多