国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 學院 > 開發設計 > 正文

如何用C#將數據庫中的記錄制成XML

2019-11-18 19:28:28
字體:
來源:轉載
供稿:網友

    以前在一個公司項目中要用數據庫中的記錄生成相應的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",Descr

 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()+"http://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()+"http://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+"http://"+monthdaycurrent);
    }
   }
   else
   {
    Directory.CreateDirectory(path+"//"+yearpath+"http://"+monthdaycurrent);
   }

  }


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 嘉善县| 安西县| 甘泉县| 商河县| 江津市| 海晏县| 开平市| 綦江县| 锡林郭勒盟| 富宁县| 香港| 陵水| 东丽区| 奉贤区| 丹东市| 克什克腾旗| 隆德县| 柯坪县| 涡阳县| 宿松县| 安塞县| 如东县| 城固县| 靖宇县| 通城县| 泰兴市| 诸暨市| 晴隆县| 闵行区| 黑龙江省| 萨迦县| 哈尔滨市| 和政县| 呼伦贝尔市| 武胜县| 柳江县| 霍山县| 保康县| 裕民县| 秀山| 玉门市|