c# execl 导入数据库

本文介绍了一种从Excel文件中读取数据并将其导入到数据库的方法。具体实现了Excel文件的上传、验证、读取,并将数据写入到指定的数据库表中。同时,文章还涉及了对已有数据的检查及更新策略。

1. default.aspx.cs

 

using System.Data.OleDb;
using System.mySQLConnection;
using System.Data.SqlClient;

 

public DataSet ExecleDs(string filenameurl,string table)
    {
        
            string strConn = "Provider=Microsoft.Jet.OleDb.4.0;" + "data source=" +filenameurl+ ";Extended Properties='Excel 8.0; HDR=YES; IMEX=1'";
          
            OleDbConnection conn = new OleDbConnection(strConn);
     
            OleDbDataAdapter odda = new OleDbDataAdapter("select * from [外地$]",conn);

            DataSet ds = new DataSet();

            odda.Fill(ds,table);
     
            return ds;

   }
    protected void Page_Load(object sender, EventArgs e)
    {

    }
    protected void Button1_ServerClick(object sender, EventArgs e)
    {

     
        string IsXls = System.IO.Path.GetExtension(FileUpload1.FileName.ToString().ToLower());
        if (IsXls != ".xls")
        {
          Page.ClientScript.RegisterStartupScript(Page.GetType(), "", "<script type='text/javascript' language='javascript'>alert('只可以选择Excel文件')</script>");
          return;//当选择的不是Excel文件时,返回
        }
       string error = null;
      
       SqlConnections cn = new SqlConnections();

       string strpath = FileUpload1.PostedFile.FileName.ToString();
       
        //获取Execle文件路径
       string filename = FileUpload1.FileName;
        //获取Execle文件名
       DataSet ds = ExecleDs(strpath,filename);

       DataRow[] dr = ds.Tables[0].Select(); 
        //定义一个DataRow数组
      int rowsnum = ds.Tables[0].Rows.Count;
      if (rowsnum == 0)                                
      {
           Page.ClientScript.RegisterStartupScript(Page.GetType(), "", "<script type='text/javascript' language='javascript'>alert('Excel表为空表,无数据!')</script>");
          
            return;
       }
     else
      {
         for (int i = 0; i < dr.Length; i++)
           {
               string YHMC = dr[i]["通知书号"].ToString();
               string YHMM = dr[i]["姓名"].ToString();
               string DQRQ = dr[i]["身份证号"].ToString();
               string ZT = dr[i]["性别"].ToString();
               string TJSJ = dr[i]["专业"].ToString();
               string JXDM = dr[i]["住址"].ToString();
               string youbian = dr[i]["邮编"].ToString();
               string dianhua = dr[i]["联系电话"].ToString();
               string shouji = dr[i]["手机"].ToString();
               string tuijianren = dr[i]["推荐人"].ToString();

           
               //还缺少,学生ID号,学生报名号

               string sqlcheck = "select f_StudentID  from t_studentInfo  where f_Name='" + YHMM + "'And f_Identify='" + DQRQ + "'";  //检查用户是否存在

               DataTable CH = System.mySQLConnection.SqlConnections.GetDataTable(sqlcheck, "aa");

               //得到专业ID

               string sql = "select o_id from t_setclass where o_outname='" + TJSJ + "'";

               string zhuanyeid = System.mySQLConnection.SqlConnections.GetNumOneField(sql);

               if (CH != null && CH.Rows.Count > 0)
               {
                   error += "<em style='color:red;font-sixe:25px'>" + YHMM + "</em>用户基本信息已存在,此行记录无法插入!<br>";   //若用户存在,将已存在用户信息打出,并提示此用户无法插入

                   string baomingId = System.mySQLConnection.SqlConnections.GetNumOneField("select dbo.myFun_StudentInfo_Flowid(getDate())");

                   string sqltext = "insert into t_StudentAdmit(f_FlowID,f_StudentID,o_id,t_tuijianname,f_zhengshu) values('" + baomingId + "','" + CH.Rows[i]["f_StudentID"].ToString() + "','" + zhuanyeid + "','" + tuijianren + "','" + YHMC + "')";

                   System.mySQLConnection.SqlConnections.UpdateOrDelete(sqltext);

                   continue;
               }
               else
               {
                  string  studentId = System.mySQLConnection.SqlConnections.GetNumOneField("select dbo.myFun_StudentInfo_XueHao(getDate())");

                  string sqltest = "insert into t_studentInfo(f_StudentID,f_Name,f_Gender,f_Identify,f_detail,f_youbian,f_zuoji,f_shouji,f_tuijianren) values('" + studentId + "','" + YHMM + "','" + ZT + "','" + DQRQ + "','" + JXDM + "','" + youbian + "','" + dianhua + "','" + shouji + "','" + tuijianren + "')";

                  System.mySQLConnection.SqlConnections.UpdateOrDelete(sqltest);


                  string baomingId = System.mySQLConnection.SqlConnections.GetNumOneField("select dbo.myFun_StudentInfo_Flowid(getDate())");

                  string sqltext1 = "insert into t_StudentAdmit(f_FlowID,f_StudentID,o_id,t_tuijianname,f_zhengshu) values('" + baomingId + "','" + studentId + "','" + zhuanyeid + "','" + tuijianren + "','" + YHMC + "')";

                  System.mySQLConnection.SqlConnections.UpdateOrDelete(sqltext1);
      
               }   
           }
           Response.Write("<script>alert('Excle表导入成功!')</script>");

           Label1.Text = error;
         }
    }

 

2.default.aspx

 <form id="form1" runat="server">
    <div>
        <br />
        <asp:FileUpload ID="FileUpload1" runat="server" /><br />
        <br />
        <input id="Button1" type="button" value="导入数据" runat="server" onserverclick="Button1_ServerClick" /><br />
        <br />
         <asp:Label ID="Label1" runat="server" Height="31px"  Width="297px"></asp:Label><br />
        <br />
        &nbsp;</div>
    </form>

 

C#中,将Excel数据导入数据库可以通过以下步骤实现: 1. 首先,创建一个用于存储Excel数据的DataTable对象。可以使用第二个引用中的代码,通过选择Excel文件并将其数据加载到DataTable中。 2. 在保存到数据库之前,需要确保DataTable中有有效的数据。可以使用第一个引用中的代码,对DataTable进行验证。 3. 然后,使用一个循环遍历DataTable中的每一行数据,并将其插入到数据库表中。可以使用第三个引用中的方法,创建一个SQL语句将Excel数据逐行插入到数据库表中。 4. 最后,根据需要,在数据插入完成后显示相应的提示信息。 需要注意的是,在插入数据时,可以选择使用事务来确保数据的完整性和一致性。可以根据需求,选择在每查询一个对象就提交一次到数据库,或者每遍历一次就生成一条SQL语句,根据事务提交到数据库。 这样,通过以上步骤,可以将Excel中的数据成功导入数据库中。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* [C#学习笔记---通过Excel导入数据库](https://blog.youkuaiyun.com/xhtom44301/article/details/128666198)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *3* [C# Excel导入数据库](https://download.youkuaiyun.com/download/water17ball/2658931)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论 2
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值