• C# 生成XML


    代码下载

    表结构:

    USE [NewHyeySaleData]
    GO
    /****** 对象:  Table [dbo].[YwHyDrugCategory]    脚本日期: 03/26/2011 18:35:34 ******/
    SET ANSI_NULLS ON
    GO
    SET QUOTED_IDENTIFIER ON
    GO
    CREATE TABLE [dbo].[YwHyDrugCategory](
    	[Id] [int] IDENTITY(1,1) NOT NULL,
    	[ProductName] [nvarchar](50) NULL,
    	[Component] [nvarchar](50) NULL,
    	[Dosageform] [nvarchar](50) NULL,
    	[FirstCategory] [nvarchar](50) NULL,
    	[FunctionSys] [nvarchar](50) NULL,
    	[SecondCategory] [nvarchar](50) NULL,
    	[MajorFunction] [nvarchar](255) NULL,
    	[ExclusiveProduct] [tinyint] NULL,
    	[InsuranceProduct] [tinyint] NULL,
    	[PrimaryProduct] [tinyint] NULL,
    	[OTC] [nvarchar](5) NULL,
    	[ProtectProduct] [tinyint] NULL,
     CONSTRAINT [PK_YwHyDrugCategory] PRIMARY KEY CLUSTERED 
    (
    	[Id] ASC
    )WITH (PAD_INDEX  = OFF, STATISTICS_NORECOMPUTE  = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS  = ON, ALLOW_PAGE_LOCKS  = ON) ON [PRIMARY]
    ) ON [PRIMARY]
    
    GO
    EXEC sys.sp_addextendedproperty @name=N'MS_Description', @value=N'产品名' , @level0type=N'SCHEMA',@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'YwHyDrugCategory', @level2type=N'COLUMN',@level2name=N'ProductName'
    GO
    EXEC sys.sp_addextendedproperty @name=N'MS_Description', @value=N'成份' , @level0type=N'SCHEMA',@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'YwHyDrugCategory', @level2type=N'COLUMN',@level2name=N'Component'
    GO
    EXEC sys.sp_addextendedproperty @name=N'MS_Description', @value=N'剂型' , @level0type=N'SCHEMA',@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'YwHyDrugCategory', @level2type=N'COLUMN',@level2name=N'Dosageform'
    GO
    EXEC sys.sp_addextendedproperty @name=N'MS_Description', @value=N'大类' , @level0type=N'SCHEMA',@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'YwHyDrugCategory', @level2type=N'COLUMN',@level2name=N'FirstCategory'
    GO
    EXEC sys.sp_addextendedproperty @name=N'MS_Description', @value=N'治疗系统' , @level0type=N'SCHEMA',@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'YwHyDrugCategory', @level2type=N'COLUMN',@level2name=N'FunctionSys'
    GO
    EXEC sys.sp_addextendedproperty @name=N'MS_Description', @value=N'亚类' , @level0type=N'SCHEMA',@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'YwHyDrugCategory', @level2type=N'COLUMN',@level2name=N'SecondCategory'
    GO
    EXEC sys.sp_addextendedproperty @name=N'MS_Description', @value=N'功能主治' , @level0type=N'SCHEMA',@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'YwHyDrugCategory', @level2type=N'COLUMN',@level2name=N'MajorFunction'
    GO
    EXEC sys.sp_addextendedproperty @name=N'MS_Description', @value=N'独家品种 1是0否' , @level0type=N'SCHEMA',@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'YwHyDrugCategory', @level2type=N'COLUMN',@level2name=N'ExclusiveProduct'
    GO
    EXEC sys.sp_addextendedproperty @name=N'MS_Description', @value=N'医保药物  1是0否' , @level0type=N'SCHEMA',@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'YwHyDrugCategory', @level2type=N'COLUMN',@level2name=N'InsuranceProduct'
    GO
    EXEC sys.sp_addextendedproperty @name=N'MS_Description', @value=N'基本药物 1是0否' , @level0type=N'SCHEMA',@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'YwHyDrugCategory', @level2type=N'COLUMN',@level2name=N'PrimaryProduct'
    GO
    EXEC sys.sp_addextendedproperty @name=N'MS_Description', @value=N'OTC 0否' , @level0type=N'SCHEMA',@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'YwHyDrugCategory', @level2type=N'COLUMN',@level2name=N'OTC'
    GO
    EXEC sys.sp_addextendedproperty @name=N'MS_Description', @value=N'中药保护品种 1是0否' , @level0type=N'SCHEMA',@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'YwHyDrugCategory', @level2type=N'COLUMN',@level2name=N'ProtectProduct'
    

    数据:

    中药	妇科用药    妇科洗液
    中药	补益药	      补血药
    中药	补益药	      补血药
    中药	补益药      补血药
    中药	补益药	     补血药
    中药	补益药	     补血药
    中药	补益药     补血药
    中药	补益药	     补血药
    中药	补益药     补血药
    中药	补益药     补血药
    中药	补益药	     补血药
    中药	补益药	     补血药
    中药	补益药	     补血药
    

    查询:

    select FirstCategory from YwHyDrugCategory group by FirstCategory
    
    select  FunctionSys from YwHyDrugCategory where FirstCategory = '化学药品' group by FunctionSys
    
    select  FunctionSys from YwHyDrugCategory where FirstCategory = '中药' group by FunctionSys
    
    
    
    select SecondCategory from YwHyDrugCategory where FirstCategory = '中药' and FunctionSys='中药注射剂'  group by SecondCategory 
    

    C#:

    using System;
    using System.Collections.Generic;
    using System.ComponentModel;
    using System.Data;
    using System.Drawing;
    using System.Linq;
    using System.Text;
    using System.Windows.Forms;
    using System.Data.SqlClient;
    using System.Xml;
    
    namespace WindowsFormsAppXML
    {
        public partial class Form1 : Form
        {
            public Form1()
            {
                InitializeComponent();
            }
    
            private void button1_Click(object sender, EventArgs e)
            {
                try
                {
                    //建立连接,将表名及对应表明的字段放入dataset中,
                    string strcon = "Data Source=192.168.1.2;Initial Catalog=NewHyeySaleData;Persist Security Info=True;User ID=sa;Password=hyey-20060705;Connect Timeout=3000;";
                    using (SqlConnection con = new SqlConnection())
                    {
                        con.ConnectionString = strcon;
                        if (con.State == ConnectionState.Closed)
                            con.Open();
                        SqlCommand cmd;
                        SqlDataAdapter da = new SqlDataAdapter();
                        DataSet ds = new DataSet();
                        this.label1.Text = "生成药品分类XML文件";
    
                        //FirstCategory
                        string strFirst = "select FirstCategory from YwHyDrugCategory group by FirstCategory";
                        cmd = new SqlCommand(strFirst, con);
                        da.SelectCommand = cmd;
                        da.Fill(ds, "FirstCategory");
    
                        if (ds != null && ds.Tables[0].Rows.Count > 0)
                        {
                            XmlDocument xmldoc = new XmlDocument();
                            XmlElement root = xmldoc.CreateElement("YwHyDrugCategory");
                            xmldoc.AppendChild(root);
                            foreach (DataRow item in ds.Tables[0].Rows)
                            {
    
                                XmlElement FirstCategory = xmldoc.CreateElement("FirstCategory");
                                XmlAttribute fname = xmldoc.CreateAttribute("name");
                                fname.Value = item["FirstCategory"].ToString();
                                FirstCategory.Attributes.Append(fname);
                                root.AppendChild(FirstCategory);
    
                                string strSecond = "select  FunctionSys from YwHyDrugCategory where FirstCategory = '" + item["FirstCategory"].ToString().Trim() + "' group by FunctionSys";
                                cmd = new SqlCommand(strSecond, con);
                                da.SelectCommand = cmd;
                                DataSet SecondDs = new DataSet();
                                da.Fill(SecondDs, "FunctionSys");
                                if (SecondDs != null && SecondDs.Tables[0].Rows.Count > 0)
                                {
                                    foreach (DataRow row in SecondDs.Tables[0].Rows)
                                    {
                                        XmlElement FunctionSys = xmldoc.CreateElement("FunctionSys");
                                        XmlAttribute sname = xmldoc.CreateAttribute("name");
                                        sname.Value = row["FunctionSys"].ToString();
                                        FunctionSys.Attributes.Append(sname);
                                        FirstCategory.AppendChild(FunctionSys);
    
                                        string strThird = "select  SecondCategory from YwHyDrugCategory where FirstCategory = '" + item["FirstCategory"].ToString().Trim() + "'and FunctionSys='" + row["FunctionSys"].ToString().Trim() + "'  group by SecondCategory";
                                        cmd = new SqlCommand(strThird, con);
                                        da.SelectCommand = cmd;
                                        DataSet ThirdDs = new DataSet();
                                        da.Fill(ThirdDs, "SecondCategory");
    
                                        if (ThirdDs != null && ThirdDs.Tables[0].Rows.Count > 0)
                                        {
                                            foreach (DataRow rowt in ThirdDs.Tables[0].Rows)
                                            {
                                                XmlElement SecondCategory = xmldoc.CreateElement("SecondCategory");
                                                XmlAttribute tname = xmldoc.CreateAttribute("name");
                                                tname.Value = rowt["SecondCategory"].ToString();
                                                SecondCategory.Attributes.Append(tname);
                                                FunctionSys.AppendChild(SecondCategory);
                                            }
                                            ThirdDs.Dispose();
                                            ThirdDs.Clear();
                                        }
    
                                    }
    
                                    SecondDs.Dispose();
                                    SecondDs.Clear();
                                }
    
                            }
                            ds.Dispose();
                            ds.Clear();
                            da.Dispose();
                            xmldoc.Save(@"E:\生成药品分类XML文件.xml");
                            this.label1.Text += "  XML文件路径-E:生成药品分类XML文件.xml";
                        }
                    }
                }
                catch (Exception ex)
                {
                    throw new Exception(ex.Message);
                }
                finally
                {
                    ;
                }
                
               
            }
        }
    }
    
  • 相关阅读:
    数据分析实战(4)-Kaggle-谷歌数据分析
    东财主力资金异动数据探索分析
    数据分析实战(2)-Kaggle-共享单核数据分析
    爬虫框架Scrapy 之(二) --- scrapy文件介绍
    爬虫框架Scrapy 之(一) --- scrapy整体认识
    atomic
    坑爹的缩写
    一些坑爹的结构体
    sensor hub
    android p 常识
  • 原文地址:https://www.cnblogs.com/Leo_wl/p/1996451.html
Copyright © 2020-2023  润新知