PL/SQL数据类型

目录

标量数据类型

1、数值类型

2、字符类型

3、时间类型

4、布尔类型

引用数据类型

1、%TYPE类型

2、%ROWTYPE类型


        PL/SQL数据类型不但支持Oracle SQL中的数据类型,还有自身自带的数据类型。PL/SQL数据类型可以分为标量数据类型引用数据类型两大部分。

标量数据类型

        标量数据类型的变量只有一个值,且内部没有分量。标量数据类型包括数字型,字符型,日期型和布尔型。这些类型有的是 Oracle SQL 中有的数据类型,有的是 PL/SQL 自身附加的数据类型。下面我们来详细介绍一下常用的标量数据类型:

1、数值类型

        主要用来存储数值类型的数据。常用的有NUMBER、PLS_INTEGER、BINARY_INTEGER和SIMPLE_INTEGER类型。

  • NUMBER:可以存储小数和整数类型数据(定点或浮点数),语法为:NUMBER(precision, scale),其中p表示的是精度(总位数),s表示的是小数点后的位数。
  • PLS_INTEGER、BINARY_INTEGER、SIMPLE_INTEGER:主要用来存储整数类型,它们存储整数的范围都是-(2^31)~(2^31-1)。但是BINARY_INTEGER发生内存溢出的时候会给它分配一个NUMBER类型的数据,而PLS_INTEGER会直接抛异常报错,SIMPLE_INTEGER是PLS_INTEGER的一个子类型,它不允许存在NULL值数据。

2、字符类型

        用来存储单个字符或字符串。主要有如下类型:

  • CHAR:存储固定长度的字符串。CHAR(n):默认长度是1,当字符串长度小于n时,会自动右补空格,所以在取数据的时候要注意补空格。
  • VARCHAR2:存储可变长度的字符串。VARCHAR2(n),最大存储的长度为4000个字节。当字符串长度小于n时,不会补齐空格。
  • LONG:存储可变长度的字符串。不同于VARCAHR2类型,它对于字段的存储长度可达2G,但是作为PL/SQL变量,和VARCHAR2一样,只能存储最大32767字节。

3、时间类型

        主要和SQL中的时间类型一致,有DATE和TIMESTAMP两种时间类型。

4、布尔类型

        PL/SQL程序中的逻辑判断的值有:TRUE、FALSE、NULL值。

引用数据类型

        引用数据类型是PL/SQL程序语言特有的数据类型,是用来引用数据库当中的某一行或者某个字段作为数据类型的声明。其中有两种引用类型:%TYPE%ROWTYPE

1、%TYPE类型

        引用数据库表中的某列的类型作为某变量的数据类型,也可以直接引用PL/SQL程序中某个变量作为新变量的数据类型。如:

DECLARE
    -- 通过学生姓名字段声明LS_STUNAME,注意这里不能用表的别名!
    LS_STUNAME STUINFO.STUNAME%TYPE;
BEGIN
    SELECT T.STUNAME INTO LS_STUNAME
    FROM STUINFO T
    WHERE T.STUID = 'ST1001';
    DBMS_OUTPUT.PUT_LINE(LS_STUNAME);
EXCEPTION
    WHEN NO_DATA_FOUND THEN
        DBMS_OUTPUT.PUT_LINE('student not found!');
END;
/

2、%ROWTYPE类型

        %ROWTYPE类型是PL/SQL程序引用数据库表中的一行作为数据类型,即 RECORD 类型(记录类型)表示一条数据记录。类似 Java 程序当中的对象的实例,可以使用"."来访问记录中的属性。如:

        我们通过查询学生信息表(stuinfo)中学号为"ST1001"的数据记录赋值给ls_stuinfo(%ROWTYPE)变量,结果如下:

DECLARE
    LS_STUINFO STUINFO%ROWTYPE;
    LS_OBJ VARCHAR2(50);
BEGIN
    SELECT T.* INTO LS_STUINFO
    FROM STUINFO T
    WHERE T.STUID = 'ST1001';
    LS_OBJ := 'ID:'||LS_STUINFO.STUID||',Name:'||LS_STUINFO.STUNAME||',Age:'||LS_STUINFO.STUAGE;
    DBMS_OUTPUT.PUT_LINE(LS_OBJ);
EXCEPTION
    WHEN NO_DATA_FOUND THEN
        DBMS_OUTPUT.PUT_LINE('student not found!');
END;
/
  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值