客户需要将一个具有2W多条数据的Excel表格中的数据导入到Oracle数据库的A表中,开始采用的是利用Oledb直接将数据读入到DataTable中,然后通过拼接InserInto语句来插入到数据库表A中.然后做好以后,发现经常提示Invalidate Character错误.但是将拼接好的SQL拿到PLSQL中执行,一切完好.最后没办法,为了缩小错误范围,开始利用begin end分段来做.具体方式为:

每隔1000条数据,加上形如   Begin  ...这里是1000条数据...   End;Commit;  的标记

具体后台代码如下:

using System;
using System.Data;
using System.Data.OracleClient;
using Microsoft.Office.Interop.Excel;
using Excel = Microsoft.Office.Interop.Excel;
using RedGlovePermission.Lib;
using System.IO;
using System.Data.OleDb;
using System.Data;
using System.Configuration;
using System.Text;
using System.Collections;
using System.Collections.Generic;
using System.Web.UI; public partial class YQKH_YQKH_OACL : BasePageWithLog,ICallbackEventHandler
{
private BusinessLogicLayer.ICommonBLL _CommonBLL;
public BusinessLogicLayer.ICommonBLL CommonBLL
{
get
{
return _CommonBLL;
}
set
{
_CommonBLL = value;
}
}
public static string result = string.Empty;
protected void Page_Load(object sender, EventArgs e)
{
this.DBGridConfig1.openURL = "../CommData/GetDataByParameter.aspx?sqlKey=t_yqkh_oa_mx"; //加载需要进行导入的表中的数据
} protected void toExcel_Click(object sender, EventArgs e)
{
if (UploadExcel.HasFile) //如果存在上传文件
{
string filename = UploadExcel.PostedFile.FileName;
String strConnectionString = string.Format("Provider=Microsoft.Jet.OLEDB.4.0;Data Source={0};Extended Properties='Excel 8.0;IMEX=1'", filename);//serverpath是Excel表格路径
using (OleDbConnection Excel_conn = new OleDbConnection(strConnectionString)) //连接Excel,和连接MSSQL数据库的方式类似
{
Excel_conn.Open(); //打开连接
System.Data.DataTable dtExcelSchema = Excel_conn.GetOleDbSchemaTable(OleDbSchemaGuid.Tables, new object[] { null, null, null, "TABLE" });//建立连接Excel的数据表
string SheetName = "";
SheetName = dtExcelSchema.Rows[3]["TABLE_NAME"].ToString();//取需要的工作表的名称
System.Data.DataTable dt = new System.Data.DataTable();
try
{
string strExcel = "";
OleDbDataAdapter myCommand = null;
strExcel = string.Format(" select * from [{0}] ", SheetName); //取工作表中的所有数据
myCommand = new OleDbDataAdapter(strExcel, Excel_conn);
myCommand.Fill(dt);
}
catch (Exception ex){} using (OracleConnection oraconn = new OracleConnection(ConfigurationManager.AppSettings["SQLString"].ToString())) //打开oracle数据库
{
oraconn.Open(); IList<StringBuilder> _list = ExecInsertIntoOracleFromExcel(dt); //list中保存的是多个需要提交的事物段
foreach (StringBuilder sb in _list) //循环,按照段来执行
{
OracleCommand oracmd = new OracleCommand(sb.ToString(), oraconn);
oracmd.ExecuteNonQuery();
}
//Response.Write("导入成功!");
ClientScript.RegisterClientScriptBlock(Page.GetType(), "alertSuccess", "<script>alert('导入成功!')</script>");
this.DBGridConfig1.openURL = "../CommData/GetDataByParameter.aspx?sqlKey=t_yqkh_oa_mx";
}
}
}
} public int iCount = 0;
private IList<StringBuilder> ExecInsertIntoOracleFromExcel(System.Data.DataTable dt)
{
IList<StringBuilder> iList = new List<StringBuilder>();
try
{
this._CommonBLL.ExecuteQuery("delete from db_zgfz.t_yqkh_oa");
}
catch(Exception ex)
{
Page.ClientScript.RegisterClientScriptBlock(Page.GetType(),"alertFail","<script>删除数据失败!</script>");
} if (dt != null)
{
if (dt.Rows.Count > 0)
{
StringBuilder sql = new StringBuilder();
sql.Append("begin ");
foreach (DataRow dr in dt.Rows)
{
iCount++;
sql.Append(" insert into db_zgfz.t_yqkh_oa values('" + dr["受理号"].ToString() + "','" +
dr["企业名称"].ToString() + "','" +
dr["事项名称"].ToString() + "','" +
dr["事项所属类别"].ToString() + "','" +
dr["事项ID"].ToString() + "','" +
dr["工作环节"].ToString() + "','" +
dr["部门"].ToString() + "','" +
dr["流经部门开始日期"].ToString() + "','" +
dr["流经部门结束日期"].ToString() + "'); ");
if (iCount % 1000 == 0) //每隔1000条数据,当做一段来执行,缩小出错范围
{
sql.Append(" commit; end; ");
iList.Add(sql);
sql = new StringBuilder();
sql.Append("begin "); }
else if (dt.Rows.Count == iCount)
{
sql.Append(" commit; end; ");
iList.Add(sql);
}
}
}
} return iList ;
} #region ICallbackEventHandler 成员 public string GetCallbackResult() //主要显示当前插入了多少条数据
{
return "当前共导入:"+result+"条数据!";
} public void RaiseCallbackEvent(string eventArgument)
{
string sql = "SELECT COUNT(*) FROM t_yqkh_oa";
System.Data.DataTable dtt = this._CommonBLL.ADONETHelper.GetDataTableBySQL(CommandType.Text, sql);
if (dtt != null)
{
if (dtt.Rows.Count > 0)
{
result = dtt.Rows[0][0].ToString();
}
}
} #endregion
}

  前台代码如下:

<%@ Page Language="C#" AutoEventWireup="true" CodeFile="YQKH_OACL.aspx.cs" Inherits="YQKH_YQKH_OACL" %>
<%@ Register Src="~/inc/DBGridConfig.ascx" TagName="DBGridConfig" TagPrefix="uc1" %>
<html xmlns="http://www.w3.org/1999/xhtml">
<head id="Head1" runat="server">
<title>外部数据导入</title>
<script language="javascript" src="../XmlDataSet/javascript/System.js"></script>
<script language="javascript" src="../XmlDataSet/javascript/ajax.js"></script>
<script language="JavaScript" src="../XmlDataSet/javascript/DataSet.js"></script>
<script language="JavaScript" src="../XmlDataSet/javascript/Control.js"></script>
<script language="JavaScript" src="../XmlDataSet/javascript/DBControl.js"></script>
<script language="JavaScript" src="../XmlDataSet/javascript/DBNavigator.js"></script>
<script language="JavaScript" src="../XmlDataSet/javascript/DBPageNavigator.js"></script>
<script language="JavaScript" src="../XmlDataSet/javascript/DBGrid.js"></script>
<script language="JavaScript" src="../XmlDataSet/javascript/ToolBar.js"></script>
<script language="javascript" src="../XmlDataSet/javascript/DBSearchToolBar.js"></script>
<script language="javascript" src="../javascripts/Collection.js"></script>
<script language="javascript" type="text/javascript" src="../javascripts/validator.js"></script>
<link href="../css/dtree.css" rel="stylesheet" type="text/css" />
<link href="../css/tables.css" rel="stylesheet" type="text/css" />
<link href="../css/main.css" rel="stylesheet" type="text/css" /> <script type="text/javascript">
var jcl_ResourceURL = "../XmlDataSet/javascript/images/";
function rServer(arg,context)
{
document.getElementById("info").innerHTML=arg;
}
function raiseCallBack(arg, context) {
<%=ClientScript.GetCallbackEventReference(this,"arg","rServer","context") %>;
}
window.onload=function(){
raiseCallBack();
}
setInterval('raiseCallBack()',2000);
</script> </head>
<body>
<form id="form1" runat="server">
<table><tr><td></td><td>
<table border="2" cellpadding="0" cellspacing="0" width="90%" align="center" style="border-collapse:collapse; text-align:center; ">
<thead>
<th align="center" colspan="4" style="font-size:large;">外部数据导入</th>
</thead>
<tbody>
<tr>
<td style="font-size:medium;" align="left"> </td>
<td style="font-size:medium;" align="left"> </td>
<td>
<asp:FileUpload ID="UploadExcel" runat="server" CssClass="inputButton" Width="300px" />
<asp:Button ID="toExcel" runat="server" Text="导入数据" CssClass="inputButton" onclick="toExcel_Click" />
</td>
<td id="info">
</td>
</tr>
<tr><td colspan="4"><hr /></td></tr>
<tr>
<td colspan="4">
<uc1:DBGridConfig ID="DBGridConfig1" runat="server" configKey="t_yqkh_oa_mx" isCanEdit="false" postURL="../CommData/UpdateData.aspx" />
</td>
</tr>
</tbody>
</table>
</td></tr></table>
</form>
</body>
</html>

  这样,当插入的时候,不断的Select count(*) from A 语句,就会发现数据时呈1000往上递增的,出现问题的时候,也会提示哪次插入出现错误了,很方便.

Excel大数据量分段导入到Oracle的更多相关文章

  1. java excel大数据量导入导出与优化

    package com.hundsun.ta.utils; import java.io.File; import java.io.FileOutputStream; import java.io.I ...

  2. java 导出Excel 大数据量,自己经验总结!

    出处: http://lyjilu.iteye.com/ 分析导出实现代码,XLSX支持: /** * 生成<span style="white-space: normal; back ...

  3. SQL Server 使用bcp进行大数据量导出导入

    转载:http://www.cnblogs.com/gaizai/archive/2010/04/17/1714389.html SQL Server的导出导入方式有: 在SQL Server中提供了 ...

  4. MySQL大数据量的导入

    最近在公司备份数据库数据,简单的看了一下.当然我用的是简单的手动备份. 第一:其实最好的方法是直接用: mysqldump -u用户名 -p密码 数据库名 < 数据库名.sql 在linux在操 ...

  5. java 导出Excel 大数据量,自己经验总结!(二)

    在上一次的基础上加上了样式,以及中文列名 package com.tommy.fundation.util; import java.io.OutputStream; import java.util ...

  6. POI 生成excel(大数据量) SXSSF

    使用POI 的SXSSF (Streaming Usermodel API)生成较大的excel,同时开启压缩 import junit.framework.Assert; import org.ap ...

  7. 使用OPENROWSET、Microsoft.ACE.OLEDB实现大数据量的高效导入

    首先说明使用的环境是:java和Sqlserver. 最近公司需要进行大数据量的导入操作.原来使用的是Apache POI,虽然可以实现功能,但是因为逻辑处理中需要进行许多校验,处理速度太慢,使用多线 ...

  8. (转)利用WPF的ListView进行大数据量异步加载

    原文:http://www.cnblogs.com/scy251147/archive/2012/01/08/2305319.html 由于之前利用Winform的ListView进行大数据量加载的时 ...

  9. 利用WPF的ListView进行大数据量异步加载

    原文:利用WPF的ListView进行大数据量异步加载 由于之前利用Winform的ListView进行大数据量加载的时候,诟病良多,所以今天试着用WPF的ListView来做了一下,结果没有让我失望 ...

随机推荐

  1. PyCharm 134 单元测试输出大量空行解决方案

    在某次BugFix中,某哥们儿在/helper/pycharm/tcunittest.py加了个这: 各位亲们可以把True改为False即可解决大量空行的问题.

  2. [原]cocos2d-lua 常用法汇总

    1.CCEditBox local back = CCScale9Sprite:create("res/ui/images/im_02.png", CCRect(20, 20, 1 ...

  3. Moto G 通话没声音

    入手了摩托罗拉被 Google 收购后推出的第二款手机 Moto G (第一款是 Moto X) 后发现有个问题,有时候会莫名其妙地通话没声音,你听不到对方的,对方也听不到你的,从网上的搜索结果来看, ...

  4. Git 执行 「fork 出来的仓库」和「最新版本的原仓库」内容同步更新

    当我们在 GitHub 上 fork 出一个仓库后,如果原仓库更新了,此时怎样才能保证我们 fork 出来的仓库和原仓库内容一致呢?我们一般关注的是仓库的 master(主干分支)的内容,通过以下步骤 ...

  5. iOS开发-Xcode升级后插件失效解决办法

    打开terminal,输入如下命令: | xargs -I{} defaults write {} DVTPlugInCompatibilityUUIDs -array-add `defaults r ...

  6. js最新手机号码、电话号码正则表达式

    原文链接:http://caibaojian.com/regexp-example.html 正则表达式(regular expression)是一个描述字符模式的对象.使用javascript正则表 ...

  7. 在没安装OFFICE的服务器SSIS中进行EXCEL的ETL操作!

    由于OFFICE 2010的安装包比较庞大,如果仅仅为了在服务器中实现操作EXCEL,完全没有必要安装整个OFFICE,是否可以不装OFFICE也实现与OFFICE文件的互相操作呢?答案是肯定的,在S ...

  8. [原]Android打包之跨平台打包

    Android自动打包流程详细图: 在前面一些博客我们知道了如何通过命令行打包,如何通过Eclipse打包,如何通过编写shell脚本来进行打包,但是这些都不能很好的跨平台进行打包. 因Python本 ...

  9. SNF开发平台WinForm之十二-发送手机短信功能调用-金笛-SNF快速开发平台3.3-Spring.Net.Framework

    1.调用前组装参数 2.调用发送信息服务脚本   .调用前组装参数: BaseSendTaskEntity entity = new BaseSendTaskEntity(); entity.Mess ...

  10. 2014 网选 广州赛区 hdu 5025 Saving Tang Monk(bfs+四维数组记录状态)

    /* 这是我做过的一道新类型的搜索题!从来没想过用四维数组记录状态! 以前做过的都是用二维的!自己的四维还是太狭隘了..... 题意:悟空救师傅 ! 在救师父之前要先把所有的钥匙找到! 每种钥匙有 k ...