繁体   English   中英

SQLite Xamarin.Forms不实例化数据库

[英]SQLite Xamarin.Forms not instantiating Database

我正在按照此指南将SQLite添加到我的Xamarin.Forms共享资产项目中。 这不是PCL。 我将XAML与代码隐藏一起使用。

我似乎在所有正确的地方都包含了所有代码。 我有一个SQLite.cs,其中包含我要进行的所有数据库调用,还定义了数据库。

我在一个我知道可以使用的类中定义了一个Interface,并且可以使用它中的其他函数来访问它。

然后,我在每个平台项目中都有一个类(在droid示例下面已显示),该类使用该接口获取本地文件路径。

最后,在共享资产项目中,我定义并(应该)实例化(我认为)数据库。

因此,在所有这些就绪的情况下,我尝试在一个ViewModel中执行数据库调用。 但是,内部异常表明我遇到了对象引用错误。 基本上,当我尝试执行database.MyMethod()时,我的“数据库”对象为null。

我不知道为什么它没有实例化。 有任何想法吗?

它执行的行是

var dbtimings = TechsportiseData.GetTimingsAsync().Result.ToList();

那方法是...

public static Task<List<Timing>> GetTimingsAsync()
{
    return database.Table<Timing>().ToListAsync();
}

由于database为空,因此跳闸。

SQLite.cs(共享资产项目)

using System;
using System.Collections.Generic;
using System.Text;
using Xamarin.Forms;
using static TechsportiseApp.Helpers.GlobalFunctions;
using TechsportiseApp.Models;
using System.Threading.Tasks;
using SQLite;

namespace TechsportiseApp.Data
{
    public class TechsportiseData
    {
        readonly SQLiteAsyncConnection database;

        public TechsportiseData(string dbPath)
        {
            database = new SQLiteAsyncConnection(dbPath);
            database.CreateTableAsync<Scan>().Wait();
            database.CreateTableAsync<Timing>().Wait();
        }


        public static Task<List<Timing>> GetTimingsAsync()
        {
            return database.Table<Timing>().ToListAsync();
        }

        public static Task<List<Timing>> GetTimingsNotUploadedAsync()
        {
            return database.QueryAsync<Timing>("SELECT * FROM [Timing] WHERE [Uploaded] = 0");
        }

        public static Task<Timing> GetTimingAsync(int id)
        {
            return database.Table<Timing>().Where(i => i.Id == id).FirstOrDefaultAsync();
        }

        public static Task<int> SaveTimingAsync(Timing timing)
        {
            if (timing.Id != 0)
            {
                return database.UpdateAsync(timing);
            }
            else
            {
                return database.InsertAsync(timing);
            }
        }

        public static Task<int> DeleteTimingAsync(Timing timing)
        {
            return database.DeleteAsync(timing);
        }

        public static Task DeleteAllTimingsAsync()
        {
            database.DropTableAsync<Timing>().Wait();          
            return database.CreateTableAsync<Timing>();
        }

        public static Task<List<Scan>> GetScansAsync()
        {
            return database.Table<Scan>().ToListAsync();
        }

        public static Task<List<Scan>> GetScansNotUploadedAsync()
        {
            return database.QueryAsync<Scan>("SELECT * FROM [Scan] WHERE [Uploaded] = 0");
        }

        public static Task<Scan> GetScanAsync(int id)
        {
            return database.Table<Scan>().Where(i => i.Id == id).FirstOrDefaultAsync();
        }

        public static Task<int> SaveScanAsync(Scan scan)
        {
            if (scan.Id != 0)
            {
                return database.UpdateAsync(scan);
            }
            else
            {
                return database.InsertAsync(scan);
            }
        }

        public static Task<int> DeleteScanAsync(Scan scan)
        {
            return database.DeleteAsync(scan);
        }

        public static Task DeleteAllScansAsync()
        {
            database.DropTableAsync<Scan>().Wait();
            return database.CreateTableAsync<Scan>();
        }



        public static Task<RaceClock> GetRaceClockAsync()
        {
            return database.Table<RaceClock>().FirstOrDefaultAsync();
        }

        public static Task<int> SaveRaceClockAsync(RaceClock clock)
        {
            return database.InsertAsync(clock);
        }

        public static Task DeleteRaceClockAsync()
        {
            database.DropTableAsync<RaceClock>().Wait();
            return database.CreateTableAsync<RaceClock>();
        }
    }
}

App.xaml.cs

using Xamarin.Forms;
using Xamarin.Forms.Xaml;
using System.Collections.Generic;
using TechsportiseApp.API;
using TechsportiseApp.Views;
using TechsportiseApp.ViewModels;
using TechsportiseApp.Models;
using TechsportiseApp.Helpers;
using TechsportiseApp.Data;
using static TechsportiseApp.Helpers.GlobalFunctions;

//[assembly: XamlCompilation(XamlCompilationOptions.Compile)]
namespace TechsportiseApp
{
    public partial class App : Application
    {
        static TechsportiseData database;



        public App()
        {

            InitializeComponent();


            Application.Current.Properties["APIServer"] = "https://www.techsportise.com/";
            //Application.Current.Properties["APIServer"] = "http://localhost:52693/";

            if (Application.Current.Properties.ContainsKey("ShowHelpOnStartup") == false)
            {
                Application.Current.Properties["ShowHelpOnStartup"] = true;
            }
            if (Application.Current.Properties.ContainsKey("ShowCompletedRaces") == false)
            {
                Application.Current.Properties["ShowCompletedRaces"] = false;
            }
            //MainPage = new NavigationPage(new ResultsProcess());

            //MainPage = new NavigationPage(new Scanning());
            //If the token is present and they are remembered
            if ((Application.Current.Properties.ContainsKey("Token")) && (Application.Current.Properties.ContainsKey("IsRemembered")))
            {
                //And is blank/null
                if (((string)Application.Current.Properties["Token"] == "") || ((GlobalFunctions.PropertyToBool(Application.Current.Properties["IsRemembered"].ToString()) != true)))
                {
                    //They need to login
                    MainPage = new NavigationPage(new Login());
                }
                //Otherwise they can go straight to their page
                else
                {
                    if (GlobalFunctions.PropertyToBool(Application.Current.Properties["ShowHelpOnStartup"].ToString()) == true)
                    {
                        MainPage = new StartupHelp(true);
                    }
                    else
                    {
                        MainPage = new MainMenuMasterDetail();
                    }

                }
            }
            else
            {
                MainPage = new NavigationPage(new Login());
            }
        }

        public static TechsportiseData Database
        {
            get
            {
                if (database == null)
                {
                    database = new TechsportiseData(DependencyService.Get<IFileHelper>().GetLocalFilePath("Techsportise.db3"));
                }
                return database;
            }
        }


        protected override void OnStart()
        {
            // Handle when your app starts
        }

        protected override void OnSleep()
        {
            // Handle when your app sleeps
        }

        protected override void OnResume()
        {
            // Handle when your app resumes
        }
    }
}

界面(共享资产项目)

using System;
using System.IdentityModel.Tokens.Jwt;
using System.Linq;
using System.Net;
using Xamarin.Forms;

namespace TechsportiseApp.Helpers
{
    public class GlobalFunctions
    {
        public GlobalFunctions()
        {
        }

        public interface IFileHelper
        {
            string GetLocalFilePath(string filename);
        }

        public static bool CheckForInternetConnection()
        {
            try
            {
                HttpWebRequest request = (HttpWebRequest)WebRequest.Create("http://www.google.com");
                request.Timeout = 5000;
                request.Credentials = CredentialCache.DefaultNetworkCredentials;
                HttpWebResponse response = (HttpWebResponse)request.GetResponse();

                if (response.StatusCode == HttpStatusCode.OK)
                    return true;
                else
                    //return false;
                    return true;
            }
            catch
            {
                //return false;
                return true;
            }

        }

        public static bool HasPremium()
        {
            var handler = new JwtSecurityTokenHandler();
            var token = handler.ReadToken(Application.Current.Properties["Token"].ToString()) as JwtSecurityToken;
            var premium = token.Claims.FirstOrDefault(claim => claim.Type == "premium").Value.ToString();
            var premiumbool = PropertyToBool(premium);

            return premiumbool;

        }
    }
}

平台类(在此示例中为Droid)

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;

using Android.App;
using Android.Content;
using Android.OS;
using Android.Runtime;
using Android.Views;
using Android.Widget;
using Xamarin.Forms;
using TechsportiseApp.Droid;
using static TechsportiseApp.Helpers.GlobalFunctions;
using System.IO;

[assembly: Dependency(typeof(FileHelper))]
namespace TechsportiseApp.Droid
{
    public class FileHelper : IFileHelper
    {
        public string GetLocalFilePath(string filename)
        {
            string path = System.Environment.GetFolderPath(System.Environment.SpecialFolder.Personal);
            return Path.Combine(path, filename);
        }
    }
}

您的数据库类不一致。 初始化是在实例构造函数中完成的,而数据库调用是静态的,这将导致您调用静态函数,即使实例尚未初始化。

将函数更改为实例函数(从函数中删除static限定符)或在静态构造函数上初始化数据库类。

暂无
暂无

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

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