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语句循环游标时,可以声明游标,但不用打开,读取,关闭游标。

  

最新文章

  1. Easyui datagrid行内【添加】、【编辑】、【上移】、【下移】
  2. Python 4 —— 函数与模块
  3. Redis_master-slave模式
  4. ADF_Controller系列4_通过创建ADF Menu作为页面向导(Part2)
  5. 【C语言模拟实现】浮点数-转-定点数
  6. C#完整的通信代码(点对点,点对多,同步,异步,UDP,TCP)
  7. iOS开发中自定义字体的方法
  8. UESTC 771 最大容积(前缀后缀和)
  9. Relax信息学题库须知
  10. VS2005、vs2008+WinXPDDK+DDKWizard配置驱动开发环境
  11. jfinal undertow web.xml
  12. Hadoop2.7.7_HA高可用部署
  13. 访问iis出现500.21错误
  14. [Go back to REDIS]
  15. Linux find查找指定文件 按照名称 然后cp拷贝到指定目录且指定文件名
  16. class-dump在osx 10.11以后安装方法
  17. linux -- &quot;./configure --prefix &quot;命令
  18. PAT甲 1046. Shortest Distance (20) 2016-09-09 23:17 22人阅读 评论(0) 收藏
  19. 分布式改造剧集三:Ehcache分布式改造
  20. kettle安装部署及远程执行

热门文章

  1. java基于xml配置的通用excel单表数据导入组件(四、DAO主处理类)
  2. WPP
  3. 直接下载adobe的完整安装包
  4. RHEL7磁盘分区挂载和格式化
  5. Yii PHP 框架分析 (一)
  6. nyoj 116 士兵杀敌(二)【线段树单点更新+求和】
  7. Linux安装Git
  8. 小物件之select单选下拉列表
  9. MINA学习之IoService
  10. iOS开发总结-UITableView 自定义cell和动态计算cell的高度