强大的 将XML文件的数据导入到数据库的 程序 只需输入xml文件名即可自动创建

原创 2012年08月02日 15:38:49

通过网上查资料并经过多天整理好的一个程序,以供需要的朋友学习:

前台:

 

 

后台:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Data;
using System.Data.SqlClient;
using System.Configuration;

namespace XML
{
    public partial class tst : System.Web.UI.Page
    {
        protected DataSet dataSetXml;
        protected DataTable dataTableXml;
        protected string tableName;
        protected string strConn = ConfigurationManager.AppSettings["ConnectionString2"].ToString();
        protected void Page_Load(object sender, EventArgs e)
        {
           
        }
        protected void buttonSubmit_Click(object sender, EventArgs e)
        {
            Message.Text = "";
            dataSetXml = new DataSet();
            dataTableXml = new DataTable();
            try
            {
                dataSetXml.ReadXml(HttpContext.Current.Server.MapPath(textBoxXml.Text));//读取xml地址
                for (int i = 0; i < dataSetXml.Tables.Count;i++ ) {

                dataTableXml = dataSetXml.Tables[i];//循环取出所有的表
                }
             
                GridView1.DataSource = dataTableXml.DefaultView;//可查看所有表的数据
                GridView1.DataBind();
                tableName = textBoxXml.Text.Substring(0, textBoxXml.Text.Length - 4);

            }
            catch
            {
                Message.Text = "不能打开Xml文件或者是Xml文件格式错误";
            }
            if (dataTableXml.Rows.Count > 0)
            {
                TableCheck();
                TableInsert();
            }
        }
        /// <summary>
        /// 检查并创建表
        /// </summary>
        private void TableCheck()
        {
            SqlConnection conn = new SqlConnection(strConn);
            try
            {
                conn.Open();
                int count = 0;
                //conn.Open();
                DataTable schemaTable = conn.GetSchema("TABLES", new string[] { "asd", tableName });
                string sqlCmd = "";
                for (int j = 0; j < dataSetXml.Tables.Count; j++)//循环所有的表
                {
                    sqlCmd = "create table " + dataSetXml.Tables[j] + "(";//循环创建所有的表名

                if (schemaTable.Rows.Count < 1)
                {
                        
                     for (int i = 0; i <dataSetXml.Tables[j].Columns.Count; i++)
                      {
                          sqlCmd +=dataSetXml.Tables[j].Columns[i].ToString()+ " varchar(200),";//循环创建所有表的列名
                      }               
                 }
                    sqlCmd = sqlCmd.Substring(0, sqlCmd.Length - 1) + ")";//删除最后一个“,”符号                
                    SqlCommand createcmd = new SqlCommand();
                    createcmd.Connection = conn;
                    createcmd.CommandText = sqlCmd;
                    createcmd.ExecuteNonQuery();
                }
            }
            catch(Exception e)
            {
                Message.Text = e.Message;// "SQL命令或语句连接出问题";
            }
            finally
            {
                conn.Close();
            }
        }
        /// <summary>
        /// 对表进行插入数据操作
        /// </summary>
        private void TableInsert()
        {
            //OracleConnection conn = new OracleConnection(strConn);
            SqlConnection conn = new SqlConnection(strConn);
            try
            {
                conn.Open();
                for (int k = 0; k < dataSetXml.Tables.Count;k++ )//循环所有的表
                {
                    foreach (DataRow dr in dataSetXml.Tables[k].Rows)
                    {
                        string  sqlCmd = "Insert Into " + dataSetXml.Tables[k] + "(";//循环插入所有的表
                        for (int i = 0; i < dataSetXml.Tables[k].Columns.Count; i++)//循环所有表的列
                        {
                            sqlCmd += dataSetXml.Tables[k].Columns[i].ColumnName.ToString() + ",";//循环用‘,’隔开
                        }
                        sqlCmd = sqlCmd.Substring(0, sqlCmd.Length - 1) + ") Values(";
                        for (int j = 0; j< dataSetXml.Tables[k].Columns.Count; j++)//循环用‘‘’隔开
                        {
                            sqlCmd += "'" + dr[j].ToString() + "',";
                        }
                          sqlCmd = sqlCmd.Substring(0, sqlCmd.Length - 1) + ")";
                         SqlCommand cmd = new SqlCommand(sqlCmd, conn);
                        cmd.ExecuteNonQuery();
                        Message.Text = "Xml文件中的数据成功加载到数据库中!";
                    }
                }
        }
            catch(Exception e)
            {
                Message.Text = e.Message;//在添加数据时产生了错误!";
            }
            finally
            {
                conn.Close();
            }
        }   
    }
}

相关文章推荐

XML文件数据导入到数据库中

  • 2013年03月21日 18:22
  • 75KB
  • 下载

Java实现数据库数据生成XML文件的通用程序

转自http://tieba.baidu.com/p/136643159 原篇内容缺失,本篇对其进行整理,以备后用。 本篇使用dom解析。方法实现将查询结果集(ResultSet对象)和要生成的XML...

Python 将excel部分内容导入到XML文件

Python 将excel部分内容导入到XML文件 首先介绍下xlrd模块 准备工作. 安装xlrd模块    到python官网下载http://pypi.python.org/pypi/xlr...

oracle数据库的xml文件数据查询

  • 2010年12月23日 20:17
  • 1007B
  • 下载

读取xml文件数据到数据库

  • 2013年01月29日 18:35
  • 456B
  • 下载

在VS2010中利用百度地图Place API获取POI数据(XML文件方式存储),并导入mysql数据库

vs2010 Place API

将数据库数据以XML文件格式保存

  • 2007年09月10日 20:23
  • 34KB
  • 下载

【java】xml文件表建立及读取环境搭建并采用DOM4J完成XML文件导入到数据库

java一种简单的解析xml方法是用DOM进行解析, dom4j是一个Java的XML API,类似于jdom,用来读写XML文件的,dom4j用于处理xml是很常用的技术,本篇博客介绍xml文件表建...

读取数据库表数据转换成XML文件

  • 2011年06月08日 14:43
  • 15KB
  • 下载
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:强大的 将XML文件的数据导入到数据库的 程序 只需输入xml文件名即可自动创建
举报原因:
原因补充:

(最多只允许输入30个字)