浅析C#绑定变量和匿名块获取获取序列当前值

我们将谈到C#绑定变量和匿名块获取获取序列当前值,首先需要在Oracle中进行一系列的操作,接下来是C#绑定变量的具体操作。

我们提供的服务有:成都做网站、网站设计、微信公众号开发、网站优化、网站认证、东港ssl等。为近1000家企事业单位解决了网站和推广的问题。提供周到的售前咨询和贴心的售后服务,是有科学管理、有技术的东港网站制作公司

1.在Oracle中建立表、序列、触发器:

 
 
 
  1. SQL> create table TESTTAB  
  2.    (  
  3.      ID   NUMBER,  
  4.      NAME VARCHAR2(10)  
  5.    ); 

表被创建

 
 
 
  1. SQL> create sequence TESTTABSEQ  
  2.     minvalue 1  
  3.     maxvalue 999999999999999999999999999  
  4.    start with 1  
  5.     increment by 1  
  6.     cache 20; 

序列被创建

 
 
 
  1. SQL> create or replace trigger Tr_testtabid  
  2.    before insert on testtab for each row  
  3.       
  4.     begin 
  5.      SELECT TESTTABSEQ.NEXTVAL into :NEW.id from dual;  
  6.      end Tr_testtabid;  
  7.     / 

触发器被创建

2.主要的C#绑定变量代码:

 
 
 
  1. using ORAC = System.Data.OracleClient;  
  2.         private void button1_Click(object sender, System.EventArgs e)  
  3.                 {  
  4.                         try 
  5.                         {  
  6.                           
  7.                                 string str_Sql = @"begin insert into testtab(name) values('test'); select TESTTABSEQ.Currval into :ID from dual; end;";  
  8.                                 ORAC.OracleCommand cmd= new ORAC.OracleCommand(str_Sql,this.oracleConnection1);  
  9.  
  10.                                 ORAC.OracleParameter parm = new ORAC.OracleParameter("ID",ORAC.OracleType.Number);  
  11.                                 parm.Direction = ParameterDirection.Output;  
  12.                                 cmd.Parameters.Add(parm);  
  13.  
  14.                                 if(this.oracleConnection1.State == System.Data.ConnectionState.Closed)  
  15.                                 {  
  16.                                         this.oracleConnection1.Open();  
  17.                                 }  
  18.                                 cmd.ExecuteNonQuery();  
  19.  
  20.  
  21.                                 this.textBox1.Text = cmd.Parameters[0].Value.ToString();  
  22.                         }  
  23.                         catch(Exception ex)  
  24.                         {  
  25.                                 MessageBox.Show("发生错误!";  
  26.                                   
  27.                         }  
  28.                         finally 
  29.                         {  
  30.                                 this.oracleConnection1.Close();  
  31.                         }  
  32.  
  33.                           
  34.                 } 

【编辑推荐】

  1. C# Attribute的概念与使用浅析
  2. C# AttributeUsage的使用浅析
  3. 浅析Attribute在C# WinForm控件开发中的使用
  4. 浅谈C#控件属性串行化的实现
  5. C#实例详解TypeConverterAttribute应用

本文题目:浅析C#绑定变量和匿名块获取获取序列当前值
文章URL:http://www.gawzjz.com/qtweb2/news46/18896.html

网站建设、网络推广公司-创新互联,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等

广告

声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联