众所周知,XML文件是保存和传输数据的载体,数据库自然也可以用XML进行读取。那么怎样使用XML技术呢?Microsoft.Net提供了XmlDataDocument类来专门来操作数据库。

 

XmlD

ataDocument是XmlDocument的一个子类,它可以去读取和操作数据库或Xml文件中的数据,它使用的是W3C Document Object(DOM)。DOM用带有层次的节点来描述数据。由于它实现了IxpathNavigable接口,所以它又可以被XslTransform使用。由于XmlDataDocument和DataSet有密切的联系,任何对XmlDataDocument的改动将映射到相应的DataSet上,反之亦然。

下面我们用一个例子来说明怎样将一个DataSet输出到一个Xml文件中去。

WriteTo.cs

怎样用XML技术对数据库进行操作using System;
怎样用XML技术对数据库进行操作
怎样用XML技术对数据库进行操作
using System.Data;
怎样用XML技术对数据库进行操作
怎样用XML技术对数据库进行操作
using System.Xml;
怎样用XML技术对数据库进行操作
怎样用XML技术对数据库进行操作
using System.Data.SqlClient;
怎样用XML技术对数据库进行操作
怎样用XML技术对数据库进行操作
怎样用XML技术对数据库进行操作
public class WriteTo
怎样用XML技术对数据库进行操作


运行这个程序,我们发现结果如下:

怎样用XML技术对数据库进行操作<NewDataSet>
怎样用XML技术对数据库进行操作
怎样用XML技术对数据库进行操作
<product>
怎样用XML技术对数据库进行操作
怎样用XML技术对数据库进行操作
<Id>1</Id>
怎样用XML技术对数据库进行操作
怎样用XML技术对数据库进行操作
<ProductName>Product1</ProductName>
怎样用XML技术对数据库进行操作
怎样用XML技术对数据库进行操作
</product>
怎样用XML技术对数据库进行操作
怎样用XML技术对数据库进行操作
<product>
怎样用XML技术对数据库进行操作
怎样用XML技术对数据库进行操作
<Id>2</Id>
怎样用XML技术对数据库进行操作
怎样用XML技术对数据库进行操作
<ProductName>Product2</ProductName>
怎样用XML技术对数据库进行操作
怎样用XML技术对数据库进行操作
</product>
怎样用XML技术对数据库进行操作
怎样用XML技术对数据库进行操作
<product>
怎样用XML技术对数据库进行操作
怎样用XML技术对数据库进行操作
<Id>3</Id>
怎样用XML技术对数据库进行操作
怎样用XML技术对数据库进行操作
<ProductName>Product3</ProductName>
怎样用XML技术对数据库进行操作
怎样用XML技术对数据库进行操作
</product>
怎样用XML技术对数据库进行操作
怎样用XML技术对数据库进行操作
<product>
怎样用XML技术对数据库进行操作
怎样用XML技术对数据库进行操作
<Id>4</Id>
怎样用XML技术对数据库进行操作
怎样用XML技术对数据库进行操作
<ProductName>Product4</ProductName>
怎样用XML技术对数据库进行操作
怎样用XML技术对数据库进行操作
</product>
怎样用XML技术对数据库进行操作
怎样用XML技术对数据库进行操作
</NewDataSet>
怎样用XML技术对数据库进行操作
怎样用XML技术对数据库进行操作
<NewDataSet>
怎样用XML技术对数据库进行操作
怎样用XML技术对数据库进行操作
<product>
怎样用XML技术对数据库进行操作
怎样用XML技术对数据库进行操作
<Id>1</Id>
怎样用XML技术对数据库进行操作
怎样用XML技术对数据库进行操作
<ProductName>Product1</ProductName>
怎样用XML技术对数据库进行操作
怎样用XML技术对数据库进行操作
</product>
怎样用XML技术对数据库进行操作
怎样用XML技术对数据库进行操作
<product>
怎样用XML技术对数据库进行操作
怎样用XML技术对数据库进行操作
<Id>2</Id>
怎样用XML技术对数据库进行操作
怎样用XML技术对数据库进行操作
<ProductName>Product2</ProductName>
怎样用XML技术对数据库进行操作
怎样用XML技术对数据库进行操作
</product>
怎样用XML技术对数据库进行操作
怎样用XML技术对数据库进行操作
<product>
怎样用XML技术对数据库进行操作
怎样用XML技术对数据库进行操作
<Id>3</Id>
怎样用XML技术对数据库进行操作
怎样用XML技术对数据库进行操作
<ProductName>Product3</ProductName>
怎样用XML技术对数据库进行操作
怎样用XML技术对数据库进行操作
</product>
怎样用XML技术对数据库进行操作
怎样用XML技术对数据库进行操作
<product>
怎样用XML技术对数据库进行操作
怎样用XML技术对数据库进行操作
<Id>4</Id>
怎样用XML技术对数据库进行操作
怎样用XML技术对数据库进行操作
<ProductName>Product4</ProductName>
怎样用XML技术对数据库进行操作
怎样用XML技术对数据库进行操作
</product>
怎样用XML技术对数据库进行操作
怎样用XML技术对数据库进行操作
</NewDataSet>
怎样用XML技术对数据库进行操作
怎样用XML技术对数据库进行操作

我们可以看到一个数据库成功的输出成一个XML文件格式。

有了XmlDataDocument这个类,我们可以很轻松的对一个数据库进行操作,并且我们对XmlDataDocument所做的操作都会映射到数据库中去。

比如我们对一个XML文件操作(这个XML文件是DataSet产生的),相应的改变也会导致DataSet的改变。

下面我们以一个实例来说明这一点,需说明的一点是,这个实例还使用了XSD进行校验,以确保数据库传输和操作的正确性。

Store.xsd:

怎样用XML技术对数据库进行操作<xsd:schema xmlns:xsd="http://www.w3.org/2001/XMLSchema">
怎样用XML技术对数据库进行操作
怎样用XML技术对数据库进行操作
<xsd:element name="bookstore" type="bookstoreType"/>
怎样用XML技术对数据库进行操作
怎样用XML技术对数据库进行操作
<xsd:complexType name="bookstoreType">
怎样用XML技术对数据库进行操作
怎样用XML技术对数据库进行操作
<xsd:sequence maxOccurs="unbounded">
怎样用XML技术对数据库进行操作
怎样用XML技术对数据库进行操作
<xsd:element name="book" type="bookType"/>
怎样用XML技术对数据库进行操作
怎样用XML技术对数据库进行操作
</xsd:sequence>
怎样用XML技术对数据库进行操作
怎样用XML技术对数据库进行操作
</xsd:complexType>
怎样用XML技术对数据库进行操作
怎样用XML技术对数据库进行操作
怎样用XML技术对数据库进行操作
<xsd:complexType name="bookType">
怎样用XML技术对数据库进行操作
怎样用XML技术对数据库进行操作
<xsd:sequence>
怎样用XML技术对数据库进行操作
怎样用XML技术对数据库进行操作
<xsd:element name="title" type="xsd:string"/>
怎样用XML技术对数据库进行操作
怎样用XML技术对数据库进行操作
<xsd:element name="author" type="authorName"/>
怎样用XML技术对数据库进行操作
怎样用XML技术对数据库进行操作
<xsd:element name="price" type="xsd:decimal"/>
怎样用XML技术对数据库进行操作
怎样用XML技术对数据库进行操作
</xsd:sequence>
怎样用XML技术对数据库进行操作
怎样用XML技术对数据库进行操作
<xsd:attribute name="genre" type="xsd:string"/>
怎样用XML技术对数据库进行操作
怎样用XML技术对数据库进行操作
</xsd:complexType>
怎样用XML技术对数据库进行操作
怎样用XML技术对数据库进行操作
怎样用XML技术对数据库进行操作
<xsd:complexType name="authorName">
怎样用XML技术对数据库进行操作
怎样用XML技术对数据库进行操作
<xsd:sequence>
怎样用XML技术对数据库进行操作
怎样用XML技术对数据库进行操作
<xsd:element name="first-name" type="xsd:string"/>
怎样用XML技术对数据库进行操作
怎样用XML技术对数据库进行操作
<xsd:element name="last-name" type="xsd:string"/>
怎样用XML技术对数据库进行操作
怎样用XML技术对数据库进行操作
</xsd:sequence>
怎样用XML技术对数据库进行操作
怎样用XML技术对数据库进行操作
</xsd:complexType>
怎样用XML技术对数据库进行操作
怎样用XML技术对数据库进行操作
</xsd:schema>
怎样用XML技术对数据库进行操作
怎样用XML技术对数据库进行操作

我们可以发现这个XSD文件控制的XML文件的格式,它定义了三个元素:title,author和price。

对应的DataSet.xml如下:

怎样用XML技术对数据库进行操作<!--sample XML fragment-->
怎样用XML技术对数据库进行操作
怎样用XML技术对数据库进行操作
<bookstore>
怎样用XML技术对数据库进行操作
怎样用XML技术对数据库进行操作
<book genre='novel' ISBN='10-861003-324'>
怎样用XML技术对数据库进行操作
怎样用XML技术对数据库进行操作
<title>The Handmaid's Tale</title>
怎样用XML技术对数据库进行操作
怎样用XML技术对数据库进行操作
<price>19.95</price>
怎样用XML技术对数据库进行操作
怎样用XML技术对数据库进行操作
</book>
怎样用XML技术对数据库进行操作
怎样用XML技术对数据库进行操作
<book genre='novel' ISBN='1-861001-57-5'>
怎样用XML技术对数据库进行操作
怎样用XML技术对数据库进行操作
<title>Pride And Prejudice</title>
怎样用XML技术对数据库进行操作
怎样用XML技术对数据库进行操作
<price>24.95</price>
怎样用XML技术对数据库进行操作
怎样用XML技术对数据库进行操作
</book>
怎样用XML技术对数据库进行操作
怎样用XML技术对数据库进行操作
</bookstore>
怎样用XML技术对数据库进行操作
怎样用XML技术对数据库进行操作

这个Xml文件可以向上例那样通过XmlDataDocument产生,数据库名是:bookstore,表名是book,column名是title和price,genre和ISBN也是当做column来处理。

针对这个Xml文件我们可以进行操作。

运行这个程序,发现输出如下:

Display the modified XML data...

 

怎样用XML技术对数据库进行操作<bookstore><book genre="novel" ISBN="10-861003-324"><title>The Handmaid's Tale</title><price>18.95</price></book><book genre="novel" ISBN="1-861001-57-5"><title>Pride And Prejudice</title><price>24.95</price></book></bookstore>

 

我们可以发现price的值已改了过来。我们可以在查找相应数据库(bookstore),发现里面的值也跟着改了。

相关文章:

  • 2021-12-13
  • 2022-12-23
  • 2022-12-23
  • 2022-12-23
  • 2021-12-08
  • 2022-12-23
  • 2021-07-02
  • 2021-12-08
猜你喜欢
  • 2021-09-23
  • 2022-12-23
  • 2022-12-23
  • 2021-10-27
  • 2022-12-23
  • 2022-12-23
  • 2021-04-26
相关资源
相似解决方案