分享Db4o的便捷封装类源码

导言

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

最近在写网站,个人对传统数据库天然抵触,感觉非常繁冗,即便是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 InconsistentNamingpublic class Db4oServerAccessor : IDisposable{// ReSharper disable once InconsistentNamingprivate 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 0;}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 InconsistentNamingpublic 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, 0);}/// <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,真心的,桌面、网站、移动无往不利,你值得拥有。

转载于:https://www.cnblogs.com/SkyD/p/3574651.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/473555.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Flink中的状态管理

1 Flink中的状态 当数据流中的许多操作只查看一个每次事件(如事件解析器)&#xff0c;一些操作会跨多个事件的信息(如窗口操作)。这些操作称为有状态。状态由一个任务维护&#xff0c;并且用来计算某个结果的所有数据&#xff0c;都属于这个任务的状态。可以简单的任务状态就是…

Python之日志处理(logging模块)

主要内容 日志相关概念logging模块简介使用logging提供的模块级别的函数记录日志logging模块日志流处理流程使用logging四大组件记录日志配置logging的几种方式向日志输出中添加上下文信息参考文档 一、日志相关概念 日志是一种可以追踪某些软件运行时所发生事件的方法。软件开…

LeetCode 514. 自由之路(记忆化递归 / DP)

文章目录1. 题目2. 解题1. 题目 电子游戏“辐射4”中&#xff0c;任务“通向自由”要求玩家到达名为“Freedom Trail Ring”的金属表盘&#xff0c;并使用表盘拼写特定关键词才能开门。 给定一个字符串 ring&#xff0c;表示刻在外环上的编码&#xff1b;给定另一个字符串 ke…

thinkpad s3 安装win8 kali双系统笔记

前段时间入手了一台thinkpad s3(i7,8G),预装了win8系统,windows下写代码,环境配置比较麻烦,就想安装kali linux做双系统,官方参考文档:http://docs.kali.org/installation/dual-boot-kali-with-windows但s3预装了64bit win8,采用的是UEFI启动,官方文档并不完全适用,所以折腾了一…

Flink中的容错机制

1 checkpoint Flink 故障恢复机制的核心&#xff0c;就是应用状态的一致性检查点checkpoint。 在Spark Streaming中仅仅是针对driver的故障恢复做了数据和元数据的Checkpoint&#xff0c;处理的是当前时间点所有分区当前数据的状态。在Flink中不能把当前所有分区的数据直接存下…

os、os.path、shutil操作文件和文件路径的常用方法总结

os模块是python标准库中的一个用于访问操作系统功能的模块&#xff0c;下面简要介绍一下常用的命令 1、os.name(). 判断现在正在使用的平台&#xff0c;windows返回’nt’&#xff0c;Linux返回‘posix’ 2、os.getcwd() 得到当前工作的目录 3、os.listdir(). 指定所在目…

LeetCode 698. 划分为k个相等的子集(回溯)

文章目录1. 题目2. 解题1. 题目 给定一个整数数组 nums 和一个正整数 k&#xff0c;找出是否有可能把这个数组分成 k 个非空子集&#xff0c;其总和都相等。 示例 1&#xff1a; 输入&#xff1a; nums [4, 3, 2, 3, 5, 2, 1], k 4 输出&#xff1a; True 说明&#xff1a;…

Linux网络服务器epoll模型的socket通讯的实现(一)

准备写一个网络游戏的服务器的通讯模块&#xff0c;参考网上看到的一些代码&#xff0c;在linux下面实现一个多线程的epoll模型的socket通讯的代码,以下是第一部分多线程的切换代码: 1 #include <stdio.h>2 #include <sys/types.h>3 #include <sys/epoll.h>…

MySQL中的表中增加删除字段

1增加两个字段&#xff1a; mysql> create table id_name(id int,name varchar(20)); Query OK, 0 rows affected (0.13 sec)mysql> alter table id_name add age int,add address varchar(11); Query OK, 0 rows affected (0.13 sec) Records: 0 Duplicates: 0 Warnin…

Ubuntu编写开机自启动脚本(转载)

From:http://blog.csdn.net/marujunyy/article/details/8466255 1、首先编写一个简单的shell脚本test.sh #! /bin/bash echo "Hello world!" filenamedate"%Y%m%d" echo $filename 2、设置脚本开机自启动 方法一&#xff1a; 编辑/etc/init.d/rc.local文件…

Ubuntu下svn 版本管理客户端工具及常用方法

Ubuntu16.04系统下安装RapidSVN版本控制器及配置diff,editor,merge和exploer工具&#xff0c;在Window下我们使用TortoiseSVN(小乌龟)&#xff0c;可以很方便地进行查看、比较、更新、提交、回滚等SVN版本控制操作。 在Linux下我们可以使用RapidSVN。RapidSVN是一款轻量级的免费…

Flink的Table API 与SQL介绍及调用

1 概述 DataSetAPI和DateStreamAPI是基于整个Flink的运行时环境做操作处理的&#xff0c;Table API和SQL是在DateStreamAPI上又包了一层。对于新版本的Blink在DateStream基础上又包了一层实现了批流统一&#xff0c;上层执行环境都是基于流处理&#xff0c;做批流统一的查询。T…

Python编程中一些异常处理的小技巧

编程中经常会需要使用到异常处理的情况&#xff0c;在阅读了一些资料后&#xff0c;整理了关于异常处理的一些小技巧记录如下。 1 如何自定义异常 1.1 定义异常类 在实际编程中&#xff0c;有时会发现Python提供的内建异常的不够用&#xff0c;我们需要在特殊业务场景下的异常…

Flink的Table API 与SQL的流处理

1 流处理与SQL的区别 Table API和SQL&#xff0c;本质上还是基于关系型表的操作方式&#xff1b;而关系型表、SQL本身&#xff0c;一般是有界的&#xff0c;更适合批处理的场景。所以在流处理的过程中&#xff0c;有一些特殊概念。 SQL流处理处理对象字段元组的有界集合字段元…

LeetCode 833. 字符串中的查找与替换(排序,replace)

文章目录1. 题目2. 解题1. 题目 某个字符串 S 需要执行一些替换操作&#xff0c;用新的字母组替换原有的字母组&#xff08;不一定大小相同&#xff09;。 每个替换操作具有 3 个参数&#xff1a;起始索引 i&#xff0c;源字 x 和目标字 y。 规则是&#xff1a;如果 x 从原始…

Json.NET

我前面的一篇博客 Metro应用Json数据处理 介绍了如何使用 DataContractJsonSerializer 类将对象的实例序列化为JSON字符串以及将JSON字符串反序列化为对象的实例的处理方式。而此种处理方式的一个很大的缺点就是要求JSON字符串格式是约定好的&#xff0c;而在很多情况下我们无法…

MySQL如何跨机器迁移数据?

经常会遇到如此需求&#xff0c;需把A主机上的MySQL数据库所有迁移到B主机上&#xff0c;或者部分数据库&#xff0c;所以接下来将介绍迁移所有数据库和迁移单个数据库时的数据迁移步骤。 1 实验环境 A主机&#xff08;源主机&#xff09;&#xff1a; IP地址&#xff1a;19…

ClickHouse的特性及读写

1 ClickHouse特性 OLAP数据库一般有2个要求&#xff1a;①容量要比关系型数据库大&#xff0c;②在线查询的速度要快。ClickHouse这两点都满足并且还支持标准的sql&#xff0c;支持比较复杂的语句&#xff0c;支持分布式。ClickHouse的几个显著特点如下&#xff1a; &#xff0…

天池 在线编程 最大得分(DP)

文章目录1. 题目2. 解题1. 题目 来源&#xff1a;https://tianchi.aliyun.com/oj/164423301311799378/184808348725744275 2. 解题 class Solution { public:/*** param matrix: the matrix* return: the maximum score you can get*/int maximumScore(vector<vector<i…

imagick用法!

https://coderwall.com/p/9hj97w sudo apt-get install imagemagick sudo apt-get install php5-imagick sudo service apache2 restart 使用imagick类&#xff1a; http://www.wodezhan.cn/?p15转载于:https://www.cnblogs.com/vincedotnet/p/3592957.html