我們知道目前大部分的數據庫都是關系型數據庫, 所謂關系型數據庫,就是指建立在關系模型 基礎之上的數據庫系統,如Oracle、SQL Server、Access、MySQL等。關系模型就是指二維表格模型,因而一個關系型數據庫就是由二維表及其之間的聯系組成的一個數據組織。一個偶然的機會我接觸到了DB4O,它是一個完全面向對象的開源數據庫,它的出現完全顛覆了傳統的數據庫在人們心中的形象,因為傳統的數據庫需要在數據體、實體之間轉換,而且需要映射文件提供映射關系。正是這個項目讓我產生了編寫Xml4DB的想法,從這個名字我們可以看粗,它是基於Xml的形式來實現存儲的。我們知道,將一個對象以一定的形式存儲稱為序列化、反之則成為反序列化,因此反射是整個項目中最為有趣和強大的基礎。由於數據庫需要查詢,所以Linq成為了我設計這個項目的首選,Xml4DB在使用上力求簡單,參考了DB4O的優雅的方法。
下載Xml4DB
免費下載地址在 http://linux.linuxidc.com/
用戶名與密碼都是www.linuxidc.com
具體下載目錄在 /2014年資料/3月/2日/C#基於Linq和反射實現數據持久化框架Xml4DB
下載方法見 http://www.linuxidc.com/Linux/2013-07/87684.htm
接下來呢,我們就來演示下如何使用Xml4DB吧。在Xml4DB中只有兩個重要的類:XmlDB和XmlDBFactory,我們只需要使用XmlDBFactory就可以實現對XmlDB的創建。XmlDBFactory是一個靜態工廠類,提供了三個方法:
1、CreatXmlDB()方法以覆蓋式的方式創建數據庫。當數據庫文件不存在時,則創建數據庫,如果數據庫存在,則對數據庫進行覆蓋操作。此方法適合第一次創建數據庫時使用。
2、LoadXmlDB()方法用於獲取一個已經存在的數據庫,如果數據庫文件不存在將引發異常。
3、UpdateXmlDB()以升級方式創建XmlDB數據庫,前提是數據庫文件已經存在,且新創建的數據庫的版本要比之前的版本高。
介紹完工廠類,我們來講解數據庫類XmlDB,在此類中我們定義了常見的數據庫方法:
1、Insert()方法用於向數據庫中插入一個對象
2、Read()方法用於從數據庫讀取一個或多個對象,返回List<T>
3、Delete()方法用於從數據庫中刪除一個或多個對象
4、Update()方法用於將一個或多個對象的值修改為對應的相同類型的值
下面我們給出一個示例程序代碼:
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Xml.Linq;
using Xml4DB;
namespace Xml4DB.Sample
{
class Program
{
static void Main(string[] args)
{
//以覆蓋方式創建XmlDB
XmlDB mDB = XmlDBFactory.CreatXmlDB("XmlDB示例程序","D:\\XmlDB演示程序\\Sample.xml",1);
//創建Student對象李逍遙
Student mStudent = new Student(1, "李逍遙", 18);
//插入Student對象李逍遙
mDB.Insert(mStudent);
//創建Student對象酒劍仙
mStudent = new Student(2, "酒劍仙", 37);
//插入Student對象酒劍仙
mDB.Insert(mStudent);
//創建Student對象趙靈兒
mStudent = new Student(3, "趙靈兒", 17);
//插入Student對象趙靈兒
mDB.Insert(mStudent);
//創建Student對象慕容紫英
mStudent = new Student(4, "慕容紫英", 20);
//插入Student對象慕容紫英
mDB.Insert(mStudent);
//提交修改
mDB.Commit();
//查詢姓名為李逍遙的Student對象
List<Student> objects = mDB.Read(new Student(0, "李逍遙", 0));
//輸出查詢結果
Console.WriteLine(objects[0].ToString());
//將姓名為酒劍仙的對象中的姓名改為司徒鐘,年齡改為40
mDB.Update(new Student(0, "酒劍仙", 0), new Student(0, "司徒鐘", 40));
//刪除ID為3的對象記錄
mDB.Delete(new Student(3, null, 0));
mDB.Commit();
//讀取全部的Student記錄
objects = mDB.Read(new Student());
foreach (Student obj in objects)
{
Console.WriteLine(obj.ToString());
}
//等待以便觀察結果
Console.ReadKey();
}
/// <summary>
/// XmlDB演示類
/// </summary>
public class Student
{
public Student()
{
}
public Student(int mID,string mName,int mAge)
{
this.mID = mID;
this.mName = mName;
this.mAge=mAge;
}
private int mAge;
public int Age
{
get { return mAge; }
set { mAge = value; }
}
private int mID;
public int ID
{
get { return mID; }
set { mID = value; }
}
private string mName;
public string Name
{
get { return mName; }
set { mName = value; }
}
public override string ToString()
{
return string.Format("ID={0},Name={1},Age={2}", this.ID, this.Name,this.Age);
}
}
}
}
怎麼樣?是不是感覺很簡單呢?這個項目采用了Xml作為數據存儲的格式,所以最終的數據庫文件就是一個Xml文件(這和序列化、反序列化類似),就像下面這樣:
<?xml version="1.0" encoding="utf-8"?>
<XmlDB DBName="XmlDB示例程序" DBVersion="1">
<Student>
<Age>18</Age>
<ID>1</ID>
<Name>李逍遙</Name>
</Student>
<Student>
<Age>37</Age>
<ID>2</ID>
<Name>酒劍仙</Name>
</Student>
<Student>
<Age>17</Age>
<ID>3</ID>
<Name>趙靈兒</Name>
</Student>
<Student>
<Age>20</Age>
<ID>4</ID>
<Name>慕容紫英</Name>
</Student>
</XmlDB>
由於假期時間有限,所以目前這個項目只提供了對整型和字符型的基礎類型的支持,後面將增加對它基本類型的支持;由於目前部分算法並不完善,所以目前這個項目不支持嵌套的類型屬性,等後面有時間的話會逐步完善這個項目的。需要注意的是,在這個項目中整型的默認值為0,字符型的默認值為null,所以請不要給對象賦予這樣的屬性值,因為這樣的對象將被排除,從而造成無法讀取對象的問題。每一個對象實體都要默認給出一個不帶參數的構造函數,因為內部構造中使用了反射技術,當根據一個類型來生成一個新實例時就會用到。希望大家會喜歡,謝謝!