开源.NET下的XML数据库介绍及入门

数据库 其他数据库
有时候尝试未必是坏事,不断尝试新事务,才能发现新东西,增加阅历,才能更容易面对复杂的情况。今天给大家带来的是一个.NET下开源的XML数据库。比较好用,轻量级,小巧,可以满足一些特殊的变态的需求。

 比如我这次遇到的。一个小得不能小的工具,本来用sqlite+XCode很快就可以搞定的东东,“领导”说非要用XML存储,那好吧。就用XML,虽然.NET操作XML很方便,但很好做。我的***反应是找一个C#操作XML文件的类,应该差不多了。没想到就发现了XML数据库这么个玩意,试用,初步还是不错的,虽然有些小问题,也很久没更新了。代码资料还是老样子,规矩看前面的博客说明,不在提示了。

XML Database初步介绍

XML Database是一套基于.NET 和 XML技术开发的数据库产品,开发者是博客园的陈希章。其定位是面向.NET开发平台的、小型的、面向对象的数据库,比较适合于本地数据缓存、嵌入式数据库应用的场景。上次更新日期是2011年了,没有仔细去研究源码,核心的程序集也才25K,所以够轻量级。那说说其基本特点,更新后的版本的说明没有找到,就看最老的版本的吧:

1.完全基于XML的存储。数据库的配置信息和对象数据、索引、日志全部是用XML格式保存的。这样的出发点主要是XML数据格式很易于阅读和传输,转换。

2.基于文件夹的数据存储。这个作者曾经有些犹豫,有时候也觉得没必要,但如果关系复杂点的对象,还是有用的。

3.完全基于.NET编写,结合了LINQ的语法。这个数据库引擎也可以算是一个所谓的嵌入式的数据库引擎吧,它是通过一个dll提供了全部的功能。目前提供的查询是基于LINQ to Object的,所有的操作都是面向对象的。

4.目前有的功能主要是数据库的创建、打开和关闭,以及面向对象的增删查改,简单的批处理和事务控制等。

简单入门例子

存储是面向对象的,对每一条数据,都会有一个GUID编号,可以去看生成的XML文件得知。平时我们要存储在数据库的对象,一般就是实体了,那看看我这个实体的简单结构:

  1. /// <summary>人脸数据</summary>   
  2.  public class Faces  
  3.  { 
  4.      #region 属性 
  5.      /// <summary>姓名</summary>        
  6.      public String Name { get; set; }     
  7.      /// <summary>年龄</summary> 
  8.      public Int32 Age { get; set; }            
  9.      /// <summary>性别</summary> 
  10.      public String Sex { get; set; }   
  11.      /// <summary>手机号码</summary>        
  12.      public String Tel { get; set; }    
  13.      /// <summary>图片位置</summary>       
  14.      public String Position { get; set; } 
  15.      /// <summary>图像的特征值,不支持存储数组类型,要转换才行</summary>       
  16.      public string Eigenvalue { get; set; } 
  17.      #endregion 
  18.  } 

值得注意的是,我试了一下,好像不支持存储数组结构,所以是数组的,要手动转换一下。比如这个特征值,是double[]数组,用的时候,读出来,要转换为double[]才能用。格式嘛,自己定。看基本操作:

  1. //数据库没有会自动创建 
  2.    using (XDatabase db = XDatabase.Open(Main.DbName)) 
  3.    {     
  4.        //然后循环将特征值和图像对应起来,添加到数据库 
  5.        for (int i = 0; i < 20; i++) 
  6.        { 
  7.            //添加图片信息 
  8.            Faces cut = new Faces(); 
  9.            cut.Name = Names[i]; 
  10.            cut.Sex = Sexs[i]; 
  11.            cut.Tel = Teles[i]; 
  12.            cut.Age = Ages[i]; 
  13.            cut.Position = fileNames[i]; 
  14.            //添加特征值 
  15.            cut.Eigenvalue = DoubleArrayToString (MeanB[i]); 
  16.            //保存到数据库 
  17.            db.Store(cut); 
  18.        } 
  19.    //查询,结果是IEnumerable<T>类型,可以用LINQ操作 
  20.        var t = db.Query<Faces>();      
  21.    } 

其实很简单,轻量级的操作就是保存和查询,更新,更新的操作很简单,和保存一样,内部会识别是新增的数据还是更新数据。查询的结果是IEnumerable<T>类型,所有可以很方便的使用LINQ来得到你所要的结果。

当然还可能有其他的一些功能,比如事务,我的工具太简陋,没有用上,可以研究下。

说明一下,不要也不要说功能有限,有时候我们的需求就这样,简单的可以就行,没必要搞那么复杂。OK,就算抛砖引玉吧,作者后来的更新也没有说明,如果使用,可以用Nuget来获取***的安装包,地址看下节。

相关资源

开源网址:http://xmldatabase.codeplex.com/

作者博客:http://www.cnblogs.com/chenxizhang/

Nuget地址:http://nuget.org/packages/XMLDatabase

原文链接:http://www.cnblogs.com/asxinyu/archive/2013/03/25/2980086.html

 

责任编辑:彭凡 来源: 博客园
相关推荐

2011-07-12 10:09:08

XML数据库服务器

2012-04-12 09:23:15

达梦数据库

2009-02-23 15:20:03

SQL Server数据库ASP.NET

2011-07-26 11:12:05

DBXML数据库

2017-11-08 09:22:36

数据库NoSQLArangoDB

2010-09-01 09:14:23

Effiproz

2009-12-21 16:36:08

ADO.Net数据库

2010-01-12 10:40:58

VB.NET数据库压缩

2011-03-29 09:40:31

SQL Server数据库链接

2009-02-04 17:36:11

ibmdwXML

2010-01-18 19:21:51

VB.NET存取数据库

2009-10-28 17:24:19

VB.NET介绍

2010-06-10 10:57:57

2011-08-18 10:55:55

SQL ServerDATEADD

2011-08-15 14:12:16

SQL ServerDATEDIFF

2013-02-20 14:54:03

C#.NETNDatabase

2010-06-11 13:22:32

2011-05-25 10:56:19

Oracle数据库Unix环境优化

2011-08-03 15:14:17

Excel XP数据库功能

2023-09-15 16:03:59

向量数据库开源
点赞
收藏

51CTO技术栈公众号