Excel导入SQL(2)

      用第一种方法,上传服务器后,在一些服务器中,可能会出现以下错误:

    必须在web.config中加 <system.web><identity impersonate="false"/></system.web> ,否则出现错误:System.Data.OleDb.OleDbException: 未指定的错误。加了以后,点多几次链接,会出现“用户 'NT AUTHORITY/NETWORK SERVICE' 登录失败”,需要重新上传,然后又出现同样的错误。
     所以,如果要上传到服务器的话,就要用到第二种方法。如下:

   public Random rd;

   rd = new Random(1);
            string filename = this.FileUpload1.PostedFile.FileName;
            //string filename = this.FileUpload1.PostedFile.FileName;
            string type = filename.Substring(filename.LastIndexOf("."));
            string z = Server.MapPath("../file/") + Guid.NewGuid().ToString() + type;
            this.FileUpload1.PostedFile.SaveAs(z);
            SqlConnection conn = new SqlConnection(ConfigurationManager.ConnectionString              ["IEISConnectionString"].ConnectionString);
                    SqlCommand cmd = new SqlCommand();
                    cmd.CommandText = "SELECT * FROM OPENROWSET('MICROSOFT.JET.OLEDB.4.0','Excel 5.0;HDR=Yes;IMEX=1;DATABASE=" + z + "',sheet1$)";
                    SqlDataAdapter da = new SqlDataAdapter();
                    da.SelectCommand = cmd;
                    cmd.Connection = conn;
                    conn.Open();
                    DataSet ds = new DataSet();
                    da.Fill(ds);
                    conn.Close();

  先上传文件,是因为服务器根据路径找不到文件,所以要先上传到服务器,否则出现错误。

 

这种方法,在一些服务器中可能会出现如下错误:

已拒绝对 OLE DB 提供程序 'MICROSOFT.JET.OLEDB.4.0' 的特殊访问。必须通过链接服务器来访问此提供程序。

可能要通过用“sa”登录才能解决问题,这时候用回第一种方法,可能问题就解决了。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值