在好例子网,分享、交流、成长!
您当前所在位置:首页C# 开发实例C#语言基础 → 将excel文件上传至sql2005数据库

将excel文件上传至sql2005数据库

C#语言基础

下载此实例
  • 开发语言:C#
  • 实例大小:0.20M
  • 下载次数:54
  • 浏览次数:327
  • 发布时间:2017-02-27
  • 实例类别:C#语言基础
  • 发 布 人:kid0824
  • 文件格式:.rar
  • 所需积分:5
 相关标签: 数据库 Excel 上传 文件 sql

实例介绍

【实例简介】

用于将.xls格式的excel文件上传至sql2005数据库

【实例截图】

【核心代码】

using System;
using System.Drawing;
using System.Collections;
using System.ComponentModel;
using System.Windows.Forms;
using System.Data;
using System.IO;
using System.Data.OleDb;

namespace ExcelToSQL2005
{
/// <summary>
/// Form1 的摘要说明。
/// </summary>
public class Form1 : System.Windows.Forms.Form
{
private System.Windows.Forms.OpenFileDialog openFileDialog1;
private System.Windows.Forms.TextBox textBox1;
private System.Windows.Forms.Button button1;
private System.Windows.Forms.DataGrid dataGrid1;
private System.Windows.Forms.Button button3;
private DataTable dtMessage = null;

/// <summary>
/// 必需的设计器变量。
/// </summary>
private System.ComponentModel.Container components = null;

public Form1()
{
//
// Windows 窗体设计器支持所必需的
//
InitializeComponent();

//
// TODO: 在 InitializeComponent 调用后添加任何构造函数代码
//
dtMessage = new DataTable();
dtMessage.Columns.Add("表名",typeof(string));
dtMessage.Columns.Add("是否创建表",typeof(string));
dtMessage.Columns.Add("是否导入数据",typeof(string));
dtMessage.Columns.Add("错误信息",typeof(string));
}

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

#region Windows 窗体设计器生成的代码
/// <summary>
/// 设计器支持所需的方法 - 不要使用代码编辑器修改
/// 此方法的内容。
/// </summary>
private void InitializeComponent()
{
this.openFileDialog1 = new System.Windows.Forms.OpenFileDialog();
this.textBox1 = new System.Windows.Forms.TextBox();
this.button1 = new System.Windows.Forms.Button();
this.dataGrid1 = new System.Windows.Forms.DataGrid();
this.button3 = new System.Windows.Forms.Button();
((System.ComponentModel.ISupportInitialize)(this.dataGrid1)).BeginInit();
this.SuspendLayout();
// 
// textBox1
// 
this.textBox1.Location = new System.Drawing.Point(16, 24);
this.textBox1.Name = "textBox1";
this.textBox1.ReadOnly = true;
this.textBox1.Size = new System.Drawing.Size(400, 21);
this.textBox1.TabIndex = 0;
this.textBox1.Text = "";
// 
// button1
// 
this.button1.Location = new System.Drawing.Point(437, 24);
this.button1.Name = "button1";
this.button1.TabIndex = 1;
this.button1.Text = "选择文件";
this.button1.Click = new System.EventHandler(this.button1_Click);
// 
// dataGrid1
// 
this.dataGrid1.DataMember = "";
this.dataGrid1.HeaderForeColor = System.Drawing.SystemColors.ControlText;
this.dataGrid1.Location = new System.Drawing.Point(16, 64);
this.dataGrid1.Name = "dataGrid1";
this.dataGrid1.ReadOnly = true;
this.dataGrid1.Size = new System.Drawing.Size(496, 352);
this.dataGrid1.TabIndex = 2;
// 
// button3
// 
this.button3.Location = new System.Drawing.Point(16, 432);
this.button3.Name = "button3";
this.button3.Size = new System.Drawing.Size(112, 23);
this.button3.TabIndex = 4;
this.button3.Text = "导入SQL2005";
this.button3.Click = new System.EventHandler(this.button3_Click);
// 
// Form1
// 
this.AutoScaleBaseSize = new System.Drawing.Size(6, 14);
this.ClientSize = new System.Drawing.Size(528, 470);
this.Controls.Add(this.button3);
this.Controls.Add(this.dataGrid1);
this.Controls.Add(this.button1);
this.Controls.Add(this.textBox1);
this.Name = "Form1";
this.Text = "ExcelToSQL2005";
((System.ComponentModel.ISupportInitialize)(this.dataGrid1)).EndInit();
this.ResumeLayout(false);

}
#endregion

/// <summary>
/// 应用程序的主入口点。
/// </summary>
[STAThread]
static void Main() 
{
Application.Run(new Form1());
}

private void button1_Click(object sender, System.EventArgs e)
{
openFileDialog1.Filter = "Excel文件(*.xls)|*.xls";
if(openFileDialog1.ShowDialog() == DialogResult.OK)
{
this.textBox1.Text = openFileDialog1.FileName;
}
}

public DataSet GetDataSetFromExcel(string strFileName)
{
OleDbConnection objConn = null;
DataSet ds = new DataSet();
DataTable schemaTable = new DataTable();
try
{
                string strConn = "Provider=Microsoft.ACE.OleDb.12.0;" "Data Source=" strFileName ";" "Extended Properties='Excel 8.0;IMEX=1;'";
objConn = new OleDbConnection(strConn);
objConn.Open();
schemaTable = objConn.GetOleDbSchemaTable(System.Data.OleDb.OleDbSchemaGuid.Tables,null);
                OleDbDataAdapter sqlAda = new OleDbDataAdapter();
                foreach (DataRow dr in schemaTable.Rows)
                {
                    if (dr[2].ToString().Trim().IndexOf("FilterDatabase") == -1)
                    {
                        string strSql = "Select * From [" dr[2].ToString().Trim() "]";
                        OleDbCommand objCmd = new OleDbCommand(strSql, objConn);
                        sqlAda.SelectCommand = objCmd;
                        sqlAda.Fill(ds, dr[2].ToString().Trim());
                        DataRow drMessage = dtMessage.NewRow();
                        drMessage["表名"] = dr[2].ToString().Trim();
                        dtMessage.Rows.Add(drMessage);
                    }
                }
                dtMessage.AcceptChanges();
}
catch(Exception ex)
{
MessageBox.Show(ex.Message);
}
finally
{
objConn.Close();
}

return ds;
}

public bool DataTableToSQL2005(string tableName,DataTable dt)
{
bool b = false;
int flag = 0;
try
{
PDSOFT.Data.DataCommand dc = new PDSOFT.Data.DataCommand();
//创建表
string createTable = "CREATE TABLE [dbo].[" tableName "](";
foreach(DataColumn col in dt.Columns)
{
createTable = "[" col.ColumnName "] [nvarchar](255) NULL,";
}
createTable = createTable.Remove(createTable.Length - 1,1) ")";
dc.ExecSql_Search_DataTable(createTable);
this.SetMessage("是否创建表",tableName,"是","");
flag = 1;
//导入数据
string insertStr = "begin tran t1 ";
string insertData = "";
for(int i = 0; i < dt.Rows.Count; i )
{
insertData = "insert " tableName " values(";
for(int j = 0; j < dt.Columns.Count; j )
{
insertData = "'" dt.Rows[i][j].ToString().Replace("'","") "',";
}
insertData = insertData.Remove(insertData.Length - 1,1);
insertData = ")";
insertStr = insertData " ";
}
insertStr = "commit tran t1";

dc.ExecSql_Search_DataTable(insertStr);
this.SetMessage("是否导入数据",tableName,"是","");
b = true;
}
catch(Exception ex)
{
if(flag == 0)
{
this.SetMessage("是否创建表",tableName,"否",ex.Message);
}
else
{
this.SetMessage("是否导入数据",tableName,"否",ex.Message);
}
b = false;
}
return b;
}

private void SetMessage(string columnName,string tableName,string message,string errorMessage)
{
foreach(DataRow dr in dtMessage.Rows)
{
if(dr["表名"].ToString() == tableName)
{
dr[columnName] = message;
dr["错误信息"] = errorMessage;
dtMessage.AcceptChanges();
break;
}
}
}

private void button3_Click(object sender, System.EventArgs e)
{
if(textBox1.Text.Trim() == "")
{
MessageBox.Show("请选择一个Excel文件");
return;
}
this.Cursor = Cursors.WaitCursor;
            dtMessage.Clear();
            DataSet ds = GetDataSetFromExcel(textBox1.Text.Trim());
            foreach (DataTable dt in ds.Tables)
            {
                DataTableToSQL2005(dt.TableName, dt);
            }
            dataGrid1.DataSource = dtMessage.DefaultView;
            this.Cursor = Cursors.Default;
}
}
}


实例下载地址

将excel文件上传至sql2005数据库

不能下载?内容有错? 点击这里报错 + 投诉 + 提问

好例子网口号:伸出你的我的手 — 分享

网友评论

发表评论

(您的评论需要经过审核才能显示)

查看所有0条评论>>

小贴士

感谢您为本站写下的评论,您的评论对其它用户来说具有重要的参考价值,所以请认真填写。

  • 类似“顶”、“沙发”之类没有营养的文字,对勤劳贡献的楼主来说是令人沮丧的反馈信息。
  • 相信您也不想看到一排文字/表情墙,所以请不要反馈意义不大的重复字符,也请尽量不要纯表情的回复。
  • 提问之前请再仔细看一遍楼主的说明,或许是您遗漏了。
  • 请勿到处挖坑绊人、招贴广告。既占空间让人厌烦,又没人会搭理,于人于己都无利。

关于好例子网

本站旨在为广大IT学习爱好者提供一个非营利性互相学习交流分享平台。本站所有资源都可以被免费获取学习研究。本站资源来自网友分享,对搜索内容的合法性不具有预见性、识别性、控制性,仅供学习研究,请务必在下载后24小时内给予删除,不得用于其他任何用途,否则后果自负。基于互联网的特殊性,平台无法对用户传输的作品、信息、内容的权属或合法性、安全性、合规性、真实性、科学性、完整权、有效性等进行实质审查;无论平台是否已进行审查,用户均应自行承担因其传输的作品、信息、内容而可能或已经产生的侵权或权属纠纷等法律责任。本站所有资源不代表本站的观点或立场,基于网友分享,根据中国法律《信息网络传播权保护条例》第二十二与二十三条之规定,若资源存在侵权或相关问题请联系本站客服人员,点此联系我们。关于更多版权及免责申明参见 版权及免责申明

;
报警