Execl数据导入数据库:

注意事项:execl中的列名与列数要与数据库的列名和列数一致、值类型一致,列名不一致的话可在导入的时候,给字段起别名,确定保持一致

v 界面代码:

<div>

导入Execl路径:

<asp:FileUpload ID="FileUpload1" runat="server" />

<asp:Button ID="ExeclToSql" runat="server" Text="导入数据库" Width="120px"    onclick="ExeclToSql_Click" />

</div>

v 后台cs代码:

protected void ExeclToSql_Click(object sender, EventArgs e)

{

string excelFile = "";

//string excelFile = FileUpload1.FileName;

System.Web.HttpPostedFile postFile = FileUpload1.PostedFile;

DataSet ds = new DataSet();

OleDbConnection conn = new OleDbConnection();

try

{

//判断路径是否为空

if (postFile.FileName != String.Empty)

{

//新建文件名

string fileName = Guid.NewGuid().ToString() + ".xls";

//文件上传服务器目录路径

string absPath = Request.PhysicalApplicationPath + ("upload\\"); if (!System.IO.Directory.Exists(absPath)) System.IO.Directory.CreateDirectory(absPath); //上传文件,要检查一下是否建立了相关目录

//保存文件至服务器

postFile.SaveAs(absPath + fileName);

//文件全部路径

excelFile = absPath + fileName;

try

{

//value代表数据库的字段名,*代表execl的字段

string ss = "INSERT INTO 数据库表名(value)  SELECT * FROM OPENDATASOURCE('Microsoft.ACE.OLEDB.12.0','Data Source=" + excelFile + ";Extended Properties=Excel 8.0')...[sheet1$]";

//注意:改方法为封装好的SQL执行语句,请用自己封装的连接数据库执行增删改查的类方法

DbHelperSQL.ExecuteSql(ss);

Page.RegisterStartupScript("js", "<script>alert('导入数据成功!')</script>");

}

catch

{

Page.RegisterStartupScript("js", "<script>alert('导入数据失败!')</script>");

}

}

else

{

throw new Exception("请上传文件!");

}

}

catch

{

Page.RegisterStartupScript("js", "<script>alert('错误!')</script>");

}

}

或者用以下类方法:

public class ExcelToSQL

{

//string  sqlcon = System.Configuration.ConfigurationManager.ConnectionStrings["ConnectionString"].ConnectionString;

public SqlConnection sqlcon = new SqlConnection("连接字符串");        //创建SQL连接

public SqlCommand sqlcom;          //创建SQL命令对象

public ExcelToSQL()

{

if (sqlcon.State.ToString() == "Open")

sqlcon.Close();

}

public int ImportSql(string excelPath, string tableName)  //导入的Excel的路径,数据库里的表名

{

if (!TableExist(tableName)) //表名是否存在

return (int)ImportState.tableNameError;

DataTable dt = ExcelToDataTable(excelPath);//把Excel里的数据转换为DataTable,并返回DataTable

if (dt == null)

{

return (int)ImportState.excelFormatError;//转换失败

}

ArrayList tableField = GetTableField(tableName);   //表格的列名称  (得到数据库表的列名)

string columnName = "MGUID,"; //Excel里的列名,增加一个ID列,如果ID自动递增则不需要增加ID列,只需要columnName=“”就可以了。

for (int i = 0; i < dt.Columns.Count; i++)

{

columnName += dt.Columns[i].ColumnName + ",";

string currentColumn = dt.Columns[i].ToString().ToUpper(); //当前列名

for (int j = 0; j < tableField.Count; j++)

{

if (tableField[j].ToString().ToUpper() == dt.Columns[i].ToString().ToUpper())

break;   //跳出本层和上一层循环,continue是跳出本层循环,如果用continue,会继续执行j++

//Excel里的字段必须在Sql中都有

if ((tableField[j].ToString().ToUpper() != dt.Columns[i].ToString().ToUpper()) && j == tableField.Count - 1)

return (int)ImportState.fieldMatchError;

}

}

int m = columnName.LastIndexOf(',');

columnName = columnName.Remove(m);  //移除最后一个逗号

sqlcom = new SqlCommand();

sqlcom.Connection = sqlcon;

sqlcon.Open();

sqlcom.CommandType = CommandType.Text;

for (int h = 0; h < dt.Rows.Count; h++)

{

string value = "'" + System.Guid.NewGuid().ToString() + "'" + ","; //如果ID自动递增ID列不需要增加了,那么value的初始值只需要value=“”就可以了。

for (int k = 0; k < dt.Columns.Count; k++) //根据列名得到值

{

value += "'" + dt.Rows[h][k].ToString() + "'" + ",";

}

value = value.Remove(0, 1);

int n = value.LastIndexOf(',');

value = value.Remove(n);    //移除最后一个逗号

n = value.LastIndexOf("'");

value = value.Remove(n);

try

{

string sql = "insert into " + tableName + "(" + columnName + ") values('" + value + "')";

sqlcom.CommandText = sql;

string sss = sqlcom.ExecuteNonQuery().ToString();

}

catch (Exception err)

{

string erroe = err.Message;

return (int)ImportState.dataTypeError;

}

}

sqlcon.Close();

sqlcom.Dispose();

return (int)ImportState.right;

}

public DataTable ExcelToDataTable(string excelPath)  //把Excel里的数据转换为DataTable,并返回DataTable

{

string strCon = "Provider=Microsoft.ACE.OLEDB.12.0;Data Source=" + excelPath + ";Extended Properties='Excel 8.0;IMEX=1'";

System.Data.OleDb.OleDbConnection Conn = new System.Data.OleDb.OleDbConnection(strCon);

string strCom = "SELECT * FROM [库存数量$]";

DataTable dt;

try

{

Conn.Open();

System.Data.OleDb.OleDbDataAdapter myCommand = new System.Data.OleDb.OleDbDataAdapter(strCom, Conn);

DataSet ds = new DataSet();

myCommand.Fill(ds, "[库存数量$]");

Conn.Close();

dt = ds.Tables[0];

}

catch (Exception err)

{

return null;

}

return dt;

}

public bool TableExist(string tableName) //查看数据库里是否有此表名

{

sqlcom = new SqlCommand();

sqlcom.Connection = sqlcon;

sqlcom.CommandType = CommandType.Text;

try

{

sqlcon.Open();

string sql = "select name from sysobjects where type='u'";

sqlcom.CommandText = sql;

SqlDataReader sqldr = sqlcom.ExecuteReader();

while (sqldr.Read())

{

if (sqldr.GetString(0).ToUpper() == tableName.ToUpper())

return true;

}

}

catch { return false; }

finally

{

sqlcon.Close();

}

return false;

}

public ArrayList GetTableField(string tableName)  //得到数据库某一个表中的所有字段

{

ArrayList al = new ArrayList();

sqlcom = new SqlCommand();

sqlcom.Connection = sqlcon;

sqlcom.CommandType = CommandType.Text;

try

{

sqlcon.Open();

string sql = "SELECT b.name FROM sysobjects a INNER JOIN syscolumns b ON a.id = b.id WHERE (a.name = '" + tableName + "')";

sqlcom.CommandText = sql;

SqlDataReader sqldr = sqlcom.ExecuteReader();

while (sqldr.Read())

{

al.Add(sqldr.GetString(0));

}

}

finally

{

sqlcon.Close();

}

return al; //返回的是表中的字段

}

public enum ImportState

{

right = 1, //成功

tableNameError = 2,//表名不存在

fieldMatchError = 3,//excel里的字段和数据库表里的字段不匹配

dataTypeError = 4, //转换数据类型时发生错误

excelFormatError = 5,//Excel格式不能读取

}

public void Alert(string str)

{

HttpContext.Current.Response.Write("<script language='javascript'>alert('" + str + "');</script>");

}

}

EXECL文件导入数据库的更多相关文章

  1. 读取Execl表 导入数据库

    不知不觉博客园园林都两年多了,我是今年毕业的应届生,最近公司项目需要改动,很多的数据需要导入,很多的实体类需要些.考虑到这些问题自己写了两个winform版的小工具,一个是读取Execl数据导入数据库 ...

  2. C# ASP.NET CSV文件导入数据库

    原文:C# ASP.NET CSV文件导入数据库 using System; using System.Collections.Generic; using System.Text; using Sy ...

  3. 【DRP】採用dom4j完毕XML文件导入数据库

    版权声明:本文为博主原创文章,未经博主同意不得转载. https://blog.csdn.net/lantingxv_jing/article/details/37762523     xml文件在如 ...

  4. 将.dat文件导入数据库

    *最近在搞文本分类,就是把一批文章分成[军事].[娱乐].[政治]等等. 但是这个先需要一些样本进行训练,感觉文本分类和"按图索骥"差不多,训练的文章样本就是"图&quo ...

  5. PHP读取CSV大文件导入数据库的示例

    对于数百万条数据量的CSV文件,文件大小可能达到数百M,如果简单读取的话很可能出现超时或者卡死的现象. 为了成功将CSV文件里的数据导入数据库,分批处理是非常必要的. 下面这个函数是读取CSV文件中指 ...

  6. CSV文件导入数据库和导出数据库

    实例一: <?php $filename = 'test'; //导出文件 header("Content-type: application/vnd.ms-excel; charse ...

  7. 记tp5.1使用composer PhpOffice的xlsx表格文件导入数据库

    在项目环境下composer require phpoffice/phpspreadsheet在项目中引用use PhpOffice\PhpSpreadsheet\IOFactory; 下面是 上传x ...

  8. mongodb csv 文件导入数据库,删除特定字段

    1. 导入数据库 mongoimport -h host_ip -p port -d db_name -c collection_name --fields name1,name2,name3,nam ...

  9. 《mysql必知必会》学习_sql文件导入数据库_20180724_欢

    解决问题1:MySQL中导入sql文件. 步骤1:show databases;#看看我有什么数据库 步骤2:use hh;#我要用hh这个数据库,返回database changed说明打开成功. ...

随机推荐

  1. C#入门经典第五版之变量与表达式编码题训练

    问题:编写一个控制台应用程序,要求用户输入4个int值,并显示它们的乘积.提示:可以使用Convert.ToDouble()命令,把用户在控制台上输入的数转换为double, 以此类推,转换成int命 ...

  2. 关于 CommonJS AMD CMD UMD 规范的差异总结

    一.CommonJS 主要是用于服务器端的规范,比如目前的nodeJS. 根据CommonJS规范,一个单独的文件就是一个模块.每一个模块都是一个单独的作用域,也就是说,在一个文件定义的变量(还包括函 ...

  3. Winform开发框架主界面设计展示

    做了好多年Winform的程序的开发,主窗口的界面设计一般都要求做的更好一些,可以根据不同的系统功能模块进行归类整合,能使客户迅速寻找到相关功能的同时,也能感觉到整体性的美观大方,因此主窗口的界面设计 ...

  4. 如何在ASP.Net中实现RSA加密

    在我们实际运用中,加密是保证数据安全的重要手段.以前使用ASP时,对数据加密可以使用MD5和SHA1算法,这两种算法虽然快捷有效,但是无法对通过它们加密的密文进行反运算,即是解密.因此需要解密数据的场 ...

  5. http 响应码

    一.HTTP码应码响应码由三位十进制数字组成,它们出现在由HTTP服务器发送的响应的第一行. 响应码分五种类型,由它们的第一位数字表示:1.1xx:信息,请求收到,继续处理2.2xx:成功,行为被成功 ...

  6. 防止用户误操作退出APP的处理

    /** * 软件退出的处理:先跳到第一个页面,再点提示“再点一次退出”,2秒内再点一次退出 * 防止用户误操作 */ private boolean isExist=false; private Ha ...

  7. Ahjesus Nodejs01 环境搭建及运行

    访问http://nodejs.org/,根据系统选择下载文件,我用的win7 64 安装一路下一步直到完成 运行cmd输入node -v查看是否安装成功 成功会显示版本号 到此环境搭建完毕 ==== ...

  8. ThreadLocal,Java中特殊的线程绑定机制

    在DRP项目中,我们使用了ThreadLocal来创建Connection连接,避免了一直以参数的形式将Connection向下传递(传递connection的目的是由于jdbc事务要求确保使用同一个 ...

  9. 关于SAP的视图类型

    1 sap的视图的类型sap的视图的类型有五种 Database views (数据库视图):和数据库的视图形同,连接条件是必须自定义. Projection views(投影视图): 用于屏蔽一些字 ...

  10. C#知识点总结【1】

    值类型和引用类型 从概念上看,其区别是值类型直接存储其值,引用类型存储值的引用. 在内存当中的状态,值类型存储在堆栈(zhan)中,而引用类型存储在托管堆上. ; int j = i; 上面的例子中 ...