C#中oracle数据库的连接方法

一、关于数据库的操作
1.数据库连接
     有2种:
     第一种:古老的方法(较为死板,不利于灵活操作),即用OracleConnection的类来连接
             string
mysqlstr ="user id = xal;data source = xal;password = xal";
            
OracleConnection mycnn = new OracleConnection(mysqlstr);
            
mycnn.open();
     第二种:新式的方法(使用较为灵活),即利用OracleConnectoinStringBuilder类来连接
            
OracleConnectionStringBuilder OcnnStrB = new OracleConnectionStringBuilder;
            
OCnnStrB.DataSource = "xal";
            
OCnnStrB.UserID = "xal";
            
OCnnStrB.Password = "xal";
             myCnn
= new OracleConnection(OCnnStrB.ConnectionString);
            
myCnn.open();

2.事务操作
 myConn.open();
      OracleCommand insertComm = new OracleCommand();
               
insertComm.Connection = myCnn;
               
insertComm.Transaction = myCnn.BeginTransaction();
 try
     {
  事务操作语句;
   insertComm.Transaction.Commit();
     }
 catch(exption ex)
     {
  insertComm.Transaction.Rollback();
  MessageBox(ex.Message);
     }
 finally
     {
  myConn.close();
     }

3.创建命令参数
        private OracleParameter
CreateOraParam(string ParamName, object ParamValue)
        {
           
OracleParameter Result = new OracleParameter();
           
Result.ParameterName = ParamName;
            if
(ParamValue != null)
            {
               
Result.Value = ParamValue;
            }
            else
            {
               
Result.Value = DBNull.Value;
            }
            return
Result;
        }
       这样的话,当要对数据库操作时就可以:
            
insertComm.CommandText = "insert into TESTADODOTNET (ID, NAME, AGE, PIC)
values (:pID, :pName, :pAge, :pPic)";
            
insertComm.Parameters.Add(CreateOraParam("pID", (txtID.Text.Trim() !=
"") ? txtID.Text.Trim() : null));
            
insertComm.Parameters.Add(CreateOraParam("pName",
(txtName.Text.Trim() != "") ? txtName.Text.Trim() : null));
            
insertComm.Parameters.Add(CreateOraParam("pAge", (txtAge.Text.Trim()
!= "") ? txtAge.Text.Trim() : null));

4.数据集的浏览(例:将结果显示在comboBox1中)
             
OracleDataAdapter oda = new OracleDataAdapter(selectCommand);
             
DataTable newtable = new DataTable();
             
oda.Fill(newtable);
       foreach (DataRow dr in
newtable.Rows)  //共有newtable.rows.count条记录
               
{
      comboBox1.Items.Add(dr[0].ToString());
      }

5.设置输入只能是数字(例:现在往textBox1中输入。如只能输入字母的方法类似)
 private void textBox1_KeyPress(object sender, KeyPressEventArgs e)//属性中的事件
         {
           
      e.Handled = !((Char.IsNumber(e.KeyChar)) ||
((Keys)e.KeyChar == Keys.Back));
         }

6.Form窗口关闭时引发的事件:弹出一个确定退出的对话框
  private void form1_FormClosing(object sender, FormClosingEventArgs
e)
         {
          if
(MessageBox.Show("是否退出系统?", "确认", MessageBoxButtons.YesNo, MessageBoxIcon.Question) ==
DialogResult.Yes)
            {
                 
e.Cancel = false;
            }
          else
            {
              
   e.Cancel = true;
            }
        }

7.OracleParameter的用法
        第一步:先创建命令参数
        private OracleParameter CreateOraParam(string
ParamName, object ParamValue)
        {
           
OracleParameter Result = new OracleParameter();
           
Result.ParameterName = ParamName;
            if
(ParamValue != null)
            {
               
Result.Value = ParamValue;
            }
            else
            {
               
Result.Value = DBNull.Value;
            }
            return
Result;
        }
       第二步:写SQL语句,并调用第一步的参数(例如::pID是个参数,代表调用insertComm.Parameters.Add中的pID的值)
        insertComm.CommandText = "insert
into TESTADODOTNET (ID, NAME, AGE, PIC) values (:pID, :pName, :pAge,
:pPic)";
 insertComm.Parameters.Add(CreateOraParam("pID",
(txtID.Text.Trim() != "") ? txtID.Text.Trim() : null));
       
insertComm.Parameters.Add(CreateOraParam("pName", (txtName.Text.Trim()
!= "") ? txtName.Text.Trim() : null));
       
insertComm.Parameters.Add(CreateOraParam("pAge", (txtAge.Text.Trim()
!= "") ? txtAge.Text.Trim() : null));

第三步:添加pictureBox1图片的二进制流字段pAge
                
//创建字节数组用于给IMAGE字段赋值,fileLength是指所选的文件的大小
         byte[] tmpImage = new
byte[fileLength];
               
//根据字节数组创建内存流,之后对该流的操作将会影响字节数组的内容
         MemoryStream curStream = new
MemoryStream(tmpImage);
                
//把控件内显示的图形写入到流中,需强制指定格式
        
pictureBox1.Image.Save(curStream, curImageFormat);//curImageFormat前面指定的图片格式
        
insertComm.Parameters.Add(CreateOraParam("pPic", tmpImage));

C#中oracle数据库的连接方法的更多相关文章

  1. Oracle数据库字符串连接方法

    转至:http://database.51cto.com/art/201011/232267.htm 和其他数据库系统类似,Oracle字符串连接使用“||”进行字符串拼接,其使用方式和MSSQLSe ...

  2. PL/SQL Developer 连接Oracle数据库详细配置方法

    PL/SQL Developer 连接Oracle数据库详细配置方法 近段时间很多网友提出监听配置相关问题,客户终端(Client)无法连接服务器端(Server).本文现对监听配置作一简单介绍,给出 ...

  3. 转载“启动\关闭Oracle数据库的多种方法”--来自百度#Oracle

    启动\关闭Oracle数据库的多种方法 启动和关闭oracle有很多种方法. 这里只给出3种方法: l         Sql*plus l         OEM控制台 l         Wind ...

  4. Java与SQL Server, MySql, Oracle, Access的连接方法以及一些异常解决

    Java与SQL Server, MySql, Oracle, Access的连接方法以及一些异常解决 I. 概述 1.1 JDBC概念 JDBC(Java Database Connectivity ...

  5. ADO访问Oracle数据库,连接异常(Unknown error 0x800a0e7a)

    ADO访问Oracle数据库,连接异常(Unknown error 0x800a0e7a) 代码如下:执行Open过程中出现异常,信息为Unknown error 0x800a0e7a  C++ Co ...

  6. 重装系统后ORACLE数据库恢复的方法

    如果我们的操作系统出现问题,重装系统后,ORACLE数据库应该如何恢复呢?下文就为您列举了两个重装系统后ORACLE数据库恢复的方法,供您参考. ORACLE数据库恢复的方法我们经常会用到,下面就为您 ...

  7. Oracle数据库的备份方法

    1.引言 Oracle数据库的备份方法很多,无论使用那种备份方法,备份的目的都是为了在出现故障后能够以尽可能小的时间和代价恢复系统.比如使用export实用程序导出数据库对象.使用Oracle备份数据 ...

  8. 总结 vb与数据库的连接方法

    总结 vb与数据库的连接方法 分类:vb数据库 (4672)  (38)  举报  收藏 总结:vb与数据库连接方式,两种分法. 根据是否使用ODBC(驱动程序)来分: 1.有源连接 2.无源连接. ...

  9. Qt 中 Oracle 数据库 QOCI 驱动问题及解决

    Qt 中 Oracle 数据库 QOCI 驱动问题及解决是本文要讲述的问题,用Qt开发Oracle程序时,常会遇到QOCI驱动问题,主要表现为程序运行时出现下面的错误. QOCI driver not ...

随机推荐

  1. MyCAT学习总结

    MyCAT介绍 简单的说,MyCAT就是: 一个彻底开源的,面向企业应用开发的“大数据库集群” 支持事务.ACID(指数据库事务正确执行的四个基本要素的缩写.包含:原子性(Atomicity).一 ...

  2. .NET Framwork 之 托管代码的执行过程

    源代码代码第一次编译形成IL中间语言的托管代码,在运行时被Class Loader装载后进行JIT第二次编译形成托管的本地代码.在执行过程中,它会不断地检查当前我们执行的代码的安全性和规范性. Cla ...

  3. sprintf、vsprintf、sprintf_s、vsprintf_s、_snprintf、_vsnprintf、snprintf、vsnprintf 函数辨析

    看了题目中的几个函数名是不是有点头晕?为了防止以后总在这样的细节里纠缠不清,今天我们就来好好地辨析一下这几个函数的异同. 实验环境: Windows下使用VS2017Linux下使用gcc4.9.4 ...

  4. docker基本

    安装(centos): Docker 运行在 CentOS 7 上,要求系统为64位.系统内核版本为 3.10 以上.Docker 运行在 CentOS-6.5 或更高的版本的 CentOS 上,要求 ...

  5. PHP安全:如何正确的取得使用者 IP?

    PHP安全:如何正确的取得使用者 IP? 很多网站都会有侦测用户 IP 的功能,不管是判断使用者来自哪边,或者是记录用户的位置.但是你知道吗?网络上大多数的教学全部都是「错误」的.正确的程序写法可以确 ...

  6. 原来这是一个经典面试题-------Day61

    前几天在table的操作中,记录了动态生成表格的三种方式: 1.html语言的拼接:用字符串或者数组拼接在html语言中,这个理解起来最直观 2.插入行和列:insertRow()和insertCel ...

  7. 为Drupal7.22添加富编辑器 on Ubuntu 12.04

    怀揣着为中小企业量身定做一整套开源软件解决方案的梦想开始了一个网站的搭建.http://osssme.org/ 基本上就是按照Drupal7宝典里描述的进行设置的. 1. 下载wysiwyg 2.   ...

  8. spring Di依赖注入

    依赖注入有两种方式 通过 get   set 方法 Person.java package cn.itcast.spring.sh.di.set; import java.util.List; imp ...

  9. struts2中 jsp:forward 失败原因及解决办法

    问题:在Struts2中<jsp:forward page="xxx.action"></jsp:forward>失效了,不但调转不过去还报404错误.不知 ...

  10. Android成长之路-实现监听器的三种方法

      第一种:  在Test类中  定义一个类接口OnClickListener 第二种:直接在Test类上写一个接口 其中的this相当于new OnClickListener()对象, 即class ...