一. 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文件并形成不同的菜单

ASP.NET+SQL Server利用XML实现动态菜单XmlDataSource设置
ASP.NET+SQL Server利用XML实现动态菜单
<asp:XmlDataSource ID="XmlDataSource1"   runat="server" DataFile="~/Test/XMLFile.xml"></asp:XmlDataSource>
ASP.NET+SQL Server利用XML实现动态菜单导航文件
ASP.NET+SQL Server利用XML实现动态菜单
<?xml version="1.0" encoding="utf-8" ?>
ASP.NET+SQL Server利用XML实现动态菜单
<menu   title="导航" description="">
ASP.NET+SQL Server利用XML实现动态菜单
<menuItem url="http://www.baidu.com" title="网易" description=""/>
ASP.NET+SQL Server利用XML实现动态菜单
<menuItem url="http://www.google.cn" title="新浪" description="" />
ASP.NET+SQL Server利用XML实现动态菜单
<menuItem url="http://www.163.com" title="126" description=""/>
ASP.NET+SQL Server利用XML实现动态菜单
<menuItem url="http://www.126.com" title="其它" description=""/>
ASP.NET+SQL Server利用XML实现动态菜单
</menu>
ASP.NET+SQL Server利用XML实现动态菜单asp:menu中的属性定义
ASP.NET+SQL Server利用XML实现动态菜单
<asp:Menu ID="Menu1" runat="server" Orientation="Horizontal" DataSourceID="XmlDataSource1"
ASP.NET+SQL Server利用XML实现动态菜单StaticDisplayLevels
="2" >
ASP.NET+SQL Server利用XML实现动态菜单
<DataBindings>
ASP.NET+SQL Server利用XML实现动态菜单
<asp:MenuItemBinding DataMember="menu" Depth="0" TextField="title"   />
ASP.NET+SQL Server利用XML实现动态菜单
<asp:MenuItemBinding DataMember="menuItem" Depth="1" NavigateUrlField="url" TextField="title" />
ASP.NET+SQL Server利用XML实现动态菜单
</DataBindings>
ASP.NET+SQL Server利用XML实现动态菜单
</asp:Menu>
ASP.NET+SQL Server利用XML实现动态菜单

 
导航文件
<?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属性设置了一开始显示的时候最大显示的层级


相关文章:

  • 2021-09-21
  • 2021-08-17
  • 2022-12-23
  • 2022-12-23
  • 2022-12-23
  • 2021-11-04
  • 2021-09-15
  • 2021-08-02
猜你喜欢
  • 2022-12-23
  • 2022-12-23
  • 2022-12-23
  • 2022-12-23
  • 2022-12-23
  • 2022-12-23
  • 2022-01-25
相关资源
相似解决方案