Oracle PL/SQL 第四章--数据类型

简介: Oracle PL/SQL 第四章--数据类型

Oracle PL/SQL 第四章–数据类型

1、数值类型

序号 类型名称 说明
1 PLS_INTEGER 带符号整数:-2,147,483,6482,147,483,647,以32位表示
2 BINARY_INTEGER 带符号整数:-2,147,483,6482,147,483,647,以32位表示
3 BINARY_FLOAT 单精度IEEE 754格式浮点数
4 BINARY_DOUBLE 双精度IEEE 754格式浮点数NUMBER
5 NUMBER(prec, scale) 1E-130到(但不包括)1.0E126范围内的绝对值的定点或浮点数。NUMBER变量也可以表示0
6 DEC(prec, scale) ANSI特定定点类型,最大精度为38位十进制数字
7 DECIMAL(prec, scale) IBM具体定点类型,最大精度为38位十进制数字
8 NUMERIC(pre, secale) 浮点型,最大精度为38位十进制数
9 DOUBLE PRECISION ANSI特定浮点类型,最大精度为126位二进制数字(大约38位十进制数字)
10 FLOAT ANSI和IBM特定浮点类型,最大精度为126位二进制数字(大约38位十进制数字)
11 INT ANSI特定整数类型,最大精度为38位十进制数
12 INTEGER ANSI和IBM特定整数类型,最大精度为38位十进制数
13 SMALLINT ANSI和IBM特定整数类型,最大精度为38位十进制数
14 REAL 浮点型,最大精度为63位二进制数字(约十八位数)

以下的声明方式有效

DECLARE 
  number1 INTEGER; 
  number2 REAL; 
  number3 DOUBLE PRECISION; 
BEGIN 
  null; 
END;

2、字符类型

序号 类型名称 说明
1 CHAR 固定长度字符串,最大大小为32767字节
2 VARCHAR2 最大大小为32767字节的可变长度字符串
3 NCHAR 固定长度的国家字符串,最大大小为32767字节
4 NVARCHAR2 可变长度的国家字符串,最大大小为32767字节
5 LONG 最大长度为32760字节的可变长度字符串
5 ROWID 物理行标识符,普通表中的行的地址

3、布尔数据类型

BOOLEAN数据类型存储逻辑运算中使用的逻辑值。逻辑值为布尔值:TRUE,FALSE以及NULL值。

但是,SQL没有类似于BOOLEAN的数据类型。 因此,布尔值不能用于

  • SQL语句
  • 内置SQL函数(如:TO_CHAR)
  • 从SQL语句调用PL/SQL函数

4、日期类型

DATE数据类型用于存储固定长度的数据日期时间,其包括自午夜以来以秒为单位的时间。 有效期为公元前4712年1月1日至公元9999年12月31日。

每个DATE类型的数据值包括世纪,年,月,日,时,分,秒。下表显示每个字段的有效值 :

序号 字段名 有效值 有效间隔值
1 YEAR -47129999(不包括第0年) 任意非零整数
2 MONTH 01 ~ 12 01 ~ 11
3 DAY 0131(限于MONTHYEAR的值,根据本地日历的规则) 任何非零整数
4 HOUR 00 ~ 23 00 ~ 23
5 MINUTE 00 ~ 59 00 ~ 59
6 SECOND 00 ~ 59.9(n),其中9(n)是时间分秒的精度 00 ~ 59.9(n),其中9(n)是时间分秒的精度

5、大对象(LOB)数据类型

大对象(LOB)数据类型指的是大数据项,如文本,图形图像,视频剪辑和声音波形。 LOB数据类型允许对数据进行高效,随机,分段访问。以下是预定义的PL/SQL LOB数据类型

序号 数据类型 描述 大小
1 BFILE 用于在数据库外的操作系统文件中存储大型二进制对象 取决于系统,但不得超过4GB
2 BLOB 用于在数据库中存储的大型二进制对象 8TB128TB
3 CLOB 用于在数据库中存储大字符数据 8TB128TB
4 NCLOB 用于在数据库中存储大块NCHAR数据 8TB128TB

6、用户定义的子类型

子类型是另一种数据类型的子集,它称为基本类型。子类型具有与其基本类型相同的操作,但只有基本类型有效值的子集。

PL/SQL预定义包STANDARD中的几个子类型。 例如,PL/SQL预先定义子类型CHARACTERINTEGER,如下所示:

SUBTYPE CHARACTER IS CHAR; 
SUBTYPE INTEGER IS NUMBER(38,0);

可以定义和使用自己的子类型。以下程序说明了如何定义和使用用户定义的子类型

DECLARE 
   SUBTYPE name IS char(20); 
   SUBTYPE message IS varchar2(100); 
   salutation name; 
   greetings message; 
BEGIN 
   salutation := 'Reader '; 
   greetings := 'Welcome to the World of PL/SQL'; 
   dbms_output.put_line('Hello ' || salutation || greetings); 
END; 
/


相关文章
|
21天前
|
SQL 数据采集 监控
局域网监控电脑屏幕软件:PL/SQL 实现的数据库关联监控
在当今网络环境中,基于PL/SQL的局域网监控系统对于企业和机构的信息安全至关重要。该系统包括屏幕数据采集、数据处理与分析、数据库关联与存储三个核心模块,能够提供全面而准确的监控信息,帮助管理者有效监督局域网内的电脑使用情况。
16 2
|
1月前
|
SQL 监控 Oracle
Oracle SQL性能优化全面指南
在数据库管理领域,Oracle SQL性能优化是确保数据库高效运行和数据查询速度的关键
|
1月前
|
SQL 存储 Oracle
Oracle数据库SQL语句详解与应用指南
在数字化时代,数据库已成为各类企业和组织不可或缺的核心组件。Oracle数据库作为业界领先的数据库管理系统之一,广泛应用于各种业务场景。掌握Oracle数据库的SQL语句是数据库管理员、开发人员及运维人员的基本技能。本文将详细介绍Oracle数据库SQL语句的基本概念、语法、应用及最佳实践。一、Or
55 3
|
1月前
|
SQL Oracle 关系型数据库
Oracle SQL:了解执行计划和性能调优
Oracle SQL:了解执行计划和性能调优
53 1
|
3月前
|
SQL Oracle 关系型数据库
SQL与PL/SQL:数据库编程语言的比较
【8月更文挑战第31天】
66 0
|
4月前
|
SQL 存储 Oracle
TDengine 3.3.2.0 发布:新增 UDT 及 Oracle、SQL Server 数据接入
**TDengine 3.3.2.0 发布摘要** - 开源与企业版均强化性能,提升WebSocket、stmt模式写入与查询效率,解决死锁,增强列显示。 - taos-explorer支持geometry和varbinary类型。 - 企业版引入UDT,允许自定义数据转换。 - 新增Oracle和SQL Server数据接入。 - 数据同步优化,支持压缩,提升元数据同步速度,错误信息细化,支持表名修改。 - 扩展跨平台支持,包括麒麟、Euler、Anolis OS等。
126 0
|
SQL 存储 Oracle
|
2月前
|
关系型数据库 MySQL 网络安全
5-10Can't connect to MySQL server on 'sh-cynosl-grp-fcs50xoa.sql.tencentcdb.com' (110)")
5-10Can't connect to MySQL server on 'sh-cynosl-grp-fcs50xoa.sql.tencentcdb.com' (110)")
|
4月前
|
SQL 存储 监控
SQL Server的并行实施如何优化?
【7月更文挑战第23天】SQL Server的并行实施如何优化?
113 13
|
4月前
|
SQL
解锁 SQL Server 2022的时间序列数据功能
【7月更文挑战第14天】要解锁SQL Server 2022的时间序列数据功能,可使用`generate_series`函数生成整数序列,例如:`SELECT value FROM generate_series(1, 10)。此外,`date_bucket`函数能按指定间隔(如周)对日期时间值分组,这些工具结合窗口函数和其他时间日期函数,能高效处理和分析时间序列数据。更多信息请参考官方文档和技术资料。