首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >使用SQLite的MissingMethodException

使用SQLite的MissingMethodException
EN

Stack Overflow用户
提问于 2019-09-04 17:51:13
回答 1查看 1.3K关注 0票数 1

我试图让SQLite在本地存储一些信息,到目前为止,我遇到了一个恼人的问题:每当我调用sqlite函数CreateTable时,它都会返回一个异常。

下面是一个例外:

代码语言:javascript
复制
Unhandled Exception:
System.MissingMethodException: Method not found: string SQLitePCL.raw.sqlite3_column_name(SQLitePCL.sqlite3_stmt,int).

下面是我用来使其跨平台的接口:

代码语言:javascript
复制
public interface IDataBase
{
    SQLiteConnection GetConnection();
}

Android实现:

代码语言:javascript
复制
[assembly: Dependency(typeof(DataBase))]
namespace MyNameSpace.Droid
{
    public class DataBase : IDataBase
    {
        public DataBase() { }
        public SQLiteConnection GetConnection()
        {
            var fileName = "DataBase.db3";
            string docsPath = System.Environment.GetFolderPath(System.Environment.SpecialFolder.Personal);
            string path = Path.Combine(docsPath, fileName);
            var conn = new SQLiteConnection(path);
            return conn;
        }
    }
}

还有一个iOs版本:

代码语言:javascript
复制
[assembly: Dependency(typeof(DataBase))]
namespace MyNameSpace.iOS
{
    public class DataBase : IDataBase
    {
        public DataBase() { }
        public SQLiteConnection GetConnection()
        {
            var fileName = "DataBase.db3";
            var docPath = Environment.GetFolderPath(Environment.SpecialFolder.Personal);
            var libraryPath = Path.Combine(docPath, "..", "Library");
            var path = Path.Combine(libraryPath, fileName);
            var conn = new SQLiteConnection(path);
            return conn;
        }
    }
}

然后我有我的表类型:

代码语言:javascript
复制
namespace MyNameSpace.DataBase
{
     public class MacroCategoria
     {
        [PrimaryKey]
        public int ID { get; set; }
        public string descrizione { get; set; }

        public MacroCategoria() { }

    }
}

获取第一个元素的DataBase控制器和I方法:

代码语言:javascript
复制
namespace MyNameSpace.DataBase
{
    public class DBController
    {
        static object locker = new object();
        SQLiteConnection database;

        public DBController()
        {
            database = DependencyService.Get<IDataBase>().GetConnection();
            if (database != null)
            {
                database.CreateTable<MacroCategoria>();
                database.Insert(new MacroCategoria() { ID = 0, descrizione = "Description" });
            }
        }

        public MacroCategoria getFirstMacro()
        {
            lock (locker)
            {
                if (database.Table<MacroCategoria>().Count() == 0)
                    return null;
                else
                    return database.Table<MacroCategoria>().First();
            }

        }

    }
}

在App类中调用:

代码语言:javascript
复制
public partial class App : Application
{
    static DBController dbController;
    public App()
    {
        InitializeComponent();
        DependencyService.Register<MockDataStore>();
        MainPage = new MainPage();
    }

    [...Other Default Methods...]

    public static DBController DBController
    {
        get
        {
            if(dbController == null)
            {
                dbController = new DBController();
            }
            return dbController;
        }
    }
}

最后,在我的mainPage中,我有一个函数,它应该获取第一个元素:

代码语言:javascript
复制
private void CartIcon_Clicked(object sender, EventArgs e)
{
    try
    {
        App.DBController.getFirstMacro();

    } catch(Exception ex) { throw; }
}
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2019-09-04 20:14:22

看起来我只需要添加SQLitePCL.Raw包。

票数 3
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/57785849

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档