PL/SQL是没命名的存储过程,函数,触发器,PL/SQL块的语法格式如下:
[declare]
--声明部分,可选
begin
--执行部分,必须
[exception]
--异常处理部分,可选
end
PL/SQL块每条语句必须用分号结束,单行注释--,多行注释/*...*/,下面是一个PL/SQL块例子
set serveroutput on
declare
--声明变量
a int := 1; --声明并且赋值
address varchar2(128);
mobilephone varchar2(20);
username varchar2(50);
begin
select address, mobilepone, usrename into address, mobilephone, username from orderinfo where orderid = 1
dbms_output.put_line('用户' || username || '的地址是' || address || '手机是' || mobilephone); --||字符连接运算符
exception
when others then
dbms_output.put_line('获取数据失败!');
end;
数据类型
1.数值类型:numeric,dec,decimal,double,integer,int,smallint,binary_integer,pls_integer
2.字符类型:varchar2, char, long,nchar,nvarchar2
varchar2最大长变为4000字节,长度可变
char最大长度为2000字节,长度不可变
long最大长度为32767字节,2GB
3.日期类型:date,7个字节
4.布尔类型boolean
特殊数据类型
1.%type可以声明一个与指定列名相同的数据类型
var_orderid orderinfo.orderid%type; var_orderid与orderinfo表中的orderid字段数据类型相同
2.record数据类型
用type语句进行定义,record类型是一种结构化数据类型,相当于C#的结构类型,可以存储多个列值组成一行,格式:
type record_type is record
(
var_member1 data_type [not null] [:=default_value],
...
var_member2 data_type [not null] [:=default_value]
)
例子:
type orderinfo is record
(
orderid int not null:=1,
ordercode varchar2(20) not null
)
3.%rowtype
它可以根据表中的结构定义一种特殊的数据类型
var_orderinfo orderinfo%rowtype --var_orderinfo变量名,orderinfo表名
定义变量和常量
<变量名> <数据类型>[(长度):=<初始值>];
var_name int;
var_name2 varchar2(20);
var_name3 numeric:=3;
定义常量
<变量名> constant <数据类型>:=<常量值>;
con_name constant integer:=3;
流程控制
1.if语句
if <condition_expression1> then
plsql_sentence;
elseif <condition_expression2> then
plsql_sentence;
else
plsql_sentence;
end;
2.case语句
case <selector>
when <expression_1> then plsql_sentence;
when <expression_2> then plsql_sentence;
.......
when <expression_n> then plsql_sentence;
[else plsql_sentence;]
end case;
循环语句
1.loop
loop语句先执行一次循环体,然后再判断exit when关键字后面的条件表达式的值true还是false,如果是true退出循环体,否则继续执行循环体
loop
plsql_sentence;
exit when end_condition_exp;
end loop;
例子:
declare
sum int := 0;
i int := 0;
begin
loop
i:= i+1;
sum := sum + i;
exit when i= 100;
end loop;
end;
2.while语句
while condition loop
plsql_sentence;
end loop;
3.for语句
for counter in [reverse] min..max loop
plsql_sentence;
end loop;
默认情况下计数器的值会循环递增,reverse关键字使计数器会随着循环器递减
for i in 1..100 loop
dbms_output.put_line(i);
end loop;
pl/sql游标
显示游标
使用游标顺序
1.声明游标
2.打开游标
3.读取游标
4.数据是否为空,是关闭游标,否继续读取
1.声明游标
cursor cur_name[(input_parameter1,input_parameter2...)]
[return ret_type]
is select_sentence;
input_parameter:para_name [in] datatype [{:= default|para_value}]
例子
cursor cur_orderinfo(ordercode in varchar2 := '0000000')
is select * from orderinfo where ordercode= ordercode;
这里的参数不可以指定长度,否则会报错
2.打开游标
open cur_name[(para_value[,para_value2]...)];
para_value:指定输入参数的值
open cur_orderinfo('11111111');
param_value是可选参数,如果未指定则用声明使用的默认值,如果指定了则用这里指定的值
3.读取游标
fetch cur_name into {variable};
例子:
var_orderinfo orderinfo%rowtype;
fetch cur_order into var_orderinfo;
如果有值的话,可以用var_orderinfo.orderid读取数据
4.关闭游标
close cur_name;
例子:
close cur_orderinfo;
游标的属性
1.%found 布尔型属性 ,如果SQL语句至少影响到一行数据,则该属性返回御前,否则返回false
2.%notfound 与%found属性相反
3.%rowcount 数字型属性,返回受SQL语句影响的行数
4.%isopen 布尔型属性,游标打开返回true,关闭返回false
例子:
set serveroutput on
declare
cursor cur_orderinfo (username in varchar2)
is select * from orderinfo where username= username;
var_orderinfo orderinfo%rowtype;
begin
open cur_orderinfo('abcd');
fetch cur_orderinfo into var_orderinfo;
while cur_orderinfo%found loop
dbms_output.put_line('订单编号:' || var_orderinfo.ordercode);
fetch cur_orderinfo into var_orderinfo;
end loop;
close cur_orderinfo;
exception
when others then
dbms_output.put_line('错误');
end;
隐式游标
在执行一个SQL语句时,Oracle会自动创建一个隐式游标。这个游标是内存中处理该语句的工作区域,隐式游标主要是处理数据操纵语句(如update,
delete语句)的执行结果,当然特殊情况下,也可以处理select语句的查询结果。由于隐式游标也有属性,当使用隐式游标属性时,需要在属性前面加上隐式
游标的默认名称--SQL。在实际编程中,经常使用隐式游标来判断更新数据行或删除数据行的情况。
set serveroutput on
begin
update orderinfo set mobilephone = '1111111111' where username = 'abcd';
if sql%notfound then
dbms_output.put_line('此用户不需要更新手机号码');
else
dbms_output.put_line('更新手机成功');
end if;
end;
通过for语句循环游标
1.for语句循环隐式游标
begin
for var_orderinfo in (select * from orderinfo)
loop
sql_sentences;
end loop;
end;
2.for语句循环显示游标
declare
cursor cur_orderinfo is select * from orderinfo;
begin
for var_orderinfo in cur_orderinfo
loop
sql_sentences;
end loop;
end;
for语句循环游标时,可以声明游标,但不用打开,读取,关闭游标。