动态网站制作指南 [  QQ表情  ]
[ 投票调查 ]
[ 企业邮箱 ]
[ 网站空间 ]
网络编程 | 站长之家 | 网页制作 | 图形图象 | 操作系统 | 冲浪宝典 | 软件教学 | 网络办公 | 手机学院 | 邮件系统 | 网络安全 | 认证考试
ASP源码 | .Net源码 | PHP源码 | JSP源码 | JAVA源码 | CGI源码 | VB源码 | C++源码 | Delphi源码 | PB源码 | VF源码 | 汇编 | 服务器
Firefox | IE | Maxthon | 迅雷 | 电驴 | BitComet | FlashGet | QQ | QQ空间 | Vista | 输入法 | Ghost | Word | Excel | wps | Powerpoint
asp | .net | php | jsp | Sql | c# | Ajax | xml | Dreamweaver | FrontPages | Javascript | css | photoshop | fireworks | Flash | Cad | Discuz!
当前位置 > 网站建设学院 > 网络编程 > C#应用
Tag:注入,存储过程,分页,安全,优化,xmlhttp,fso,jmail,application,session,防盗链,stream,无组件,组件,md5,乱码,缓存,加密,验证码,算法,cookies,ubb,正则表达式,水印,索引,日志,压缩,base64,url重写,上传,控件,Web.config,JDBC,函数,内存,PDF,迁移,结构,破解,编译,配置,进程,分词,IIS,Apache,Tomcat,phpmyadmin,Gzip,触发器,socket
网络编程:ASP教程,ASP.NET教程,PHP教程,JSP教程,C#教程,数据库,XML教程,Ajax,Java,Perl,Shell,VB教程,Delphi,C/C++教程,软件工程,J2EE/J2ME,移动开发
文章搜索服务
邮件订阅
输入你的邮件地址,
你将不会错过任何关于:
[ C#应用 ]的信息

本月文章推荐
.如何让数据访问过程更透明.
.获取cpu序列号,硬盘ID,网卡MAC地.
.C#中接口的深入浅出.
.C#计算20902个汉字的拼音首字母 .
.C#中四种进程或线程同步互斥的控.
.C#下的查杀进程.
.几个C#编程的小技巧.
.C#列出局域网中可用SQL Server服.
.两个获取http页面的c#函数.
.如何用C#编写文本编辑器.
.通过COM来获取CookieContainer,简.
.DateDiff in c#(转载:DateDiff 方.
.使用C#在进度条中显示复制文件的.
.在c#中实现3层架构.
.C#消息队列应用程序 -2.
.C#中Dispose和Close的区别.
.关于C#和C++的重载(Overload)、.
.发送邮件程序(Csharp2005).
.用c#监控网络流量.
.C#中调用Windows API的要点.

如何用C#将数据库中的记录制成XML

发表日期:2004-12-10 |


    以前在一个公司项目中要用数据库中的记录生成相应的XML文件[主要是为了提高访问速度],但由于当时资料的缺乏,在开发过程中遇到了不过的困难,好在最终完成了工作,我在这里把当时其中的一个功能函数列出来,其于的函数大同小意,希望兄弟们以后在遇到这样的问题时不象我当初一样再吃苦头.
using System;
using System.Collections;
using System.ComponentModel;
using System.Data;
using System.Diagnostics;
using System.Web;
using System.Web.Services;
using System.Xml;
using System.Data.SqlClient;
using System.Configuration;
using System.Text;
using System.Xml.Xsl;
using System.IO;

namespace admin
{
 /// <summary>
 /// CreateXML 的摘要说明。
 /// </summary>
 ///
  [System.Web.Services.WebService(Namespace="http://..../admin/createxml.asmx",Description="生成或更新星迷俱乐部中的xml文件")]

 public class CreateXML : System.Web.Services.WebService
 {
  public CreateXML()
  {
   //CODEGEN: 该调用是 ASP.NET Web 服务设计器所必需的
   InitializeComponent();
  }

  #region 组件设计器生成的代码
 
  //Web 服务设计器所必需的
  private IContainer components = null;
   
  /// <summary>
  /// 设计器支持所需的方法 - 不要使用代码编辑器修改
  /// 此方法的内容。
  /// </summary>
  private void InitializeComponent()
  {
  }

  /// <summary>
  /// 清理所有正在使用的资源。
  /// </summary>
  protected override void Dispose( bool disposing )
  {
   if(disposing && components != null)
   {
    components.Dispose();
   }
   base.Dispose(disposing); 
  }
 
  #endregion

  [WebMethod]
  public string CreateClubXMLByID(String ID)
  { 
   DateTime filenamedate=DateTime.Now;
   CreatePath("..\\"+filenamedate.Year.ToString(),filenamedate.Month.ToString()+"_"+filenamedate.Day.ToString());//按时期生成相应的时期型文件夹
   string filename=Server.MapPath("..\\"+filenamedate.Year.ToString()+"\\"+filenamedate.Month.ToString()+"_"+filenamedate.Day.ToString()+"\\Club"+ID.Trim()+".xml"); 
   XmlTextWriter PicXmlWriter = null;
   Encoding GB = Encoding.GetEncoding("GB2312");
   PicXmlWriter = new XmlTextWriter (filename,GB);
  
   try
   {
    string strConn=ConfigurationSettings.AppSettings["starclub"];
    
    String SQLStatement="SELECT * FROM  club where id="+ID.ToString().Trim();
    SqlConnection myConnection= new SqlConnection(strConn);
    SqlDataAdapter myCommand = new SqlDataAdapter(SQLStatement,myConnection);
    DataSet myDataSet;
    myCommand.SelectCommand.CommandType=CommandType.Text;
    myDataSet = new DataSet();
    myCommand.Fill(myDataSet, "MyTable");
 
    PicXmlWriter.Formatting = Formatting.Indented;
    PicXmlWriter.Indentation= 6;
    PicXmlWriter.Namespaces = false;
    PicXmlWriter.WriteStartDocument();
    //PicXmlWriter.WriteDocType("文档类型", null, ".xml", null);
    //PicXmlWriter.WriteComment("按在数据库中记录的ID进行记录读写");
    PicXmlWriter.WriteProcessingInstruction("xml-stylesheet","type='text/xsl' href='../../xsl/1.xsl'") ;  //写入用于解释的XSL文件名
    PicXmlWriter.WriteStartElement("","club","");
    foreach(DataRow r in myDataSet.Tables[0].Rows)   //依次取出所有行
    {
      PicXmlWriter.WriteStartElement("","record","");
     foreach(DataColumn c in myDataSet.Tables[0].Columns)  //依次找出当前记录的所有列属性
     {
      if ((c.Caption.ToString()!="pic"))
      {
       PicXmlWriter.WriteStartElement("",c.Caption.ToString().Trim(),"");  //写入字段名
       PicXmlWriter.WriteString(r[c].ToString().Trim());   //写入数据
       PicXmlWriter.WriteEndElement();
      }
      else
      {
       PicXmlWriter.WriteStartElement("",c.Caption.ToString().Trim(),"");
       string [] pic=r[c].ToString().Trim().Split('|');
       for (int i=0;i<pic.Length;i++)
       {
       
        if (pic[i].Trim()!="")   //数据库中图片字段的插入格式为:  文件名,高,宽|  以此类推. 例如  no.jpg,132,142|
        {
         PicXmlWriter.WriteStartElement("",c.Caption.ToString().Trim()+"s","");
         string [] picstr=pic[i].Split(',');
         PicXmlWriter.WriteStartElement("","picstr","");
         PicXmlWriter.WriteString(picstr[0].Trim().Trim());
         PicXmlWriter.WriteEndElement();

         PicXmlWriter.WriteStartElement("","height","");
         PicXmlWriter.WriteString(picstr[1].Trim().Trim());
         PicXmlWriter.WriteEndElement();

         PicXmlWriter.WriteStartElement("","width","");
         PicXmlWriter.WriteString(picstr[1].Trim().Trim());
         PicXmlWriter.WriteEndElement();
        
         PicXmlWriter.WriteStartElement("","comment","");
         PicXmlWriter.WriteString(pic[++i].Trim().Trim());
         PicXmlWriter.WriteEndElement();
         PicXmlWriter.WriteEndElement();
        }
        else
        {
         i++;
        }
       
       }
       PicXmlWriter.WriteEndElement();
      
      }
     }
     PicXmlWriter.WriteEndElement();
    }
               
    PicXmlWriter.WriteEndElement();
    PicXmlWriter.Flush();
  
   }
   catch (Exception e)
   {
    Console.WriteLine ("异常:{0}", e.ToString());
   }

   finally
   {
    Console.WriteLine();
    Console.WriteLine("对文件 {0} 的处理已完成。", ID);
    if (PicXmlWriter != null)
     PicXmlWriter.Close();
    //关闭编写器
    if (PicXmlWriter != null)
     PicXmlWriter.Close();
   }
   return filenamedate.Year.ToString()+"\\"+filenamedate.Month.ToString()+"_"+filenamedate.Day.ToString()+"\\Club"+ID.Trim()+".xml";
  }
 

public void CreatePath(string yearpath,string monthdaycurrent)
  {  
   string path=Server.MapPath("");
   if (Directory.Exists(path+yearpath))
   {
    if (Directory.Exists(path+yearpath+monthdaycurrent))
    {
     ;
    }
    else
    {
     Directory.CreateDirectory(path+"\\"+yearpath+"\\"+monthdaycurrent);
    }
   }
   else
   {
    Directory.CreateDirectory(path+"\\"+yearpath+"\\"+monthdaycurrent);
   }

  }

上一篇:C#实现的根据年月日计算星期几的函数 人气:16485
下一篇:利用C#实现标准的 Dispose模式 人气:10907
浏览全部C#的内容 Dreamweaver插件下载 网页广告代码 2009年新年快乐
  最新网站源码 最新软件下载
2009-1-8 SMF论坛Simple Machines Forum v
2009-1-8 SMF论坛Simple Machines Forum v
2009-1-8 深度学习(asp)拼图游戏 v0.2.3
2009-1-8 纵横B2B电子商务系统XYECS!B2B v
2009-1-8 马克斯CMS v2.0 bulid 090105 be
2009-1-8 淘宝妈妈_淘客推广系统 v1.0
2009-1-8 淄博某企业网站源码
2009-1-8 silverlight制作的手机功能演示
2009-1-8 大型WEB束鹿三国游戏 特别版
2009-1-7 汉字任意点阵字库制作软件 V2.6
2009-1-7 书法家毛笔字生成器 Ougishi V4.
2009-1-7 字体修复大师
2009-1-7 微雨字体效果浏览器 1.0
2009-1-7 字体试衣间 2.9.6.8 豪华版
2008-11-29 Tencent Traveler 4.4
2008-11-29 龙卷风网络收音机 v3.0.0.0
2008-11-29 Intel Chipset Software Install
2008-11-29 TweakVI 1.0 Build 1100
  发表评论
姓 名: 验证码: [ 查看评论 ]
内 容:
站长工具:网站收录查询 | Google PR查询 | ALEXA排名查询 | CSS在线编辑器 | OPEN参数生成器 | 弹出式窗口代码产生器 | 密码登录生成器 | 在线按钮生成器 | Meta标签生成器 | 多色彩特效字代码生成器 | 网页代码调试器 | 在线FTP登陆 | Flash取色器 | 配色代码对照表 | 配色辞典 | CSS生成器 | 广告代码 | 框架网页代码生成器 | js/vbs加密 | md5加密 | 进制转换 | UTF-8 转换工具 | 在线调色板 | Html转换js | Html转换asp | Html转换php | Html转换perl
实用工具:汉字翻译拼音 | 拼音字典 | 符号对照表 | 个税计算 | 公积金贷款计算 | 购房银行按揭利率计算 | 实时汇率查询换算 | 经典小工具 | 汉字简繁转换 | 普通单位换算 | 公制单位换算 | 生辰老黄历 | 国内电话区号 | 国家代码与域名缩写 | 文字加密解密 | 元素周期表 | 健康查询 | 世界时间 | 全国各地车牌查询 | 全国车辆交通违章查询 | 万年历 | 二十四节气 | 汉字横竖排版 | 手机号码查询 | 计算器 | ip搜索
业务联系 | 广告刊登 | 频道合作 | 投稿荐稿 | 联系方式 | 加入收藏 | RSS订阅
Copyright © 2000-2009 www.knowsky.com All rights reserved | 沪ICP备05001343号
ホームページ制作 不動産検索システム 求人情報
防水工事·改修工事 フットサル大会 探偵
SEO対策 中国語教室 ホームページ作成