oracle之PL/SQL编程

时间过得好快 ,快三月没写简书了 今天来练练手

PL/SQL块结构:


declare   —声明部分,可选

声明所用到的变量,常量和游标  在这个SQL块中声明的这些只能在这个块中使用,其他的SQL块是不能够参与调用的,


begin     — 执行部分,必选

select    定义好的变量名  into   所在表中的指定的列   from   表  where   过滤条件

////******** 使用 select    into 语句   用于表示将从数据库中的哪一张表中哪些指定的列选择出来存放在事先定义好的变量中去

  if then

endif

end;

exception   — 异常处理 可选

when ............then

when..............then

end;

简单小李子:

SQL>set serveroutput  on//必须打开服务端

SQL>declare

       a int :=100;

       b int :=200;

       c number;

begin

            c:(a+b)/(a-b);

             dbms_output.put_line(c);

excpetion

             when zero_divide then

             dbms_output.put_line(divider don't for zero);

end;

注释: 单行注释   -- while   多行注释   /*    需注释的代码*/   和Java得注释一样

数据类型与定义变量与常量



1.基本数据类型

    1.1 数值类型 number

     1.2字符类型  char    varchar

     1.3 日期类型 date

     1.4 boolean 类型  T F N   三种返回值


2.特殊数据类型

2.1% TYPE类型

使用该关键字可以声明一个与指定列名称相同的数据类型,通常紧跟在指定列后面。

eg:   声明一个emp中job列的数据类型完全相同的var-job

       declare

           var-job emp.job %type

好处2个点:1.用户不必查看表中数据的各个数据类型,就可以确定所定义的变量能够存储检索的数据。2.如果对表中已有列的数据类型进行修改,则用户不必考虑对已定义的变量所使用的数据类项进行修改,因为%type 可以自动进行变量上的调整。


2.2 record 类型 或者叫记录类型       与Java中的类有相似的地方

  eg:  

type record_type is record


var-m1  data_type ;

var-m2    data_type ;

var-m3    data_type ;
var-m4     data_type ;

var-m5    data_type ;

)


举个栗子:

set serveroutput on //   必须打开服务 不然下面没法执行

declare

         type emp_type is recode

(

       var_ename varchar2(20),

       var_job       varchar2(20),

       var_sal        varchar2(20)


);

empinfo emp_type;             //    定义变量 empinfo  类型时记录形,对这个变量操作可以对以上三个成员变量操作 ,减少编程的复杂度和代码的冗余度。[感觉像是C语言中的结构体更合适点吧]

begin   

         select ename ,job,sal into  from empinfo from emp where empmo=9527;

dbms_output.put_line(empinfo.var_name||empionfo.var_job||empinfo.var_sal);


end;


3.%rowtype


语法格式:

row var_name table_name%rowtype

rowvar_name :表示可以存贮一行数据的变量名   注意 这是一行数据

table_name :指定的表名。


eg:

set serveroutput on

declare

rowvar_emp emp %rowtype

begin select *  into  rowvar-emp from emp where empno =9527;

dbms_output.put_line(empinfo.var_name||empionfo.var_job||empinfo.var_sal);

end;

\



定变量和常量

1.定义变量

<变量名><类型>[长度:=初始值]

eg:name varchar2(50):=‘克里斯多夫司机’;

定义常量

<常量名>constant<数据类型>:=<常数值>

eg:months constant intrger:=12;

流程控制语句


1选择语句

  


2循环语句

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,547评论 6 477
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,399评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,428评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,599评论 1 274
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,612评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,577评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,941评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,603评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,852评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,605评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,693评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,375评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,955评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,936评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,172评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 43,970评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,414评论 2 342

推荐阅读更多精彩内容

  • 1.SQL基础 数据定义语言DDL:create(创建)、alter(更改)和drop(删除)命令。 数据操纵语言...
    文袁阅读 705评论 0 4
  • 1.PLSQL入门 Oracle数据库对SQL进行了扩展,然后加入了一些编程语言的特点,可以对SQL的执行过程进行...
    随手点灯阅读 595评论 0 8
  • 1.简介 数据存储有哪些方式?电子表格,纸质文件,数据库。 那么究竟什么是关系型数据库? 目前对数据库的分类主要是...
    乔震阅读 1,699评论 0 2
  • 十月中以来,温哥华变成了雨哥华,绵绵不绝的秋雨下个不停,甚至创造了十一月份的连续下雨记录,我们的健行活动也因此停顿...
    游闲温哥华阅读 1,253评论 0 2
  • 没有一块空地, 能够腾出来装我的尸体, 因为我的心, 是长眠于寂寞的土地。 没有人能够忘了呼吸, 因为叹息是歌唱的...
    曾龙纸媒写作发表培训阅读 226评论 0 1