ข้อความอธิบายไว้ในส่วนของโปรแกรม คลาส XmlWriter ส่วนใหญ่จะใช้สำหรับการสร้างไฟล์ XML
ต่อไปนี้เป็นกระบวนการสร้างไฟล์ XML ที่สอดคล้องกันจากฐานข้อมูลเชิงสัมพันธ์ เนื่องจาก XML เป็นเพียงมิดเดิลแวร์ Schema หรือ DTD จึงถูกละเว้น
1 โมฆะส่วนตัว Page_Load (ผู้ส่งวัตถุ System.EventArgs e)
2 {
3 //ใส่รหัสผู้ใช้ที่นี่เพื่อเริ่มต้นเพจ
4 // คำจำกัดความข้อมูลพื้นฐาน
5 สตริง strTableName="systypes";
6 สตริง strConnection="server=suntears;user id=sa;password=041210;database=webapplication1_db";
7 สตริง strSql="เลือก * จาก "+strTableName;
8 SqlConnection objConn=การเชื่อมต่อ Sql ใหม่ (strConnection);
9 SqlDataAdapter objAdapter=SqlDataAdapter ใหม่ (strSql,objConn);
10 ชุดข้อมูล objDSet=ชุดข้อมูลใหม่();
11 objAdapter.Fill(objDSet,"อุณหภูมิ");
12 XmlTextWriter objXmlWriter;
13 สตริง strtemp1=คำขอPhysicalApplicationPath;
14 สตริง strpath=strtemp1+"qiming.xml";
15 //เตรียมใช้งาน XmlWriter ใช้คลาสนี้ในการเขียนไฟล์ XML
16 objXmlWriter=XmlTextWriter ใหม่ (strpath,null);
17 //สร้างการประกาศ XML ที่จุดเริ่มต้น
18 objXmlWriter.WriteStartDocument();
19 //สร้างองค์ประกอบรูท xml1
20 objXmlWriter.WriteStartElement("xml1");
21 //ชื่อตารางคือชื่อองค์ประกอบ ชื่อฟิลด์คือแอตทริบิวต์ และบันทึกในตารางคือค่าของแอตทริบิวต์
22 สำหรับ(int i=0;i
24 objXmlWriter.WriteStartElement("เมนู");
25 for(int j=0;j
27 // เขียนคุณสมบัติ
28 objXmlWriter.WriteAttributeString(objDSet.Tables["temp"].Columns[j].ColumnName,objDSet.Tables["temp"].แถว[i][j].ToString());
29 }
30 objXmlWriter.WriteEndElement();
31}
32 objXmlWriter.WriteEndElement();
33 objXmlWriter.WriteEndDocument();
34 //ใช้วิธีปิดเพื่อปิดไฟล์ ไม่เช่นนั้นไฟล์จะถูกล็อค
35 objXmlWriter.ปิด();
36 // แสดงผลลัพธ์บนเพจ
37 สตริง strXmlResult;
38 StreamReader objSR = File.OpenText(strpath);
39 strXmlResult = objSR.ReadToEnd();
40 objSR.ปิด();
41 Response.Write("" + Server.HtmlEncode(strXmlResult) + "
");
42 }
ต่อไปนี้เป็นรหัสเพื่อสร้างฐานข้อมูลเชิงสัมพันธ์ผ่านไฟล์ XML ที่สร้างโดยโปรแกรมข้างต้น
1 โมฆะส่วนตัว Page_Load (ผู้ส่งวัตถุ System.EventArgs e)
2 {
3 //ใส่รหัสผู้ใช้ที่นี่เพื่อเริ่มต้นเพจ
4 // คำจำกัดความข้อมูลพื้นฐาน
5 int cx=1;
6 สตริง strConn="server=suntears;user id=sa;password=;database=xml_example";
7 string strappstr=Request.PhysicalApplicationPath;
8 สตริง strpath=strappstr+"qiming.xml";
9 สตริง strtablename="xml1";
10 สตริง strCreatetable="สร้างตาราง "+strtablename+"(";
11 XmlTextReader objXmlReader=XmlTextReader ใหม่(strpath);
12 SqlConnection objConn=การเชื่อมต่อ Sql ใหม่ (strConn);
13 SqlCommand objคำสั่ง;
14 SqlDataAdapter objAdapter;
15 ชุดข้อมูล objDSet=ชุดข้อมูลใหม่();
16 DataRow ตรงข้าม;
17 XmlNodeType objNodeType;
18 //ใช้คลาส XmlReader สำหรับการดำเนินการเข้าถึงไฟล์ XML
19 //XmlReader ใช้โหมดดึง ดังนั้นแต่ละโหนดจึงถูกวนซ้ำโดยใช้เมธอด Read()
20 ในขณะที่(objXmlReader.Read())
ยี่สิบเอ็ด {
22 objNodeType=objXmlReader.NodeType;
23 //ดำเนินการที่แตกต่างกันตามประเภทของโหนด
24 สวิตช์ (objNodeType)
25 {
26 //ประกาศที่จุดเริ่มต้นของไฟล์ XML
27 กรณี XmlNodeType.Xmlการประกาศ:
28 Response.Write("11111"+objXmlReader.Name+"
");
29 พัก;
30 // ประเภทโหนดปกติ
31 กรณี XmlNodeType.Element:
32 //พิจารณาว่าเป็นองค์ประกอบรูทตามจำนวนแอตทริบิวต์หรือไม่
33 ถ้า(objXmlReader.AttributeCount>0)
34 {
35 //cx เป็นบิตแฟล็ก สร้างฐานข้อมูลตามโครงสร้างองค์ประกอบเมื่อเข้าถึงโหนดองค์ประกอบที่ไม่ใช่รูทเป็นครั้งแรก
36 ถ้า(cx==1)
37 {
38 ในขณะที่ (objXmlReader.MoveToNextAttribute())
39 {
40 strCreatetable=strCreatetable+objXmlReader.Name+" varchar(50), ";
41 }
42 strCreatetable=strCreatetable+"";
43 objCommand=ใหม่ SqlCommand(strCreatetable,objConn);
44 objConn.เปิด();
45 objCommand.ExecuteNonQuery();
46 objConn.ปิด();
47 objAdapter=new SqlDataAdapter("เลือก * จาก "+strtablename,objConn);
48 objAdapter.Fill(objDSet,strtablename);
49 objXmlReader.MoveToFirstAttribute();
50 //เปลี่ยนแฟล็กเป็นค่า cx
51cx=0;
52 }
53 //ดัมพ์ข้อมูลในไฟล์ XML ลงในวัตถุชุดข้อมูล
54 objrow=objDSet.Tables[strtablename].NewRow();
55 objXmlReader.MoveToFirstAttribute();
56 สำหรับ(int j=0;j
58 objrow[j]=objXmlReader.Value.ToString();
59 objXmlReader.MoveToNextAttribute();
60 }
61 objDSet.Tables[strtablename].Rows.Add(objrow);
62 }
63 แตก;
64}
65 }
66 //แสดงตารางข้อมูลที่ถ่ายโอน
67 DataGrid1.DataSource=objDSet.Tables[strtablename];
68 DataGrid1.DataBind();
69 }ยังไม่ได้เขียนโค้ดสำหรับอัปเดตข้อมูลไปยังฐานข้อมูลด้วยตนเอง^_^