存储过程笔记——参数、变量篇

存储过程参数、变量

1,变量,

**变量:**普通变量、引用型变量、记录型变量。
1普通变量,直接声明使用。
2引用型变量,为确保声明变量类型与取值来源字段,不会发生类型不匹配情况,声明时,将类型与取值来源字段保持一致。
如声明变量v_age用于接受年龄信息,此时不确定,数据来源表中的age字段是字符串类型还是数值类型,定义时,就可声明v_age与表中age字段类型一致。
3记录型变量,可获取表中某一行数据的全部字段信息,较引用型变量节省了单个字段的声明过程。
声明变量的方式:
变量名 变量类型(变量长度) 例:v_name varchar(2);
变量赋值:
1,直接赋值。如 v_name := ‘张三’;
2,语句赋值。如select … into …变量名

2,参数

参数:指存储过程在创建时声明的变量,作用是存储过程调用前的输入,和运行后的输出。

3,示例

存储过程创建:
(后附相关代码)
在这里插入图片描述
调用:
在这里插入图片描述
运行结果:
在这里插入图片描述
create or replace procedure test_var(v_name_in in test_01.name%type,v_age_out out test_01.age%type) as
–1.1存储过程创建时可选输入、输出参数。此处输入是v_name_in,输出是v_age_out
– Local variables here
–2此处也可以定义参数
v_age integer;–3.1普通变量,可为char,varchar,date,number,boolean,integer…
v_name varchar(20) := ‘张三’;–3.11普通型变量,定义变量,并直接赋值
v_name2 test_01.name%TYPE:=‘李四’;–3.2引用型变量,定义变量,并直接赋值,适用于不确定字段类型时,直接与取值字段类型保持一致
存储过程代码:

  v_age2 test_01.age%TYPE;
  v_line test_01%ROWTYPE;--3.3记录型变量 用于获取表数据整行数据信息
  --v_name:='张三';
begin
  -- Test statements here
  select age into v_age 
  from test_01 where name = v_name;--3.12变量赋值方式2:select  .... into var from table;
  select age into v_age2 
  from test_01 where name = v_name2;
  
  select * into v_line from test_01 where name = '张三';
  select age into v_age_out from test_01 where name = v_name_in;--1.2根据输入的参数,为输出参数赋值
  --打印
  DBMS_OUTPUT.put_line(v_name||'年龄:'||v_age);
         --输出操作,调用存储过程,实际输出参数,只有v_age_out,其余为存储过程内部打印
  DBMS_OUTPUT.put_line(v_name2||'年龄:'||v_age2);
  DBMS_OUTPUT.put_line('记录型变量打印:'||v_line.name||','||v_line.age);
  dbms_output.put_line('存储过程的输入输出练习:'||'其中输入是'||v_name_in||','||'其中输出是'||v_age_out);

end test_var;
/

调用代码:

-- Created on 2024/1/7 by LCLDeer 
declare 
  -- Local variables here
v_age_out2  test_01.age%type;--定义参数,用于获取输出参数。调用时,存储过程内部定义、调用的参数不用关注,只关注存储过程的输入、输出参数即可
v_name_in2 test_01.name%type := '张三';--定义参数,用于指定输入参数。
begin
  -- Test statements here
  test_var( v_name_in2,v_age_out2);--调用存储过程,指定输入、输出参数
  dbms_output.put_line('打印存储过程的参数:'||v_age_out2);
end;
  • 8
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
C#中的各种名词: 常数:声明时用const修饰,是隐式静态类型 域:一个代表和某对象或类相关的变量的成员 字段:和属性相同,是用来存储对象的值,可以直接访问数据且不能对数据添加任何限制,但是属性不能且可以对数据添加访问限制。一个在类或结构的定义中声明的变量。可以被这个类或者结构的所有成员函数(方法、构造函数)使用,可以是值类型或引用类型,主要有实例字段和静态字段。区别于局部变量在于局部变量只能被给定的函数或代码块使用 属性:一种用于访问对象或类的特性的成员。属性的访问器是一种使属性可以像公共数据成员一样被使用的特殊方法(get/set方法)。属性结合了字段和方法的多个方面,对于对象的用户,它显示为字段;对于类的实现者,它是一个或两个代码块(用于表示get/set访问器)。写类的时候使用System.Serializable属性以便使类的成员可以序列化 方法:是一种用于实现可以由对象或类执行的计算或操作的成员。类的方法主要是和类相关联的动作,它是类的外部界面,对于那些私有的字段来说,外部界面实现对它们的操作一般只能通过方法来实现。方法在类或结构中声明,声明时需要制定访问级别、返回值、方法名称及方法参数。一个方法的签名由它的名称以及它的形参的个数、修饰符和类型组成。方法的签名是方法的唯一标识(同一个类中的区别标识)。 方法的重载:是指方法名相同,但参数类型、个数或顺序不同的方法,与返回值无关(同一类或子类之间) 方法的重写:子类对父类方法的重新实现(方法头相同,方法体即代码块不同) 事件:是使得对像和类提供通知的成员。一个类通过提供事件声明来定义一个事件,这看起来与域和事件声明相当类似,但是有一个event关键字。这个声明的类型必须是delegate类型。如下例子: public delegate void EventHandler(object sender, Event e); public class Button { public event EventHandler Click; public void Reset() { Click = null; } } 索引:是使得对象可以像数组一样被索引的成员 结构:一种值类型,几个数据组成的数据结构。向方法传递结构时,是通过传值方式传递的,结构实例化可以不用new,结构可以声明构造函数,但必须带参数,且声明的构造函数是用来对成员初始化的,必须包含每个字段。结构不能从另一个结构或类继承而来,但可以实现接口,结构中不能初始化实例。结构存储在栈中且只用来表示小的数据结构,类存储在托管堆中 类:是一种数据结构,是具有相同或相似结构、操作和约束规则的对象组成的集合。算法和数据结构的集合(对象),具有封装、继承、多态等特点。父类—基类、子类—派生类。类的多态是指不同的类进行同一操作可以有不同的行为。类是相同对象的集合,并为这些对象定义了编程语言上的属性和方法。类修饰符:new在类声明时使用,public公共的,访问不受限,protected只能从其所在类和所在类的子类中进行访问,internal只有其所在类才能进行访问,private私有的,abstract抽象类,不能实例化,sealed密封类,不能被继承 虚拟成员:声明为virtual的类成员 析构函数:以类名+~来命名的,不能有参数,不能有任何修饰符而且不能被调用。当某个类的实例被认为不再有效并符合析构条件时,.NET Framework类库的垃圾回收功能就会调用该类的析构函数实现垃圾回收,一个类只能有一个析构函数。一般准则是,除非有迫不得已的原因,不要使用析构函数,而应把清楚操作交给运行时完成 接口:声明的所有成员隐式的为public和abstract。在命名空间中声明的接口可以被授予public或internal访问类型。嵌套的接口可以被授予public、protected、internal、protected internal或private访问类型。默认为internal.接口的成员隐式的被声明为public和abstract访问类型且没有实现没有修饰符 密封类:密封类不能作为基类被继承,但可以继承别的类或接口,密封类中不能声明受保护的成员或虚成员,密封类不能声明为抽象的,声明密封类用sealed.密封方法只能用于对基类的虚方法进行实现,声明密封方法时同时使用sealed和override且必须通过重写基类中的虚方法来实现 名称空间:类似java中的包 集合: 代表: 访问修饰符:private、public、protected、internal:局部的 readonly:只读修饰符 new(新的)、static(静态的)、virtual(虚拟的)、override()、sealed(密封的)、abstranct(抽象的)、extern(外面的) 派生类调用基类的方法可以使用base关键字,如base.Method();

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值