C#2005,Excel导入oracle数据库并显示在listview上.

表名为:KLCUSTOM_BOMS,表中栏位分别为:CUSTOM_CODE,ASSEMBLY_ITEM,COMMPONET_ITEM,COMMPONET_DESCRIPT... 表名为: KLCUSTOM_BOMS,表中栏位分别为:CUSTOM_CODE,ASSEMBLY_ITEM,COMMPONET_ITEM,
COMMPONET_DESCRIPTION,COMMPONET_QUANTITY,TOTAL_QUANTITY
程式中用到了一个openFileDialog1用来在电脑上找到相关Excel文档.

private static string connectionString = "Data Source=ebs3;Persist Security Info=True;User ID=apps;Password=apps3316;Unicode=True";

private void button1_Click(object sender, EventArgs e)
{
OracleConnection con = new OracleConnection(connectionString);
OracleCommand cmd = new OracleCommand("select * from KLCUSTOM_BOMS");
cmd.Connection = con;
con.Open();
//将Excel文档导入oracle数据库,难点啊,不会弄.这里应该是先通过openFileDialog1来找到文档,再进行导入数据库.请帮忙完善.
???????????????????????????????????????????????
问题解决追加100分,希望M得良师义友~
2,3,4点啊,大哥,我是刚刚学的,什么也不知道啊
另外,我先得判定Excel表的结构,才导入.那么Excel表的具体项怎么表示呢,比如,表的第3行,第4列为空,
展开
 我来答
xx_lzj
2008-02-20 · TA获得超过970个赞
知道大有可为答主
回答量:578
采纳率:0%
帮助的人:738万
展开全部
1、通过openFileDialog1.FileName,得到Excel文件名,还要知道工作表名,比如sheet1,然后用类似下面的代码将Excel表读入到DataTable中:
//定义连接excel的字符串
string strCon = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source= ***.xls"
OleDbConnection oleConn = new OleDbConnection(strCon);
OleDbDataAdapter oleDA = new OleDbDataAdapter("select * from [Sheet1$]", oleConn);
DataTable sourceDataTable = new DataTable();
oleDA.Fill(sourceDataTable);
2、oracle的目的表也读入到内存,为destinationDataTable,代码略
3、逐行遍历sourceDataTable,将其赋值给destinationDataTable的新行,若两表结构相同,也可以直接调用复制方法,而且如果目标表为空在第4中直接对sourceDataTable操作
4、将destinationDataTable通过OracleCommand或者OracleDataAdapter更新到Oracle即可。
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式