网站需要怎么做才能被百度收录,什么是网站什么是网址,开发公司质量管理制度,子域名大全excel 数据表上传到oracle数据库。过程例如以下#xff1a; 1、打开本地excel文件 2、用OleDb连接excel文件 3、将来excel的数据读取到dataset中 4、把dataset 中数据insert到oracle中对应的表中 以下截图说明#xff1a; 建立项目文件。非常easy。就是建立普通的winform项目… excel 数据表上传到oracle数据库。过程例如以下 1、打开本地excel文件 2、用OleDb连接excel文件 3、将来excel的数据读取到dataset中 4、把dataset 中数据insert到oracle中对应的表中 以下截图说明 建立项目文件。非常easy。就是建立普通的winform项目。当中訪问oracle要加入引用System.Data.OracleClient vs2010 默认是.net framework 4.0 client profile 。在加入引用时是看不到System.Data.OracleClient须要在 项目文件上右击。选择属性。会弹出例如以下对话框 在target framework 下拉框中 选择.net framework 4。这样兴许加入引用时才干在.net页签看到System.Data.OracleClient。 以下是所有代码 using System; using System.Data; using System.Drawing; using System.Text; using System.Windows.Forms; using System.IO; using System.Data.OleDb; using System.Data.OracleClient; namespace WindowsFormsApplication4 { public partial class Form1 : Form { public Form1() { InitializeComponent(); } private void button1_Click(object sender, EventArgs e) { openFileDialog1.Filter 1(*.xlsx)|*.xlsx; openFileDialog1.ShowDialog();//打開對話方塊 this.textBox1.Text openFileDialog1.FileName;//得到檔路徑名稱 } private void button2_Click(object sender, EventArgs e) { try { DataSet ds ImportExcel(this.textBox1.Text);//將excel的對象先放到ds 中 if (ds ! null) { if (ds.Tables[0].Rows.Count 0)//假设ds中是有值的話 執行以下的操作 { if (ExportInfo(ds)) { MessageBox.Show(導入資料庫成功!); } else { MessageBox.Show(導入資料庫失敗!); } } } } catch { MessageBox.Show(導入資料庫失敗 請檢查導入檔是否填寫正確!); } } public static DataSet ImportExcel(string file) { FileInfo fileInfo new FileInfo(file); if (!fileInfo.Exists) return null; string strConn ProviderMicrosoft.Ace.OleDb.12.0;Data Source file ;Extended PropertiesExcel 12.0; HDRyes; IMEX2; // 此处用的是excel2010,假设为其它excel版本号。请选择对应的连接驱动和字符串 OleDbConnection objConn new OleDbConnection(strConn); DataSet dsExcel new DataSet(); try { objConn.Open(); string strSql select * from [Sheet1$]; OleDbDataAdapter odbcExcelDataAdapter new OleDbDataAdapter(strSql, objConn); odbcExcelDataAdapter.Fill(dsExcel); return dsExcel; } catch (Exception ex) { throw ex; } } public static bool ExportInfo(DataSet ds) { if (ds ! null) { if (ds.Tables[0].Rows.Count 0)//假设ds中是有值的話 執行以下的操作 { return Do(ds);//執行成功 } } return false;//執行失敗 } public static bool Do(DataSet ds) { OracleConnection conNorthwind new OracleConnection(Data Sourcetiptop;User Iditeqdg;Passworditeqdg;Integrated Securityno;);//連結字串 OracleCommand commandNorthwind new OracleCommand(); try { conNorthwind.Open();//打開資料庫連結 OracleTransaction tranNorthwind conNorthwind.BeginTransaction();//开始事務 for (int i 0; i ds.Tables[0].Rows.Count; i) { DataRow dr ds.Tables[0].Rows[i]; OracleParameter[] parameters null;//為了得到插入資料庫的参數 定義参數物件 為空 string sql GetSqlString(dr, out parameters);//執行sql --用out關鍵字得到参數 賦到parameters物件上 //插入資料庫中 PrepareCommand(commandNorthwind, conNorthwind, tranNorthwind, sql, parameters); commandNorthwind.ExecuteNonQuery();//執行操作 } commandNorthwind.Transaction.Commit();//提交事務 conNorthwind.Close();//關閉資料庫連結資源 return true; } catch//假设有異常 不一定要捕捉異常 但要rollback事務 { if (commandNorthwind.Transaction ! null conNorthwind ! null) { commandNorthwind.Transaction.Rollback();//rollback事務 conNorthwind.Close();//關閉資料庫連結 } return false; } } /// summary /// 每一行資訊插入資料庫中 /// /summary /// param namedr要插入的這一行ds-datarow對象/param /// returnssql語句和用out關鍵字的参數陣列物件/returns public static string GetSqlString(DataRow dr, out OracleParameter[] parameters) { StringBuilder sb new StringBuilder(); sb.Append(INSERT INTO TEXT VALUES(:ID,:NAME)); parameters new OracleParameter[] { new OracleParameter(:ID, Convert.ToString(dr[0])), new OracleParameter(:NAME, Convert.ToString(dr[1])) }; return sb.ToString();//將sqlreturn出去 } private static void PrepareCommand(OracleCommand cmd, OracleConnection conn, OracleTransaction trans, string cmdText, OracleParameter[] cmdParms) { PrepareCommand(cmd, conn, trans, cmdText, CommandType.Text, cmdParms); } //参數設定 此方法被重載 private static void PrepareCommand(OracleCommand cmd, OracleConnection conn, OracleTransaction trans, string cmdText, CommandType cmdType, OracleParameter[] cmdParms) { if (conn.State ! ConnectionState.Open) { conn.Open(); } cmd.Connection conn; cmd.CommandText cmdText; if (trans ! null) { cmd.Transaction trans; } cmd.CommandType cmdType; // CommandType.Text;//cmdType; if (cmdParms ! null) { foreach (OracleParameter parameter in cmdParms) { if (parameter ! null) { if (parameter.Value null) { parameter.Value DBNull.Value; } cmd.Parameters.Add(parameter); } } } } } } 转载于:https://www.cnblogs.com/llguanli/p/8919101.html