SQL Server XML查询工具

导读:SQL Server 提供了一个非常好用的客户端检索工具-查询分析器,但是美中不足的是查询分析器无法对XML查询给出很好的结果,用户无法完整查看XML结果集。上学期给IBM电子商务班讲XML与WebService时,不得不自己写了一个程序执行XML检索。虽然程序实在有些简陋,但毕竟可以完成课堂演示的要求。

程序主体是通过sqlCommand的ExecuteXmlReader方法完成的。我添加了一些对特殊字符的MIME编码(这一部分应当有现成代码,不过我没有找到,只好自己将就着写了),以及XML格式处理功能。先贴上一些代码,具体可以自己下载后看。希望多提宝贵意见。

关键代码:

  1.  
  2. private void btnSearch_Click(object sender, System.EventArgs e)  
  3. {  
  4.  
  5.   string s = "<?xml version="1.0" encoding="utf-8"?><SearchResult>";  
  6.   string endWith = "";  
  7.  
  8.   // 创建连接对象实例  
  9.   SqlConnection myConnection =   
  10.       new SqlConnection(ConfigurationSettings.AppSettings["ConnectString"]);  
  11.   SqlCommand myCommand = new SqlCommand(txtCondition.Text, myConnection);  
  12.   myCommand.CommandType = CommandType.Text;  
  13.  
  14.   // 创建 XML Reader,并读取数据到 XML 字符串中  
  15.   XmlTextReader xmlReader = null;  
  16.  
  17.   try  
  18.   {  
  19.     // 打开数据库连接  
  20.     myConnection.Open();  
  21.  
  22.     // 运行存储过程并初始化 XmlReader  
  23.     xmlReader = (XmlTextReader)myCommand.ExecuteXmlReader();  
  24.  
  25.     while(xmlReader.Read())  
  26.     {  
  27.       if (xmlReader.NodeType == XmlNodeType.Element)   
  28.       {  
  29.         s += "<" + xmlReader.Name;  
  30.           
  31.         if (xmlReader.IsEmptyElement)   
  32.           endWith ="/";  
  33.         else  
  34.           endWith = "";  
  35.           
  36.         if (xmlReader.HasAttributes)   
  37.         {  
  38.           while(xmlReader.MoveToNextAttribute())  
  39.             s += " " + xmlReader.Name + "="" + ToMIMEString(xmlReader.Value) + """;  
  40.         }  
  41.  
  42.         s += endWith + ">";  
  43.           
  44.       }  
  45.       else if (xmlReader.NodeType == XmlNodeType.EndElement)  
  46.       {  
  47.         s += "</" + xmlReader.Name + ">";  
  48.       }   
  49.       else if (xmlReader.NodeType == XmlNodeType.Text)   
  50.       {  
  51.         if (xmlReader.Value.Length != 0)   
  52.         {  
  53.           s += ToMIMEString(xmlReader.Value);  
  54.         }  
  55.       }  
  56.     }  
  57.  
  58.     s+="</SearchResult>";  
  59.     txtResult.Text = s;          
  60.   }  
  61.   catch (Exception)  
  62.   {  
  63.     txtResult.Text = "Got an error";  
  64.     //不处理任何错误  
  65.   }  
  66.   finally  
  67.   {  
  68.     // 关闭数据库连接并清理 reader 对象  
  69.     myConnection.Close();  
  70.     xmlReader = null;  
  71.   }  
  72.  
  73.   XmlDocument xmlDoc = new XmlDocument();  
  74.   xmlDoc.LoadXml(s);  
  75.   //=============================================  
  76.   //将结果写入  
  77.   //=============================================  
  78.   try  
  79.   {  
  80.     MemoryStream ms = new MemoryStream();  
  81.     XmlTextWriter xtw = new XmlTextWriter(ms, Encoding.UTF8);  
  82.     xtw.Formatting = Formatting.Indented;  
  83.     xmlDoc.Save(xtw);  
  84.     byte[] buf = ms.ToArray();  
  85.     txtResult.Text = Encoding.UTF8.GetString(buf,0,buf.Length);  
  86.     xtw.Close();  
  87.   }  
  88.   catch  
  89.   {  
  90.     txtResult.Text = "出现错误!";  
  91.   }  
  92.  
  93. }  
  94.     
  95. private string ToMIMEString(string s)  
  96. {  
  97.   StringBuilder sb = new StringBuilder();  
  98.  
  99.   char[] ssource = s.ToCharArray();  
  100.   foreach(char c in source)  
  101.   {  
  102.     if(c=='<')  
  103.       sb.Append("&lt;");  
  104.     else if(c=='&')  
  105.       sb.Append("&amp;");  
  106.     else if(c=='>')  
  107.       sb.Append("&gt;");  
  108.     else if(c=='"')  
  109.       sb.Append("&quot;");  
  110.     else  
  111.       sb.Append(c);  
  112.   }  
  113.   return sb.ToString();  

数据库连接可以通过修改 XML_Search.exe.config 文件实现。程序对本地默认SQL实例的Northwind数据库执行XML查询。

【编辑推荐】

  1. SQL Server XML 入门的18句话
  2. SQL Server管理工具的升级
  3. 深入讨论SQL Server 表的主键问题
  4. SQL Server数据库中对图片进行保存和输出

文章来源网络,作者:运维,如若转载,请注明出处:https://shuyeidc.com/wp/307823.html<

(0)
运维的头像运维
上一篇2025-05-27 07:27
下一篇 2025-05-27 07:28

相关推荐

  • 个人主题怎么制作?

    制作个人主题是一个将个人风格、兴趣或专业领域转化为视觉化或结构化内容的过程,无论是用于个人博客、作品集、社交媒体账号还是品牌形象,核心都是围绕“个人特色”展开,以下从定位、内容规划、视觉设计、技术实现四个维度,详细拆解制作个人主题的完整流程,明确主题定位:找到个人特色的核心主题定位是所有工作的起点,需要先回答……

    2025-11-20
    0
  • 社群营销管理关键是什么?

    社群营销的核心在于通过建立有温度、有价值、有归属感的社群,实现用户留存、转化和品牌传播,其管理需贯穿“目标定位-内容运营-用户互动-数据驱动-风险控制”全流程,以下从五个维度展开详细说明:明确社群定位与目标社群管理的首要任务是精准定位,需明确社群的核心价值(如行业交流、产品使用指导、兴趣分享等)、目标用户画像……

    2025-11-20
    0
  • 香港公司网站备案需要什么材料?

    香港公司进行网站备案是一个涉及多部门协调、流程相对严谨的过程,尤其需兼顾中国内地与香港两地的监管要求,由于香港公司注册地与中国内地不同,其网站若主要服务内地用户或使用内地服务器,需根据服务器位置、网站内容性质等,选择对应的备案路径(如工信部ICP备案或公安备案),以下从备案主体资格、流程步骤、材料准备、注意事项……

    2025-11-20
    0
  • 如何企业上云推广

    企业上云已成为数字化转型的核心战略,但推广过程中需结合行业特性、企业痛点与市场需求,构建系统性、多维度的推广体系,以下从市场定位、策略设计、执行落地及效果优化四个维度,详细拆解企业上云推广的实践路径,精准定位:明确目标企业与核心价值企业上云并非“一刀切”的方案,需先锁定目标客户群体,提炼差异化价值主张,客户分层……

    2025-11-20
    0
  • PS设计搜索框的实用技巧有哪些?

    在PS中设计一个美观且功能性的搜索框需要结合创意构思、视觉设计和用户体验考量,以下从设计思路、制作步骤、细节优化及交互预览等方面详细说明,帮助打造符合需求的搜索框,设计前的规划明确使用场景:根据网站或APP的整体风格确定搜索框的调性,例如极简风适合细线条和纯色,科技感适合渐变和发光效果,电商类则可能需要突出搜索……

    2025-11-20
    0

发表回复

您的邮箱地址不会被公开。必填项已用 * 标注