基础学习(二):PL/SQL编程

最近在看PL/SQL开发的基础知识,以下博文的作者总结的简洁明了,作为初步了解够用了。
原文链接:https://blog.csdn.net/yujikui1/article/details/80701817

首先,先介绍一下PL/SQL 是什么?
PL/SQL是是由甲骨文公司在90年代初开发,以提高SQL的功能。PL/SQL是嵌入在Oracle数据库中的编程语言之一。PL/SQL是Oracle数据库对SQL语句的扩展。在普通SQL语句的使用上增加了编程语言的特点,所以PL/SQL就是把数据操作和查询语句组织在PL/SQL代码的过程性单元中,通过逻辑判断、循环等操作实现复杂的功能或者计算的程序语言。

总结就是:PL/SQL是一门为扩展Oracle中SQL功能的编程语言。

在 pl/sql dev 开发工具中打开 SQL window 窗口可以进行PL/SQL 开发。 在左上角有输出框。可以查看由dbms_output.put_line( )得到的结果。
先来个Hello world 展示一下吧!

declare
    msg varchar(20);
begin
    msg := 'Hello world ! ';
    dbms_output.put_line(msg);

exception
    -- 单行注释
    /*
     * 多行注释 ,这部分是异常处理模块,可有可无。
     */
end;

declare 声明部分 – 所有变量,游标,子程序,和其他元素
begin - end ; – 程序主体,可执行命令

PL/SQL中常见符号解释:
||     字符串连接符
:=    赋值运算符
%    属性索引 使用%type可以使变量获得与字段相同的数据类型,用于不知道给什么类型才合适的变量
=     相等运算符

谈一种编程语言,肯定要说变量和数据类型呀!

PL/SQL 变量命名 : 由数字,字母,下划线,美元符号组成。字母开头。
变量分类:局部变量和全局变量。


变量的常见类型:


varchar2 : 可变长字符串
int : 整数类型
number (precision,scale) :
1. precision表示数字中的有效位,如果没有指定precision的话,oracle将使用38作为精度;
2. 如果scale大于零,表示数字精度到小数点右边的位数;scale默认设置为0;如果scale小于零,oracle将把该数字取舍到小数点左边的指定位数。


clob: 用于存储字符大块数据在数据库中 大小为 8 - 128 TB
date : 日期和时间


变量的定义分为局部变量和全局变量。

DECLARE
    -- Global variables
    num1 number := 95;
    num2 number := 85;
BEGIN
    dbms_output.put_line('Outer Variable num1: ' || num1);
    dbms_output.put_line('Outer Variable num2: ' || num2);
    DECLARE
        -- Local variables
        num1 number := 195;
        num2 number := 185;
    BEGIN
        dbms_output.put_line('Inner Variable num1: ' || num1);
        dbms_output.put_line('Inner Variable num2: ' || num2);
    END;
END;

SQL的SELECT INTO子句给PL/SQL变量赋值

declare
  c_id customers.id%type := 1;
  c_name customers.name%type;
  c_addr customers.address%type;
  c_sal customers.salary%type;
begin
  select name,address,salary into c_name,c_addr,c_sal from customers where id = c_id;
  dbms_output.put_line('Customer '||c_name||' from '||c_addr||' earns '||c_sal);
end;

PL/SQL 中的常量:

PI constant number := 3.14;

很不习惯呀,常量和变量名放在前面,数据的类型放在后面。。。

 

PL/SQL 中的运算符:

PL/SQL 中的条件控制语句:

注意: 每一次 if 结构结束都要用 end if; 这才表示 if 结束。

DECLARE
    a number(3) := 100;
BEGIN
    IF ( a = 10 ) THEN
        dbms_output.put_line('Value of a is 10' );
    ELSIF ( a = 20 ) THEN
        dbms_output.put_line('Value of a is 20' );
    ELSIF ( a = 30 ) THEN
        dbms_output.put_line('Value of a is 30' );
    ELSE
        dbms_output.put_line('None of the values is matching');
    END IF;
    dbms_output.put_line('Exact value of a is: '|| a );
END;

CASE 结构:

declare
  grade char(1) := 'A';
begin
  case grade
    when 'A' then dbms_output.put_line('A');
    when 'B' then dbms_output.put_line('B');
    else dbms_output.put_line('NO');
  end case;
end;

PL/SQL 中的循环控制语句:

举例说明:

DECLARE
    x number := 10;
BEGIN
    LOOP
        dbms_output.put_line(x);
        x := x + 10;
        IF x > 50 THEN
            exit;
        END IF;
    END LOOP;
    -- after exit, control resumes here
    dbms_output.put_line('After Exit x is: ' || x);
END;
DECLARE
    a number(2) := 10;
BEGIN
    WHILE a < 20 LOOP
        dbms_output.put_line('value of a: ' || a);
        a := a + 1;
    END LOOP;
END;
DECLARE
    a number(2);
BEGIN
    FOR a in 10 .. 20 LOOP   -- 10 .. 20 表示10-20 全包含
        dbms_output.put_line('value of a: ' || a);
    END LOOP;
END;


常用的操作字符串的函数:


UPPER(x) :x转换为大写字母,并返回该字符串
TRIM([trim_char FROM) x) : 从左侧和右侧修剪x字符的空格
SUBSTR(x, start [, length]) : 返回x的一个子开始于由start指定的位置。可选长度为子字符串
CHR(x) : 返回字符 x 的 ASCII 值
CONCAT(x, y) : 连接字符串x和y,并返回附加的字符串
INITCAP(x) : 每个单词的首字母x中转换为大写,并返回该字符串
INSTR(x, find_string [, start] [, occurrence]) :搜索find_string在x中并返回它出现的位置
INSTRB(x) : 返回另一个字符串中字符串的位置,但返回以字节为单位的值
LENGTH(x) : 返回x中的字符数
LOWER(x) : 在x转换为小写字母,并返回该字符串
LTRIM(x [, trim_string]) : 从x的左修剪字符


练习

1:使用loop语句求得前100个自然数的和。

declare
    i int:=0;
    sum_i int:=0;
begin
    loop
        i:=i+1;
        sum_i:=sum_i+i;
        exit when i=100;
    end loop;
    dbms_output.put_line('前100个自然数的和是:'||sum_i)
end;
    

2:使用while语句求得前100个自然数的和。

declare
    i int:=0;
    sum_i int:=0;
begin
    while i<=99 loop
        i:=i+1;
        sum_i:=sum_i+i;
    end loop;
    dbms_output.put_line('前100个自然数的和为:'||sum_i);
end;

3:使用for语句求得前100个自然数中偶数之和。

declare
    sum_i int:=0;
begin
    for i in reverse 1..100 loop     //遍历前100个自然数
        if mod(i,2)=0  then          //判断是否为偶数,mod(i,2)=0判断余数是否为0
            sum_i:=sum_i+i;
        end if;
    end loop;
    dbms_output.put_line('前100个自然数中偶数之和为:'||sum_i);
end;

注:for 语句中使用了关键字reverse,表示计数器i的值为递减状态,即i的初始值为100,随着每次递减1,最后一次for循环时i的值变为1。如果在for语句中不使用关键字reverse,则表示计数器i的值为递增状态,即i的初始值为1.(oracle教材p127,0是偶数,前100个自然数不到100?)

本节就先看到这里吧!下一篇再整理一下数组,函数,存储过程等方面的知识。
 

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
提供的源码资源涵盖了安卓应用、小程序、Python应用和Java应用等多个领域,每个领域都包含了丰富的实例和项目。这些源码都是基于各自平台的最新技术和标准编写,确保了在对应环境下能够无缝运行。同时,源码中配备了详细的注释和文档,帮助用户快速理解代码结构和实现逻辑。 适用人群: 这些源码资源特别适合大学生群体。无论你是计算机相关专业的学生,还是对其他领域编程感兴趣的学生,这些资源都能为你提供宝贵的学习和实践机会。通过学习和运行这些源码,你可以掌握各平台开发的基础知识,提升编程能力和项目实战经验。 使用场景及目标: 在学习阶段,你可以利用这些源码资源进行课程实践、课外项目或毕业设计。通过分析和运行源码,你将深入了解各平台开发的技术细节和最佳实践,逐步培养起自己的项目开发和问题解决能力。此外,在求职或创业过程中,具备跨平台开发能力的大学生将更具竞争力。 其他说明: 为了确保源码资源的可运行性和易用性,特别注意了以下几点:首先,每份源码都提供了详细的运行环境和依赖说明,确保用户能够轻松搭建起开发环境;其次,源码中的注释和文档都非常完善,方便用户快速上手和理解代码;最后,我会定期更新这些源码资源,以适应各平台技术的最新发展和市场需求。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值