【总结】C#上传excel文件到Sql server数据库

本文介绍了使用C#结合NOPI库将Excel数据高效地导入到Sql Server数据库的方法,包括创建数据库表、编写ExcelHelper类、使用Ajax进行文件上传以及一般处理程序的实现。需要注意Excel格式要求和数据验证。
摘要由CSDN通过智能技术生成

工具 :  VS2015 + SQL Server 2008 R2  

框架:三层+一般处理程序

方法:方法很多种,百度千奇百怪,总结下来更好更快的方法,以下会提到

最近接触到需要实现将一个excel表格的数据移植到数据库的需求,但此前从未接触过

百度+体会+探讨  总结下来以便后续需要使用,乐于分享给大家,望给予修正

少废话上代码

①数据库,移植到数据库肯定需要表吧,都懂不多说

②需要一个帮助类(当然自己写也可以,个人比较喜欢帮助类,即ExcelHelper类,放dal层)

一时半会可能看不懂(除了导入还有导出,挺全),c+v  懂?

另外注意,需要引用Nuget包  NOPI  使用nopi去导入导出我觉得目前自己掌握的来说最好

using System;
using System.Collections.Generic;
using System.Data;
using System.IO;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using NPOI.SS.UserModel;
using NPOI.XSSF.UserModel;
using NPOI.HSSF.UserModel;

namespace Customer_DAL
{
     

   public class NopiExcelHelper:IDisposable
    {
        private string fileName = null; //文件名
        private IWorkbook workbook = null;
        private FileStream fs = null;
        private bool disposed;
        public NopiExcelHelper(string fileName)
        {
            this.fileName = fileName;
            disposed = false;
        }
        /// <summary>
        /// 将DataTable数据导入到excel中
        /// </summary>
        /// <param name="data">要导入的数据</param>
        /// <param name="isColumnWritten">DataTable的列名是否要导入</param>
        /// <param name="sheetName">要导入的excel的sheet的名称</param>
        /// <returns>导入数据行数(包含列名那一行)</returns>
        public int DataTableToExcel(DataTable data, string sheetName, bool isColumnWritten)
        {
            int i = 0;
            int j = 0;
            int count = 0;
            ISheet sheet = null;
            fs = new FileStream(fileName, FileMode.OpenOrCreate, FileAccess.ReadWrite);
            if (fileName.IndexOf(".xlsx") > 0) // 2007版本
                workbook = new XSSFWorkbook();
            else if (fileName.IndexOf(".xls") > 0) // 2003版本
                workbook = new HSSFWorkbook();
            try
            {
                if (workbook != null)
                {
                    sheet = workbook.CreateSheet(sheetName);
                }
                else
                {
                    return -1;
                }
                if (isColumnWritten == true) //写入DataTable的列名
                {
                    IRow row = sheet.CreateRow(0);
                    for (j = 0; j < data.Columns.Count; ++j)
                    {
                        row.CreateCell(j).SetCellValue(data.Columns[j].ColumnName);
                    }
                    count = 1;
                }
                else
                {
                    count = 0;
             
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值