首页 新闻 会员 周边

Excel导入数据库中

0
[已解决问题] 解决于 2014-08-27 14:19

将Excel中的数据导入到Sqlserver已有的数据表中,想在C#中写代码,能说的详细点吗最好有具体的代码

C#
lxj19920104的主页 lxj19920104 | 菜鸟二级 | 园豆:206
提问于:2013-06-16 14:49
< >
分享
最佳答案
0
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Collections;
using System.IO;
using System.Data;
using System.Data.OleDb;

namespace Com.DataCool.AppCommon
{
    /// <summary>
    /// OLE连接Excel数据文件Helper
    /// </summary>
    public  class ExcelDBHelper
    {
        /// <summary>
        /// 取得Excel文本中的记录,并作成DataTable
        /// </summary>
        /// <param name="strExcelFileName">Excel文件路径</param>
        /// <param name="strSheetName">指定Excel中的那个Sheet</param>
        /// <returns>DataTable</returns>
        public static DataTable ExcelToDataTable(string strExcelFileName, string strSheetName)
        {
            string strConn = "Provider=Microsoft.Jet.OLEDB.4.0;" + "Data Source=" + strExcelFileName + ";" + "Extended Properties='Excel 8.0;HDR=NO;IMEX=1';";
            string strSheet = GetSheetName(strExcelFileName);
            string strExcel = "select * from [" + strSheet + "$]";
            DataSet ds = new DataSet();
            using (OleDbConnection conn = new OleDbConnection(strConn))
            {
                try
                {
                    conn.Open();
                    OleDbDataAdapter adapter = new OleDbDataAdapter(strExcel, strConn);
                    adapter.Fill(ds, strSheetName);
                }
                catch (Exception ex)
                {
                    LogHelper.Error(ex);
                }
                finally
                {
                    conn.Close();
                }
            }
            return ds.Tables[strSheetName];
        }

        /// <summary>
        /// 取得指定Excel的sheet名
        /// </summary>
        /// <param name="filePath">指定的Excel路径</param>
        /// <returns>string返回Sheet名</returns>
        public static string GetSheetName(string filePath)
        {
            string sheetName = "";
            System.IO.FileStream tmpStream = File.OpenRead(filePath);
            byte[] fileByte = new byte[tmpStream.Length];
            tmpStream.Read(fileByte, 0, fileByte.Length);
            tmpStream.Close();
            byte[] tmpByte = new byte[]
            {
                Convert.ToByte(11),Convert.ToByte(0),Convert.ToByte(0),Convert.ToByte(0),Convert.ToByte(0),Convert.ToByte(0),Convert.ToByte(0),Convert.ToByte(0),
                Convert.ToByte(11),Convert.ToByte(0),Convert.ToByte(0),Convert.ToByte(0),Convert.ToByte(0),Convert.ToByte(0),Convert.ToByte(0),Convert.ToByte(0),
                Convert.ToByte(30),Convert.ToByte(16),Convert.ToByte(0),Convert.ToByte(0)
            };
            int index = GetSheetIndex(fileByte, tmpByte);
            if (index > -1)
            {
                index += 16 + 12;
                ArrayList sheetNameList = new ArrayList();
                for (int i = index; i < fileByte.Length - 1; i++)
                {
                    byte temp = fileByte[i];
                    if (temp != Convert.ToByte(0))
                        sheetNameList.Add(temp);
                    else
                        break;
                }
                byte[] sheetNameByte = new byte[sheetNameList.Count];
                for (int i = 0; i < sheetNameList.Count; i++)
                    sheetNameByte[i] = Convert.ToByte(sheetNameList[i]);
                sheetName = System.Text.Encoding.Default.GetString(sheetNameByte);
            }
            return sheetName;
        }

        /// <summary>
        /// 只供方法GetSheetName()使用
        /// </summary>
        /// <returns></returns>
        private static int GetSheetIndex(byte[] FindTarget, byte[] FindItem)
        {
            int index = -1;
            int FindItemLength = FindItem.Length;
            if (FindItemLength < 1) return -1;
            int FindTargetLength = FindTarget.Length;
            if ((FindTargetLength - 1) < FindItemLength) return -1;
            for (int i = FindTargetLength - FindItemLength - 1; i > -1; i--)
            {
                ArrayList tmpList = new ArrayList();
                int find = 0;
                for (int j = 0; j < FindItemLength; j++)
                {
                    if (FindTarget[i + j] == FindItem[j]) find += 1;
                }
                if (find == FindItemLength)
                {
                    index = i;
                    break;
                }
            }
            return index;
        }
    }
}

项目里随便摘取的。FYI~

建议使用BulkCopy批量插入比较快。

奖励园豆:5
数据酷软件 | 初学一级 |园豆:130 | 2013-06-17 13:35
其他回答(3)
0
kylin.chen | 园豆:983 (小虾三级) | 2013-06-16 15:10
0

1.先解析excel,找到所有的列。

2.找到目标数据库,获取所有的字段以及各式和长度。

3.一行一行的进行解析excel,数据的格式和长度进行处理,主键值一定要有,而且不能重复,

拼装好Insert的SQL,直接执行就Ok了。

二十三号同学 | 园豆:974 (小虾三级) | 2013-06-16 18:17
0

NPOI组件,

直接读出数据,然后再批量插入.

只会造轮子 | 园豆:2274 (老鸟四级) | 2013-06-17 14:03
清除回答草稿
   您需要登录以后才能回答,未注册用户请先注册