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 = @"Provider=Microsoft.Ace.OleDb.12.0;Data Source=" + file + ";Extended Properties='Excel 12.0; HDR=yes; IMEX=2'";

           // 此处用的是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 Source=tiptop;User Id=iteqdg;Password=iteqdg;Integrated Security=no;");//連結字串
            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 name="dr">要插入的這一行ds-datarow對象</param>
        /// <returns>sql語句和用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);
                    }
                }
            }
        }
    }
}

c# vs2010 excel 上传oracle数据的更多相关文章

  1. Excel上传并读取数据

    最近一段时间,维护一个旧系统,其中有一个功能,是把Excel上传,并读取数据进行维护,然后转插入至SQL数据库中.下面Insus.NET使用asp.net 标准上传控件: <asp:FileUp ...

  2. EXCEL上传POI

    Java SpringMVC POI上传excel并读取文件内容 2017年11月27日 15:26:56 强人锁男. 阅读数:15329   用的SSM框架,所需要的jar包如图所示:,链接地址:j ...

  3. excel上传和下载

    需要注意的地方: 1.js构造表单并提交 2.js中文传参encodeURI(encodeURI("中文")),action接收并转换value = URLDecoder.deco ...

  4. Thinkphp5+PHPExcel实现批量上传表格数据功能

    http://www.jb51.net/article/129262.htm 1.首先要下载PHPExcel放到vendor文件夹下,我的路径是:项目/vendor/PHPExcel/,把下载的PHP ...

  5. IT轮子系列(六)——Excel上传与解析,一套代码解决所有Excel业务上传,你Get到了吗

    前言 在日常开发当中,excel的上传与解析是很常见的.根据业务不同,解析的数据模型也都不一样.不同的数据模型也就需要不同的校验逻辑,这往往需要写多套的代码进行字段的检验,如必填项,数据格式.为了避免 ...

  6. Thinkphp5+PHPExcel实现批量上传表格数据

    1.首先要下载PHPExcel放到vendor文件夹下,我的路径是:项目/vendor/PHPExcel/,把下载的PHPExcel文件放在这里 2.前端代码 <!DOCTYPE html> ...

  7. C# winform 窗体应用程序之图片上传Oracle数据库保存字段BLOB

    C# winform 窗体应用程序之图片上传Oracle数据库保存字段BLOB 我用的数据库是Oracle,就目前来看,许多数据库现在都倾向于Oracle数据库,对ORACLE数据库基本的操作也是必须 ...

  8. 基于thinkphp5的Excel上传

    涉及知识点: thinkphp5.0: excel上传: mysql建立新表(基本的create语句): mysql ignore(避免重复插入): 主要功能: 通过在视图中上传excel文件,在my ...

  9. 2019.06.05 ABAP EXCEL 操作类代码 OLE方式(模板下载,excel上传,内表下载)

    一般使用标准的excel导入方法9999行,修改了标准的excel导入FM 整合出类:excel的 模板下载,excel上传,ALV内表下载功能. 在项目一开始可以SE24创建一个类来供整体开发使用, ...

随机推荐

  1. Flex报错Error #2048: 安全沙箱冲突

    Flex+JPA架构,JPA程序迁移,从Aserver到B. 其它一切没变.唯一变的就是IP. 前端Flex也就是swf报错Error #2048: 安全沙箱冲突:http://xxx.swf 不能从 ...

  2. MobX快速入门教程(重要概念讲解)

    转载请注明原文地址:http://www.cnblogs.com/ygj0930/p/7372119.html 一:Mobx工作流程图 二:MobX涉及到的概念 1:状态state 组件中的数据. 2 ...

  3. 【Shell】Linux的判断表达式:-d,-f,-e等

    文件比较运算符 表达式         说明                            案例 -e filename    如果filename存在,则为真        [ –e /et ...

  4. excel如何快速更改表格边框的颜色

    1.当完成基本的表格设置之后,对颜色不甚满意,怎么办 2.重新给表格选择一种颜色,这里会出现一个“笔”形状的鼠标箭头,不用理睬她 3.再次给表格统一加边框即可(开始--边框--所有框线)

  5. python之函数用法startswith()

    # -*- coding: utf-8 -*- #python 27 #xiaodeng #python之函数用法startswith() #http://www.runoob.com/python/ ...

  6. 转:如何编译delta3d

    回头看,自上学以来,做虚拟现实.三维地理信息系统已有六个年头.为了节省花费在编码上的精力,编程应用的API函数也由opengl变成了OpenSceneGraph,但还是花费了很多气力,为了更好的提高开 ...

  7. 微信小程序解决方案合集

    微信小程序解决方案合集:http://www.wxapp-union.com/special/solution.html 跳坑系列:http://www.wxapp-union.com/forum.p ...

  8. 【TP3.2.*】解决session过期不失效 和 设置不成功问题

    // ---------- 更新与 2019/01/23日 -------------// 1.问题:本来我想设置session有效期1800秒即30分钟 失效的,可是实际使用TP3.2.0的时候发现 ...

  9. ubuntu 安装 oracle-xe-universal

    安装oracle-xe-universal第一个我们要考虑的就是交换分区是否足够大, 如果你直接安装,可能会出现下面的英文提示: This system does not meet the minim ...

  10. c++ 在控制台用 wcout输出宽字符的问题

    在我的电脑上要想通过 std::wcout输出 宽字符 需加入以下代码 #include <io.h> #include <fcntl.h> void main() { _se ...