导言

大家好,话说真是好久好久没写文章了,哈哈。

最近在写网站,个人对传统数据库天然抵触,感觉非常繁冗,即便是Entity Framework也过于庞杂了,Db4o这种轻量级且读写、配置都极其方便的新型数据库非常适合我。

不过我发现Db4o这么多年发展下来,竟然仍旧没多少中文资料可寻,很奇怪为什么这么优秀的数据库国内使用率极低呢?于是我就想尝试自己来写一些心得什么的,为Db4o在国内的传播尽微薄之力吧。

此次分享的是自己写的工具类代码,封装了Db4o的一种基本使用方式,高度优化了调用体验,下面直接介绍用法,源代码在文章末尾贴出。

初始化

如果是桌面应用的话,那就在程序开始时直接初始化即可:

        /// <summary>
/// Db4o服务器管理器
/// </summary>
public static Db4oServerManager Db4oServerManager=new Db4oServerManager("db.db4o");

如果是网站,建议在Global.asax里作为网站核心类的静态属性,并在网站启动时初始化:

    public class MvcApplication : System.Web.HttpApplication
{
/// <summary>
/// Db4o服务器管理器
/// </summary>
public static Db4oServerManager Db4oServerManager; protected void Application_Start()
{
AreaRegistration.RegisterAllAreas();
FilterConfig.RegisterGlobalFilters(GlobalFilters.Filters);
RouteConfig.RegisterRoutes(RouteTable.Routes);
BundleConfig.RegisterBundles(BundleTable.Bundles); Db4oServerManager = new Db4oServerManager(Server.MapPath(System.Configuration.ConfigurationManager.ConnectionStrings["db4o"].ConnectionString));
} public override void Dispose()
{
Db4oServerManager.Dispose();
base.Dispose();
}
}

然后记得在Web.config里配置数据库存放路径:

    <connectionStrings>
<add name="db4o" connectionString="/App_Data/db.db4o"/>
</connectionStrings>

调用方法

注:下文以网站项目为例

建议采用Lambda表达式方法调用:

                    //无返回值调用方法
MvcApplication.Db4oServerManager.Access(q =>
{
//查找相同ID的对象,以进行更新,否则直接存储将存储为新对象
var u = q.Query<ApplicationUser>(t => t.Id == user.Id).First();
u.用户信息.名称 = model.DisplayName;
//必须明确存储子对象才能得到正确更新,因为默认貌似没有开启级联更新(新建对象存储时会默认自动存储子对象,但更新对象时不会自动更新子对象)
q.Store(u.用户信息);
});
                    //有返回值调用方法
return MvcApplication.Db4oServerManager.AccessAndReturn(q => q.Query<WebSite.Models.ApplicationUser>(t => t.UserName == User.Identity.GetUserName()).First().用户信息.名称)

下面是传统一些的调用方式:

            using (var dbsa = MvcApplication.Db4oServerManager.CreatAccessor())
{
var finduser = dbsa.Query<TUser>(q => q.Id == user.Id).FirstOrDefault();
dbsa.Delete(finduser);
}

源代码

    /// <summary>
/// Db4o服务器访问器。注意,对数据进行修改后必须释放此对象才能真正的将更改提交到服务器。建议配合using(var dbsa=new Db4oServerAccessor(...)){...}语句使用
/// </summary>
// ReSharper disable once InconsistentNaming
public class Db4oServerAccessor : IDisposable
{
// ReSharper disable once InconsistentNaming
private IObjectContainer DBContainer { get; set; } /// <summary>
/// 构造函数
/// </summary>
/// <param name="serverManager">Db4o服务器管理器</param>
public Db4oServerAccessor(Db4oServerManager serverManager)
{
DBContainer = serverManager.OpenClient();
} public void Store(object o)
{
DBContainer.Store(o);
} public IDb4oLinqQuery<T> Query<T>(Predicate<T> p)
{
return from T q in DBContainer where p(q) select q;
} public IDb4oLinqQuery<T> QueryAll<T>()
{
return from T q in DBContainer select q;
} public int Count<T>(IDb4oLinqQuery<T> collection)
{
return collection.Count();
} public int CountAll<T>()
{
return QueryAll<T>().Count();
} public int Count<T>(Predicate<T> p)
{
return Query(p).Count();
} public int CountAllByExt<T>()
{
foreach (var storedClass in DBContainer.Ext().StoredClasses())
{
if (storedClass.GetName() == typeof(T).FullName) return storedClass.InstanceCount();
}
return ;
} public void Delete(object o)
{
DBContainer.Delete(o);
} public void Delete<T>(Predicate<T> p)
{
foreach (var f in Query<T>(p))
{
Delete(f);
}
} #region IDisposable 成员 public void Dispose()
{
DBContainer.Dispose();
} #endregion
}
    /// <summary>
/// Db4o服务器管理器
/// </summary>
// ReSharper disable once InconsistentNaming
public class Db4oServerManager : IDisposable
{
private IObjectServer _db4OServer;
private readonly string _dbFilePath; /// <summary>
/// 构造函数
/// </summary>
/// <param name="dbFilePath">数据库文件路径,通常使用Server.MapPath("/xxxx/xx.xx")函数获取到。</param>
public Db4oServerManager(string dbFilePath)
{
_dbFilePath = dbFilePath;
OpenServer();
} private void OpenServer()
{
IServerConfiguration serverConfig = Db4oClientServer.NewServerConfiguration();
_db4OServer = Db4oClientServer.OpenServer(serverConfig, _dbFilePath, );
} /// <summary>
/// 开启一个客户端实例
/// </summary>
/// <returns>客户端实例</returns>
public IObjectContainer OpenClient()
{
Begin:
try
{
return _db4OServer.OpenClient();
}
catch
{
OpenServer();
goto Begin;
}
} /// <summary>
/// 创建一个服务器访问器对象。注意,对数据进行修改后必须释放此对象才能真正的将更改提交到服务器。
/// </summary>
/// <returns>一个服务器访问器对象</returns>
public Db4oServerAccessor CreatAccessor()
{
return new Db4oServerAccessor(this);
} /// <summary>
/// 创建并访问一个服务器访问器对象。
/// </summary>
/// <param name="action">对服务器访问器对象的操作行为</param>
public void Access(Action<Db4oServerAccessor> action)
{
using (var dba = CreatAccessor())
{
action(dba);
}
} /// <summary>
/// 创建并访问一个服务器访问器对象,继而获得返回值。
/// </summary>
/// <param name="action">对服务器访问器对象的操作行为</param>
/// <typeparam name="T">返回值类型</typeparam>
public T AccessAndReturn<T>(Func<Db4oServerAccessor,T> action)
{
T v = default(T);
using (var dba = CreatAccessor())
{
v= action(dba);
//System.Diagnostics.Debug.WriteLine(v.ToString());
}
return v;
} #region IDisposable 成员 public void Dispose()
{
_db4OServer.Dispose();
} #endregion
}

结语

最后容我再郑重向大家强力推荐一下Db4o,真心的,桌面、网站、移动无往不利,你值得拥有。

分享Db4o的便捷封装类源码的更多相关文章

  1. 分享45个android实例源码,很好很强大

    分享45个android实例源码,很好很强大 http://www.apkbus.com/android-20978-1-1.html 分享45个android实例源码,很好很强大http://www ...

  2. 分享45个android实例源码,很好很强大.收藏吧!!!

    andriod闹钟源代码 http://www.apkbus.com/android-20974-1-1.html android源码分享之指南针程序 http://www.apkbus.com/an ...

  3. Visual Studio 2015开发Qt项目实战经验分享(附项目示例源码)

    Visual Studio 2015开发Qt项目实战经验分享(附项目示例源码)    转 https://blog.csdn.net/lhl1124281072/article/details/800 ...

  4. 【腾讯Bugly干货分享】微信iOS SQLite源码优化实践

    本文来自于腾讯bugly开发者社区,非经作者同意,请勿转载,原文地址:http://dev.qq.com/topic/57b58022433221be01499480 作者:张三华 前言 随着微信iO ...

  5. 【分享】Maven插件的源码下载(SVN)

    偶然的情况下找到了Maven插件源码的网址,现分享下 http://svn.apache.org/repos/asf/maven/plugins/ 可以使用SVN下载,在添加新的资源路径时,把上面的网 ...

  6. 阿里P7分享如何面对枯燥的源码

    一个软件开发人员,工作到了一定的年限(一般是3.4年左右),如果他还没学会阅读源码,那么他就会遇到瓶颈.因为到了这个时候的开发,他应该不仅仅只会做那些 CURD 的业务逻辑,而应该会根据公司的实际情况 ...

  7. 分享一套主流框架源码资料,征服阿里 P7 面试必备!

    2019年已经过完一半了, 我在这里为大家准备了一份资料,征服阿里 P7 面试必备! 希望这些资料可以帮助到大家,从一个码农进阶为一个优秀的程序员,也可以帮大家提升系统实战能力. 这些资料包括: 讲解 ...

  8. Webfunny知识分享:webpack sourceMap解析源码

    前端的业务越来越庞大,导致我们需要引入的js等静态资源文件的体积也越来越大,不得不使用压缩js文件的方式来提高加载的效率. 编译工具的诞生,极大地方便了我们处理js文件的这一过程,但压缩后的js文件极 ...

  9. 【源码分享】仿网易客户端源码效果 apkbus的~

    http://www.apkbus.com/forum.php?mod=viewthread&tid=184867 内容我就不说了,直接点开看吧.

随机推荐

  1. swift 键盘属性与事件

    1.键盘的类型 textField1.keyboardType = UIKeyboardType.default //系统默认的虚拟键盘 textField1.keyboardType = UIKey ...

  2. HL7 2.6解析转XML(C#版)

    HL7 2.6解析转XML(C#版) 项目中需要解析HL7,所以在网上找到解析代码,但错误很多,所以我修改了一下,测试好用. using System; using System.Collection ...

  3. js中function参数默认值

    --在dreamweaver做网站时,函数定义是在一个*.js文件中,其中定义了一个func,有四个参数,function func(string1,url,flag,icon),然后在另一个asp中 ...

  4. scala-类

    ---恢复内容开始--- 随笔记录scala中,有哪些类,如何定义一个类,有哪些注意点. 一,scala中有哪些类? 1,简单类 class 2,单例模式 object 3,伴生类 4,case cl ...

  5. linux 学习10 shell 基础

    10.1 Shell概述 .Shell是什么 Shell是一个命令行解释器,它为用户提供了一个向Linux内核发送请求以便运行程序的界面系统级程序,用户可以用Shell来启动.挂起.停止甚至是编写一 ...

  6. 在 Windows 環境下利用 VNC 遠端控管 Mac OS X Server

    Mac OS Server 可以使用 VNC 來遠端控管.不過,在 Mac 上打開這個功能很簡單,要讓 Windows 的 VNC Viewer 連上卻很難,原來是有原因的. 首先我們來看怎麼在 Ma ...

  7. MS SQLSERVER 存儲過程與緩存

    提升SQL Server最具性能的一个方面就是存储过程,SQL Server具备执行计划的缓存功能,以便计划重用.SQL Server2000增强了ad-hoc执行计划的缓存功能,就处理存储过程上性能 ...

  8. YII2学习第一天

    YII2学习第一天,之前稍微看了看TP,感觉和自己的理念不是很符合,然后转学YII2了. 使用的文档是https://github.com/yiisoft/yii2/tree/master/docs/ ...

  9. fedora 24下修改IP

    在ROOT环境下 cd /etc/sysconfig/network-scripts 找到类似  ifcfg-enp1s0的文件 sudo vi ifcfg-enp1s0 HWADDR=XX:XX:X ...

  10. python——请求服务器(http请求和https请求)

    一.http请求 1.http请求方式:get和post get一般用于获取/查询资源信息,在浏览器中直接输入url+请求参数点击enter之后连接成功服务器就能获取到的内容,post请求一般用于更新 ...