一. XML資料類型SQL Server 的存取(SQL Server 2005或2008)
1. 將XML類型的資料存入DB
註: [SPPRF]在DB中的類型要是XML類型的。
SqlParameter sp = new SqlParameter();
sp.SqlDbType = SqlDbType.Xml;
System.Xml.XmlReader xr = System.Xml.XmlReader.Create(@"E:\a.xml");
string strSqlConn = "#########";
string strSelectSQL = "INSERT INTO [QAUSER]([USRID],[USPWD],[SPPRF]) ";
strSelectSQL += "VALUES('test','123',@xml)";
SqlConnection SqlConn = new SqlConnection(strSqlConn);
SqlCommand SqlCmd = new SqlCommand(strSelectSQL, SqlConn);
SqlCmd.Parameters.Add("@xml", SqlDbType.Xml).Value = xr;
SqlConn.Open();
SqlCmd.ExecuteNonQuery();
2. 取出XML
二. 將XML綁定ASP.NET 中的控制項
使用XmlDataSource動態地載入xml檔案並形成不同的菜單
XmlDataSource設定
<asp:XmlDataSource ID="XmlDataSource1" runat="server" DataFile="~/Test/XMLFile.xml"></asp:XmlDataSource>
導航檔案
<?xml version="1.0" encoding="utf-8" ?>
<menu title="導航" description="">
<menuItem url="http://www.baidu.com" title="網易" description=""/>
<menuItem url="http://www.google.cn" title="新浪" description="" />
<menuItem url="http://www.163.com" title="126" description=""/>
<menuItem url="http://www.126.com" title="其它" description=""/>
</menu>
asp:menu中的屬性定義
<asp:Menu ID="Menu1" runat="server" Orientation="Horizontal" DataSourceID="XmlDataSource1"
StaticDisplayLevels="2" >
<DataBindings>
<asp:MenuItemBinding DataMember="menu" Depth="0" TextField="title" />
<asp:MenuItemBinding DataMember="menuItem" Depth="1" NavigateUrlField="url" TextField="title" />
</DataBindings>
</asp:Menu>
XmlDataSource設定
<asp:XmlDataSource ID="XmlDataSource1" runat="server" DataFile="~/Test/XMLFile.xml"></asp:XmlDataSource>
導航檔案
<?xml version="1.0" encoding="utf-8" ?>
<menu title="導航" description="">
<menuItem url="http://www.baidu.com" title="網易" description=""/>
<menuItem url="http://www.google.cn" title="新浪" description="" />
<menuItem url="http://www.163.com" title="126" description=""/>
<menuItem url="http://www.126.com" title="其它" description=""/>
</menu>
asp:menu中的屬性定義
<asp:Menu ID="Menu1" runat="server" Orientation="Horizontal" DataSourceID="XmlDataSource1"
StaticDisplayLevels="2" >
<DataBindings>
<asp:MenuItemBinding DataMember="menu" Depth="0" TextField="title" />
<asp:MenuItemBinding DataMember="menuItem" Depth="1" NavigateUrlField="url" TextField="title" />
</DataBindings>
</asp:Menu>
MenuItemBinding中定義出不同的層次來,並給datamemeber定義出資料來源來,比如說第一個層級datamember中的層次就是0層級,第二個層級的資料來源就是menuitem
由於第一個節點是根結點,一般不用設定NaviateUrlField這個屬性
StaticDisplayLevels屬性設定了一開始顯示的時候最大顯示的層級