PLSQL语句

DECLARE 声明部分

BEGIN 程序编写,SQL语句

EXECPTION 处理异常

END;

/

声明部分(DECLARE)

SQL> set serveroutput on --打开输出

SQL> declare

  2  v_num number;

  3  begin

  4  v_num:=30;

  5  dbms_output.put_line('V_NUM'||v_num);

  6  end;

  7  /

V_NUM30

查找empno为7900的员工的名字

declare

v1 scott.emp.ename%type;

v2 scott.emp.sal%type;

begin

select ename,sal into v1,v2 from scott.emp where empno=7900;

dbms_output.put_line('ename:'||v1);

dbms_output.put_line('sal:'||v2);

end;

/

set serveroutput on

/

查找雇员号和姓名

set serveroutput on

declare

   v_eno number;

   v_ename varchar2(10);

   begin

   v_eno:=&empno;

   select ename into v_ename from emp where empno=v_eno;

   dbms_output.put_line('number:'||v_eno||'name:'||v_ename);

   end;

   /

求平均工资

SQL> !vi test.sql

SQL> !cat test.sql

declare

v_avgsal number(6,2);

begin

select avg(sal) into v_avgsal from scott.emp where deptno=&no;

dbms_output.put_line('avg_sal:'||v_avgsal);

end;

SQL> @test.sql

  7  /

Enter value for no: 20

old   4: select avg(sal) into v_avgsal from scott.emp where deptno=&no;

new   4: select avg(sal) into v_avgsal from scott.emp where deptno=20;

PL/SQL procedure successfully completed.

声明变量的语法

组成:

CONSTANT:定义常量

NOT NULL:表示此变量不允许设置为NULL

:=value:表示在变量声明时,设置好其初始化内容

DECLARE

V_resultA CONSTANT NUMBER NOT NULL:=100;

BEGIN

DBMS_OUTPUT.put_line('v_resultA常量内容:'||(v_resultA));

END;

/

使用%TYPE声明变量类型(对列类型赋值)

DECLARE

eno emp.emono%TYPE;

ename emp.ename%TYPE;

BEGIN

  DBMS_OUTPUT.put_line(请输入雇员编号:);

  dbms_output.put_line('sal:'||v2);

end;

使用%ROWTYPE标记可以定义表中一行记录的类型(对行类型赋值)

SQL> DECLARE

  2  deptRow dept%ROWTYPE;

  3  BEGIN

  4  SELECT * INTO deptRow FROM dept WHERE deptno=10;

  5  DBMS_OUTPUT.put_line('deptno:'||deptRow.deptno||',name:'||deptRow.dname||',loc:'||deptRow.loc);

  6  end;

  7  /

使用关系运算符

DECLARE

        v_url VARCHAR2(50):='www.vdedu.com.cn';

        v_num1 NUMBER:=80;

        v_num2 NUMBER:=30;

BEGIN

        IF v_num1>v_num2 THEN

                DBMS_OUTPUT.put_line('A');

        END IF;

        IF v_url LIKE '%vdedu%' THEN

                DBMS_OUTPUT.put_line('includes vdedu');

        END IF;

END;

 

 

AND   OR   NOT运算符

 

DECLARE

v_flag1 BOOLEAN:=TRUE;

v_flag2 BOOLEAN:=FALSE;

v_flag3 BOOLEAN;

BEGIN

IF v_flag1 and (NOT v_flag2) THEN

DBMS_OUTPUT.PUT_LINE('1');

END IF;

IF v_flag1 or v_flag3 THEN

DBMS_OUTPUT.PUT_LINE('2');

END IF;

IF v_flag1 and v_flag3 is null THEN

DBMS_OUTPUT.PUT_LINE('3');

END IF;

END;

PL/SQL常用语法及举例的更多相关文章

  1. oracle入门(6)——PL/SQL常用语法

    [本文介绍] 本文不是”语法大全“,只是记录下作项目里自己常用的一些语法.方便查询. [语法] [输出]   (1)输出语法 DBMS_OUTPUT.PUT_LINE( ) [定义]   (1)定义变 ...

  2. PL/SQL常用表达式及举例(二)

    使用LOOP循环 declare v_i number:=1; begin loop dbms_output.put_line('v_i='||v_i); exit when v_i>=3; v ...

  3. PL/SQL常用表达式及举例(一)

    IF 判断条件 THEN 满足条件时执行语句 END IF; DECLARE v_countResult NUMBER; BEGIN SELECT COUNT(empno) INTO v_countR ...

  4. Sql常用语法以及名词解释

    Sql常用语法以及名词解释 SQL分类: DDL—数据定义语言(CREATE,ALTER,DROP,DECLARE) DML—数据操纵语言(SELECT,DELETE,UPDATE,INSERT) D ...

  5. sql 常用语法汇总

    Sql常用语法 SQL分类: DDL—数据定义语言(CREATE,ALTER,DROP,DECLARE) DML—数据操纵语言(SELECT,DELETE,UPDATE,INSERT) DCL—数据控 ...

  6. PL/SQL基本语法

    *2.PL/SQL基本语法   1)匿名块   一段不能在数据库存储的PL/SQL. 基本结构如下:   DECLARE     //变量的声明定义区域(可省略)   BEGIN     //业务处理 ...

  7. PL/SQL基础语法入门

    先前安装了PL/SQL软件 PL/SQL全称为Procedural Language/SQL. PL/SQL也是一种程序语言,叫做过程化SQL语言,是Oracle数据库对SQL语句的扩展 打PL/SQ ...

  8. Oracle PL/SQL入门语法点

    PL_SQL:带有分支和循环,面向过程匿名块:declare(可选,声明各种变量和游标的地方)begin(必要的,从此开始执行)exception(抓取到异常后执行的)end;[sql] view p ...

  9. PL/SQL常用设置 可看引用位置更清晰直观 引自:http://blog.csdn.net/xiaoqforever/article/details/27695569

    引自:http://blog.csdn.net/xiaoqforever/article/details/27695569 1,登录后默认自动选中My Objects 默认情况下,PLSQL Deve ...

随机推荐

  1. 【Python 爬虫系列】从某网站下载小说《鬼吹灯》,正则解析html

    import re import urllib.request import urllib.parse import urllib.error as err import time # 下载 seed ...

  2. hbase2.0.0-安装部署

    依赖hadoop 环境,我这边的版本是hadoop-2.6.5 选择hbase2.0.0版本的时候,去官网查看支持的hadoop版本 1.伪分布式安装 下载:http://mirror.bit.edu ...

  3. HttpClient(五)-- 模拟表单上传文件

    1.maven依赖 <dependency> <groupId>org.apache.httpcomponents</groupId> <artifactId ...

  4. python中的数据类型与json的数据类型之间的转化

    什么是json: JSON(JavaScript Object Notation) 是一种轻量级的数据交换格式.易于人阅读和编写.同时也易于机器解析和生成.它基于JavaScript Programm ...

  5. PHP中$_SERVER的详细用法

    PHP中$_SERVER的详细用法 $_SERVER['PHP_SELF'] #当前正在执行脚本的文件名,与 document root相关. $_SERVER['argv'] #传递给该脚本的参数. ...

  6. GitHub----初学习(一)

    刚开始学习GitHub,在这借鉴一下别人的总结,http://youngxhui.github.io/2016/05/03/GitHub-for-Windows%E4%BD%BF%E7%94%A8%E ...

  7. 删除sql注入

    ), );--过滤字符串 字符串及之后的数据将被替换为空 set @FilterStr='</title><style>.alx2{'; set @curTable='user ...

  8. 【Java基础系列】Java IO系统

    前言 创建好的输入/输出系统不仅要考虑三种不同种类的IO系统(文件,控制台,网络连接)还需要通过大量不同的方式与他们通信(顺序,随机访问,二进制,字符,按行,按字等等). 一.输入和输出 Java的I ...

  9. Android.mk(3) 宏

    https://www.jianshu.com/p/7c20b299ee63 传统上我们一直称这种东西为makefile中的变量,其实本质上就是一个宏,只是做的是字符串替换.我们何如就把它叫做宏呢. ...

  10. Simple Mail Transfer Protocol --- SMTP协议

    https://en.wikipedia.org/wiki/Simple_Mail_Transfer_Protocol   Simple Mail Transfer Protocol