简单的将Excel数据同步到SqlServer数据库中

Posted yixuan.han

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了简单的将Excel数据同步到SqlServer数据库中相关的知识,希望对你有一定的参考价值。

1.创建一个WinForm程序,添加一个Button控件

2.Button事件

 private void button1_Click(object sender, EventArgs e)
        {
            System.Windows.Forms.OpenFileDialog fd = new OpenFileDialog();
            if (fd.ShowDialog() == DialogResult.OK)
            {
                string fileName = fd.FileName;
                syncExcelToDataBase(fileName, textBox1.Text.ToString());
            }
        }

3.从Excel读取数据到DataTable

       private void syncExcelToDataBase(string excelfilepath, string sheetName)
        {
            string strConn = "Provider=Microsoft.ACE.OLEDB.12.0;Data Source=" + excelfilepath + ";" + "Extended Properties=‘Excel 12.0; HDR = Yes‘";
            string strExcel = string.Format("select * from [{0}$]", sheetName);
            OleDbDataAdapter da = new OleDbDataAdapter(strExcel, strConn);
            DataSet ds = new DataSet();
            try
            {
                da.Fill(ds);
                dt = ds.Tables[0];
                if (dt != null && dt.Rows.Count > 0)
                {
                    foreach (DataRow dr in dt.Rows)
                    {
                        Update(dr);
                    }
                }

            }
            catch (Exception err)
            {
                MessageBox.Show("操作失败!" + err.ToString());
            }
        }

4.更新到Sql server 数据库中

        private void Update(DataRow dr)
        { 
            string saleName = dr["TELESALES MANILA"].ToString().Trim();
            string crn = dr["CRN"].ToString().Trim();
            if(!string.IsNullOrEmpty(saleName) && saleName != "#N/A")
            {
                string[] arr = saleName.Split( );
                if(arr.Length>0)
                {
                    string sql1 = "SELECT *FROM [dbo].[PUserAdmin] where FirstName=‘" + arr[0] + "‘ and LastName=‘" + arr[1] + "";
                    DataTable dtResult = SqlHelper.ExecuteDataTable(sql1,CommandType.Text);
                        string sql2 = "update [dbo].[PAgents] set BFax=‘" + dtResult.Rows[0][0] + "‘ where CRN=‘" + crn + "";
                        SqlHelper.ExecuteNonQuery(sql2, CommandType.Text);
                }
            }
        }

以上是关于简单的将Excel数据同步到SqlServer数据库中的主要内容,如果未能解决你的问题,请参考以下文章

kettle利用excel文件增量同步一个库的数据(多表一次增量同步)

csharp SQLite数据库到SQLServer同步的简单依赖注入

请教,怎么将mysql里的大数据同步到 sqlserver2008里

excel怎么快速的将新数据替换旧数据?

SQL SERVER2012同步Oracle数据

将excel数据导入SQLServer2005