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列为空, 展开
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列为空, 展开
1个回答
展开全部
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即可。
//定义连接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即可。
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询