.net数据库实现Excel的导入与导出

参考路径:https://www.cnblogs.com/splendidme/archive/2012/01/05/2313314.html

1.default.aspx文件

 <form id="form1" runat="server">
<table style="width: 858px">
<tr>
<td style="width: 334px">
<asp:Button ID="readFromDB" runat="server" OnClick="readFromDB_Click" Text="从数据库读取数据" />
<asp:GridView ID="GridView1" runat="server" AutoGenerateColumns="True" BackColor="White" BorderColor="#E7E7FF" BorderStyle="None" BorderWidth="1px" CellPadding="" Font-Names="Arial" Font-Size="12px" GridLines="Horizontal" RowStyle-HorizontalAlign="Center" Width="98%">
<FooterStyle BackColor="#B5C7DE" ForeColor="#4A3C8C" /> <RowStyle BackColor="#E7E7FF" ForeColor="#4A3C8C" HorizontalAlign="Center" />
<SelectedRowStyle BackColor="#738A9C" Font-Bold="True" ForeColor="#F7F7F7" />
<PagerStyle BackColor="#E7E7FF" ForeColor="#4A3C8C" HorizontalAlign="Right" />
<HeaderStyle BackColor="#4A3C8C" Font-Bold="True" ForeColor="#F7F7F7" HorizontalAlign="Center" />
<AlternatingRowStyle BackColor="#F7F7F7" /> </asp:GridView>
<asp:FileUpload ID="FileUpload1" runat="server" />
<asp:Button ID="Import" runat="server" OnClick="Import_Click" Text=" 导入" />
<asp:Button ID="output" runat="server" OnClick="btnOut_Click" Text=" 导出" />
</td>
</tr>
</table>
</form>

2.default.aspx.cs文件

 using System;
using System.Data;
using System.Configuration;
using System.Collections;
using System.Web;
using System.Web.Security;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Web.UI.WebControls.WebParts;
using System.Web.UI.HtmlControls;
using System.Data.SqlClient;
using System.Data.OleDb;
using System.Text;
using JJoobb.Web;
using System.IO;
public partial class _Default : System.Web.UI.Page
{
string strConn = SiteSetting.ConnectionString;
string sqlSelectALL = SiteSetting.sqlSelALL;
string exToDB = SiteSetting.ExToDB;
protected void Page_Load(object sender, EventArgs e)
{ }
protected void readFromDB_Click(object sender, EventArgs e)
{
Bind();
}
public void btnOut_Click(object sender, EventArgs e)
{
try
{
CreateExcel(getds());
Response.Write("<script>alert('数据导出成功!')</script>");
}
catch
{
Response.Write("<script>alert('数据导出失败!')</script>");
}
}
public void CreateExcel(DataSet ds)
{
string outPutPath=SiteSetting.OutPutPath +DateTime.Now.ToString ("yyyyMMddHHmmss-")+SiteSetting.FileName;
FileStream file = new FileStream(outPutPath, FileMode.Create);
StreamWriter sw = new StreamWriter(file,Encoding.Default);//设置编码为当 面页面编码
string colHeaders = "", ls_item = "";
//定义表对象与行对象,同时用DataSet对其值进行初始化
DataTable dt = ds.Tables[];
DataRow[] myRow = dt.Select();//可以类似dt.Select("id>10")之形式达到数 据筛选目的
int i = ;
int cl = dt.Columns.Count;
//取得数据表各列标题,各标题之间以\t分割,最后一个列标题后加回车 符
for (i = ; i < cl; i++)
{
if (i == (cl - ))//最后一列,加\n
{
colHeaders += dt.Columns[i].Caption.ToString() + "\n";
}
else
{
colHeaders += dt.Columns[i].Caption.ToString() + "\t";
}
}
sw.Write(colHeaders);
foreach (DataRow row in myRow)
{
//当前行数据写入输出流,并且置空ls_item以便下行数据
for (i = ; i < cl; i++)
{
if (i == (cl - ))
{
ls_item += row[i].ToString() + "\n";
}
else
{
ls_item += row[i].ToString() + "\t";
}
}
sw.Write(ls_item);
ls_item = "";
}
sw.Flush();
sw.Close();
file.Close();
} //从数据库取出要导出的Detset数据集
private DataSet getds()
{
SqlConnection conns = new SqlConnection(strConn);
SqlDataAdapter da = new SqlDataAdapter(sqlSelectALL, conns);
DataSet ds = new DataSet();
da.Fill(ds);
conns.Close();
conns.Dispose();
return ds;
}
//绑定数据
public void Bind()
{
DataSet ds = new DataSet();
using (SqlConnection conn = new SqlConnection())
{
SqlDataAdapter sda = new SqlDataAdapter(sqlSelectALL, strConn);
sda.Fill(ds, "ex_test");
}
GridView1.DataSource = ds.Tables["ex_test"];
GridView1.DataBind();
}
//导入数据
protected void Import_Click(object sender, EventArgs e)
{
string getErrMsg = "";
DataSet excelDs = new DataSet();
if (FileUpload1.PostedFile.FileName == "")
{
Response.Write("<script language=javascript>alert('请选择要上传的文件 !');</script>");
return;
}
//从Excel读取数据
string filePath = FileUpload1.PostedFile.FileName;
string connString = exToDB + filePath;
OleDbConnection excelConn = new OleDbConnection(connString);
OleDbDataAdapter ExcelDA = new OleDbDataAdapter("SELECT * FROM [Sheet1$]", excelConn);
try
{
ExcelDA.Fill(excelDs, "ex_test");
}
catch (Exception err)
{
Response.Write(err.Message);
}
finally
{
excelConn.Close();
excelConn = null;
}
//将数据写入数据库
if (excelDs.Tables[].Rows.Count != )
{
SqlConnection sqlConn = new SqlConnection(strConn);
sqlConn.Open();
SqlCommand myCommand = sqlConn.CreateCommand();
SqlTransaction myTrans = sqlConn.BeginTransaction();
myCommand.Transaction = myTrans;
try
{
for (int i = ; i < excelDs.Tables[].Rows.Count; i++)
{
string sql = "insert into ex_test(id, name, sex,email,address) values('" + excelDs.Tables[].Rows[i]["编号"].ToString() + "','" + excelDs.Tables[].Rows[i][" 姓名"].ToString() + "','" + excelDs.Tables[0].Rows[i]["性别"].ToString() + "','" + excelDs.Tables[].Rows[i]["邮箱"].ToString() + "','" + excelDs.Tables[].Rows[i]["地 址"].ToString() + "')";
myCommand.CommandText = sql; myCommand.ExecuteNonQuery();
}
myTrans.Commit();
}
catch (Exception ex)
{
getErrMsg = ex.Message.ToString();
Response.Write(ex.Message.ToString());
myTrans.Rollback();
}
finally
{
sqlConn.Close();
sqlConn = null;
} }
//返回提示信息
if (getErrMsg == "" || getErrMsg == null)
{
Response.Write("<script language='Javascript'>alert('导入成功!') </script>");
Bind();
}
else
{
Response.Write("<script language='Javascript'>alert('导入失败!') </script>");
return;
}
} }

3.SiteSetting.cs

 using System;
using System.Configuration;
using System.Collections.Generic;
using System.Text; /// <summary>
/// SiteSetting 的摘要说明
/// </summary>
namespace JJoobb.Web
{
public class SiteSetting
{
//数据库连接字符串
public static string ConnectionString = ConfigurationManager.ConnectionStrings["connectionString"].ConnectionString; //导出文件名称
public static string FileName = "OutPut.xls"; //导出文件地址
public static string OutPutPath = "C:\\Documents and Settings\\Administrator\\桌面\\excleFile\\"; //sql语句
public static string sqlSelALL = "select id,title,contents,userName,phone,email,CONVERT(varchar(), AddDate, ) AddDate,ReContents from Feedback"; //从excel读数据
public static string ExToDB = "Provider=Microsoft.Jet.OLEDB.4.0;Extended Properties=\"Excel 8.0;HDR=Yes;IMEX=1\";Data Source=";
}
}

4.web.config

<connectionStrings>
<add name="connectionString" connectionString="server=local;uid=sa;pwd=pwd;database=TestExcel" providerName="System.Data.SqlClient"/>
</connectionStrings>

.net数据库实现Excel的导入与导出的更多相关文章

  1. SpringBoot中关于Excel的导入和导出

    前言   由于在最近的项目中使用Excel导入和导出较为频繁,以此篇博客作为记录,方便日后查阅.本文前台页面将使用layui,来演示对Excel文件导入和导出的效果.本文代码已上传至我的gitHub, ...

  2. excel的导入与导出---通用版

    excel的导入与导出---通用版 web项目关于导入导出的业务场景很常见,最近我就又遇到了这个业务场景.这次将最近半个月做的导入导出总结一下 使用的pom如下,主要还是阿里巴巴的easyexcel依 ...

  3. C#中Excel的导入和导出的几种基本方式

    在上一篇(http://www.cnblogs.com/fengchengjushi/p/3369386.html)介绍过,Excel也是数据持久化的一种实现方式.在C#中.我们常常会与Excel文件 ...

  4. Excel报表开发(主要讲Excel的导入和导出)

    一.Excel数据导入 连接字符串Excel2003版: OleDbConnection conn = new OleDbConnection("provider=Microsoft.Jet ...

  5. java实现Excel的导入、导出

    一.Excel的导入 导入可采用两种方式,一种是JXL,另一种是POI,但前者不能读取高版本的Excel(07以上),后者更具兼容性.由于对两种方式都进行了尝试,就都贴出来分享(若有错误,请给予指正) ...

  6. SQL Server 迁移数据库 (一)导入和导出

    今天正好换服务器,记录一下迁移数据库的过程. 以前经常用备份还原法,今天试试‘SQL Server 2016 导入和导出数据’这个看怎么玩. 1. 建数据库结构 1.1 在需要迁移的数据库名字上右击, ...

  7. SpringBoot整合easyexcel实现Excel的导入与导出

    导出 在一般不管大的或者小的系统中,各家的产品都一样,闲的无聊的时候都喜欢让我们这些程序员导出一些数据出来供他观赏,非说这是必须需求,非做不可,那么我们就只能苦逼的哼哧哼哧的写bug喽. 之前使用PO ...

  8. 在C#中关于excel的导入和导出操作

    一.先来看看最常见的导入操作吧! private void Import() { //打开excel选择框 OpenFileDialog frm = new OpenFileDialog(); frm ...

  9. mysql数据库中的数据导入与导出

    需求: 在本地电脑上的mysql中创建了一个数据库,并且在该数据库中创建了很多表,表中数据比较多: 现在想换一台电脑,但是又不想重新建数据库.建表.造数据. 解决方案: 利用mysql提供的命令,在本 ...

随机推荐

  1. python学习笔记---文件的操作

    数据的保存: 1.内存:常用的变量2.文件:文本内容,二进制的文件内容3.数据库: 读文件:1.要读取的文件路径一定要存在.2.打开存在的文件:open函数    参数1:文件的路径,相对的或者是绝对 ...

  2. JEECG3.8 全套实战视频全部开放,免费下载!

    JEECG快速开发平台V3.8版本自去年10月份发布以来,下载使用数屡创新高,并受到众多开发者积极反馈.为帮助更多初学者能够快速上手,JEECG V3.8版本实战教程现已全面开放,免费下载!本教程深入 ...

  3. ----Androd 系统开机显示白条提示 “there is internal problem with your device, Contact your manufacture ... ”

    ref: https://www.theandroidsoul.com/how-to-fix-theres-an-internal-problem-with-your-device-error-on- ...

  4. Java源码分析:关于 HashMap 1.8 的重大更新(转载)

    http://blog.csdn.net/carson_ho/article/details/79373134 前言 HashMap 在 Java 和 Android 开发中非常常见 而HashMap ...

  5. cxgrid属性说明,每次用的时候费时费力查找。

    由层得到数据表名: procedure TFB_PatientWaiting.cxgrdbtblvwGrid1DBTableView_MyPatienWaitingDblClick( Sender: ...

  6. 几种解决方法:idea 找不到符号或找不到包

    一. idea找不到符号,可能是因为编码问题,所以,在File->settings->Editor->File Encodings-找到编码设置,更改为项目的编码要求,一般都为utf ...

  7. lvs的负载均衡测试

    近来工作闲暇之余,知道自己的知识欠缺,就在网上找来一些学习视频进行学习,在学习的时候,按照讲课老师的讲解步骤进行配置lvs负载均衡,配置环境如下图: 客户端是我本机的虚拟网卡vmnet8 lvs调度器 ...

  8. 浅谈Spring

    参考文章: https://www.ibm.com/developerworks/cn/java/j-lo-spring-principle/ 参考书籍: <SPRING技术内幕:深入解析SPR ...

  9. Linux 用户与组

    在 Linux 操作系统下,如何添加一个新用户到一个特定的组中?如何同时将用户添加到多个组中?又如何将一个已存在的用户移动到某个组或者给他增加一个组?对于不常用 Linux 的人来讲,记忆 Linux ...

  10. 50代码HTML5 Canvas 3D 编辑器优雅搞定

    1024程序员节刚过,手痒想实现一个html的3d编辑器,看了three.js 同时还看了网上流传已久的<<基于 HTML5 Canvas 的简易 2D 3D 编辑器>>,都觉 ...