偷偷摘套内射激情视频,久久精品99国产国产精,中文字幕无线乱码人妻,中文在线中文a,性爽19p

開源.NET下的XML數(shù)據(jù)庫介紹及入門

數(shù)據(jù)庫 其他數(shù)據(jù)庫
有時候嘗試未必是壞事,不斷嘗試新事務(wù),才能發(fā)現(xiàn)新東西,增加閱歷,才能更容易面對復(fù)雜的情況。今天給大家?guī)淼氖且粋€.NET下開源的XML數(shù)據(jù)庫。比較好用,輕量級,小巧,可以滿足一些特殊的變態(tài)的需求。

 比如我這次遇到的。一個小得不能小的工具,本來用sqlite+XCode很快就可以搞定的東東,“領(lǐng)導(dǎo)”說非要用XML存儲,那好吧。就用XML,雖然.NET操作XML很方便,但很好做。我的***反應(yīng)是找一個C#操作XML文件的類,應(yīng)該差不多了。沒想到就發(fā)現(xiàn)了XML數(shù)據(jù)庫這么個玩意,試用,初步還是不錯的,雖然有些小問題,也很久沒更新了。代碼資料還是老樣子,規(guī)矩看前面的博客說明,不在提示了。

XML Database初步介紹

XML Database是一套基于.NET 和 XML技術(shù)開發(fā)的數(shù)據(jù)庫產(chǎn)品,開發(fā)者是博客園的陳希章。其定位是面向.NET開發(fā)平臺的、小型的、面向?qū)ο蟮臄?shù)據(jù)庫,比較適合于本地數(shù)據(jù)緩存、嵌入式數(shù)據(jù)庫應(yīng)用的場景。上次更新日期是2011年了,沒有仔細(xì)去研究源碼,核心的程序集也才25K,所以夠輕量級。那說說其基本特點,更新后的版本的說明沒有找到,就看最老的版本的吧:

1.完全基于XML的存儲。數(shù)據(jù)庫的配置信息和對象數(shù)據(jù)、索引、日志全部是用XML格式保存的。這樣的出發(fā)點主要是XML數(shù)據(jù)格式很易于閱讀和傳輸,轉(zhuǎn)換。

2.基于文件夾的數(shù)據(jù)存儲。這個作者曾經(jīng)有些猶豫,有時候也覺得沒必要,但如果關(guān)系復(fù)雜點的對象,還是有用的。

3.完全基于.NET編寫,結(jié)合了LINQ的語法。這個數(shù)據(jù)庫引擎也可以算是一個所謂的嵌入式的數(shù)據(jù)庫引擎吧,它是通過一個dll提供了全部的功能。目前提供的查詢是基于LINQ to Object的,所有的操作都是面向?qū)ο蟮摹?/p>

4.目前有的功能主要是數(shù)據(jù)庫的創(chuàng)建、打開和關(guān)閉,以及面向?qū)ο蟮脑鰟h查改,簡單的批處理和事務(wù)控制等。

簡單入門例子

存儲是面向?qū)ο蟮模瑢γ恳粭l數(shù)據(jù),都會有一個GUID編號,可以去看生成的XML文件得知。平時我們要存儲在數(shù)據(jù)庫的對象,一般就是實體了,那看看我這個實體的簡單結(jié)構(gòu):

  1. /// <summary>人臉數(shù)據(jù)</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>圖像的特征值,不支持存儲數(shù)組類型,要轉(zhuǎn)換才行</summary>       
  16.      public string Eigenvalue { get; set; } 
  17.      #endregion 
  18.  } 

值得注意的是,我試了一下,好像不支持存儲數(shù)組結(jié)構(gòu),所以是數(shù)組的,要手動轉(zhuǎn)換一下。比如這個特征值,是double[]數(shù)組,用的時候,讀出來,要轉(zhuǎn)換為double[]才能用。格式嘛,自己定??椿静僮鳎?/p>

  1. //數(shù)據(jù)庫沒有會自動創(chuàng)建 
  2.    using (XDatabase db = XDatabase.Open(Main.DbName)) 
  3.    {     
  4.        //然后循環(huán)將特征值和圖像對應(yīng)起來,添加到數(shù)據(jù)庫 
  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.            //保存到數(shù)據(jù)庫 
  17.            db.Store(cut); 
  18.        } 
  19.    //查詢,結(jié)果是IEnumerable<T>類型,可以用LINQ操作 
  20.        var t = db.Query<Faces>();      
  21.    } 

其實很簡單,輕量級的操作就是保存和查詢,更新,更新的操作很簡單,和保存一樣,內(nèi)部會識別是新增的數(shù)據(jù)還是更新數(shù)據(jù)。查詢的結(jié)果是IEnumerable<T>類型,所有可以很方便的使用LINQ來得到你所要的結(jié)果。

當(dāng)然還可能有其他的一些功能,比如事務(wù),我的工具太簡陋,沒有用上,可以研究下。

說明一下,不要也不要說功能有限,有時候我們的需求就這樣,簡單的可以就行,沒必要搞那么復(fù)雜。OK,就算拋磚引玉吧,作者后來的更新也沒有說明,如果使用,可以用Nuget來獲取***的安裝包,地址看下節(jié)。

相關(guān)資源

開源網(wǎng)址: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

 

責(zé)任編輯:彭凡 來源: 博客園
相關(guān)推薦

2011-07-12 10:09:08

XML數(shù)據(jù)庫服務(wù)器

2012-04-12 09:23:15

達(dá)夢數(shù)據(jù)庫

2009-02-23 15:20:03

SQL Server數(shù)據(jù)庫ASP.NET

2011-07-26 11:12:05

DBXML數(shù)據(jù)庫

2017-11-08 09:22:36

數(shù)據(jù)庫NoSQLArangoDB

2010-09-01 09:14:23

Effiproz

2009-12-21 16:36:08

ADO.Net數(shù)據(jù)庫

2010-01-12 10:40:58

VB.NET數(shù)據(jù)庫壓縮

2011-03-29 09:40:31

SQL Server數(shù)據(jù)庫鏈接

2009-10-28 17:24:19

VB.NET介紹

2010-01-18 19:21:51

VB.NET存取數(shù)據(jù)庫

2010-06-11 13:22:32

2010-06-10 10:57:57

2011-05-25 10:56:19

Oracle數(shù)據(jù)庫Unix環(huán)境優(yōu)化

2011-08-15 14:12:16

SQL ServerDATEDIFF

2011-08-18 10:55:55

SQL ServerDATEADD

2009-02-04 17:36:11

ibmdwXML

2013-02-20 14:54:03

C#.NETNDatabase

2011-08-03 15:14:17

Excel XP數(shù)據(jù)庫功能

2023-09-15 16:03:59

向量數(shù)據(jù)庫開源
點贊
收藏

51CTO技術(shù)棧公眾號