MongoDB:利用官方驱动改装为EF代码风格的MongoDB.Repository框架 六:支持多数据库操做

本次主要内容:修正MongoDB.Repository框架对多数据库的支持。

在以前的五篇文章中对MongoDB.Repository框架作了简单的介绍是实现思路。以前是考虑MongoDB.Repository框架是能够同时支持多数据,且已实现支持多数据库。但有个前提:实体的类型不能重复,即一个实体类型(即命名空间同样)只能存在一个数据库中。举例,X实体,若是注册在了A数据库,那么将不能注册在B数据库中。git

虽然实现了该功能,可是存在一些问题和不足:github

问题:只有在使用具体的实例进行数据库操做时才会提示异常,且异常信息不清楚。数据库

不足:文件操做还未能支持多数据库,由于以前的版本对IMongoFile没有在IMongoDBContext上下文进行注册,全部的文件都会保存到一个数据库中。安全

固然以上的问题,若是不须要支持多数据库,那么也就不存在这些问题。而在实际的设计中,却很难避免。好比咱们若是要作一个简单的平台,出于安全、独立等因素,用户信息和应用信息应该是分开的数据库部署。框架

本次修正内容:ide

A:将实体注册放置在上下文注册以前,即在注册上下文以前,首先要检查该上下文中注册的实体是否已经被其它上下文注册过。spa

B:IMongoFile的实体也须要在上下文中进行注册,不能对未注册的文件类型进行操做。并将MongoFile设置为abstract class,以保证注册流程。设计

下面给出一个具体的注册案例:xml

    public class Company : Entity
    {    }

    public class Factory : Entity
    {  }

    public class CompanyDBContext : MongoDBContext
    {
        public CompanyDBContext() : base("CompanyDBContext") { }
        public override void OnRegisterModel(ITypeRegistration registration)
        {
            registration.RegisterType<Company>().RegisterType<Factory>();    //一次注册
        }
    }

    public class FactoryDBContext : MongoDBContext
    {
        public FactoryDBContext() : base("FactoryDBContext") { }
        public override void OnRegisterModel(ITypeRegistration registration)
        {
            registration.RegisterType<Factory>();    //二次注册
        }
    }

    //注册上下文
    MongoDBRepository.RegisterMongoDBContext(new CompanyDBContext());
    MongoDBRepository.RegisterMongoDBContext(new FactoryDBContext());    //因Factory进行了屡次注册,在此会抛出类型屡次注册异常

 若是须要使用文件,那么文件实体也同样须要注册,这在以前的版本并不是强制,也存在必定的问题:blog

    public class MyFile : MongoFile
    {
        public MyFile()
            : base(@"c:\testxml.xml", "test.xml", "xml")
        { }
    }

    public class TestDBContext : MongoDBContext
    {
        public TestDBContext() : base("TestDBContext") { }

        public override void OnRegisterModel(ITypeRegistration registration)
        {
            registration.RegisterType<MyFile>();    //注册文件实体
        }
    }

 文件实体注册后,便可以使用,使用方式与其余实体无异:

            //加载本地文件,并实例一个IMongoFile
            IMongoFile file = MongoEntity.CreateFile<MyFile>(@"c:\pic1.jpg", "pic2.jpg", "jpg");

            //下载文件,等同于文件另存为 
            file.Download(@"c:\beforesave.jpg");

            //文件保存至数据库 
            file.Save();

            //从数据中加载刚才保存的文件
            IMongoFile fs = MongoEntity.LoadFile<MyFile>(file.Id);

            //将从数据中加载的文件下载
            fs.Download(@"c:\aftersave.jpg");

            //根据数据库中的文件名检索文件
            var files = MongoEntity.LoadAllFiles<MyFile>("pic2.jpg");

            //根据文件id,将数据库中的文件下载到本地
            MongoEntity.DownloadFile<MyFile>(file.Id, @"c:\copy.jpg");

 以上列出了一些文件的简单操做,并非所有,每一个方法也有不一样程度的重载,并在之后根据实际使用状况会逐步的增长。

 

欢迎你们下载DLL使用,并在使用过程当中提出问题,共同改善,源码地址,分享快乐!

相关文章
相关标签/搜索