невозможно открыть базу данных (sqlite с nhibernate) в проекте библиотеки .netstandard - PullRequest
0 голосов
/ 11 февраля 2019

Я пытаюсь открыть базу данных sqlite из проекта библиотеки .netstandard, который используется проектом форм xamarin (uwp и android). Я только попробовал проект uwp и получил невозможность открыть исключение базы данных

Я попытался использовать путь к личной папке и попытался открыть соединение через Sqliteconnection.Полный проект доступен здесь: https://github.com/blndr83/OutlookCalender

internal class DatabaseProvider
{
    private static ISessionFactory _sessionFactory;
    private static Configuration _configuration;
    private static HbmMapping _mapping;

    public static ISession OpenSession()
    {
        //Open and return the nhibernate session
        return SessionFactory.OpenSession();
    }

    public static ISessionFactory SessionFactory
    {
        get
        {
            if (_sessionFactory == null)
            {
                //Create the session factory
                _sessionFactory = Configuration.BuildSessionFactory();
            }
            return _sessionFactory;
        }
    }

    public static Configuration Configuration
    {
        get
        {
            if (_configuration == null)
            {
                //Create the nhibernate configuration
                _configuration = CreateConfiguration();
            }
            return _configuration;
        }
    }

    public static HbmMapping Mapping
    {
        get
        {
            if (_mapping == null)
            {
                //Create the mapping
                _mapping = CreateMapping();
            }
            return _mapping;
        }
    }

    private static Configuration CreateConfiguration()
    {
        var configuration = new Configuration();
        //Loads properties from hibernate.cfg.xml
        configuration.Configure();
        IDictionary<string, string> props = new Dictionary<string, string>
        {
            { "connection.connection_string", @"Data Source=Calendar.db;FailIfMissing=false;New=false;Compress=true;Version=3"},
            { "connection.driver_class", "NHibernate.Driver.SQLite20Driver" },
            { "dialect", "NHibernate.Dialect.SQLiteDialect" },
            { "connection.provider", "NHibernate.Connection.DriverConnectionProvider" },
            { "show_sql", "false" }
        };
        configuration.SetProperties(props);
        configuration.AddDeserializedMapping(Mapping, null);


        return configuration;
    }

    private static HbmMapping CreateMapping()
    {
        var mapper = new ModelMapper();
        //Add the person mapping to the model mapper
        mapper.AddMappings(new List<System.Type> { typeof(EventModelMap) });
        //Create and return a HbmMapping of the model mapping in code
        return mapper.CompileMappingForAllExplicitlyAddedEntities();
    }
}

public class Repository : IRepository
{
    private readonly ISession _session;

    public Repository()
    {
        _session = DatabaseProvider.OpenSession();
        var schemaUpdate = new SchemaUpdate(DatabaseProvider.Configuration);
        schemaUpdate.Execute(Console.WriteLine, true);
    }

    public void Delete<T>(T entity) where T : Entity
    {
        using (var transaction = _session.BeginTransaction())
        {
            _session.Delete(entity);
            transaction.Commit();
        }
    }

    public T Find<T>(Expression<Func<T,bool>> expression) where T : Entity
    {
            return _session.QueryOver<T>().Where(expression).SingleOrDefault();
    }

    public async Task<IList<T>> FindAll<T>(Expression<Func<T, bool>> expression) where T : Entity
    {
        return await _session.QueryOver<T>().Where(expression).ListAsync();
    }

    public void Save<T>(T entity) where T : Entity
    {
        using (var transaction = _session.BeginTransaction())
        {
            _session.Save(entity);
            transaction.Commit();
        }
    }

    public void Update<T>(T entity) where T : Entity
    {
        using (var transaction = _session.BeginTransaction())
        {
            _session.Update(entity);
            transaction.Commit();
        }

    }
}

Решена проблема с использованием Entity Framework Core

1 Ответ

0 голосов
/ 12 февраля 2019

Вы можете попробовать .NET Standard реализацию оболочки SQLite, есть два различия:

  1. Обеспечить .NET Standard библиотеку, которая работает на трех основных платформах: UWP, Android,и iOS без библиотек, специфичных для платформы.

  2. Обеспечение доступа к плоским таблицам с запросами SQL.Т.е. не принуждают использовать функциональность, подобную ORM, подобную языку.

https://github.com/MelbourneDeveloper/SQLite.Net.Standard

...