数据类型

char, Nchar

varchar2, Nvarchar2

clob, Nclob

number

number(9, 2);  -- 定点小数, 小数点左边7位, 右边2位

number, 浮点小数

number(2) 整数

pls_integer: 由硬件实现算法的整数类型, 顾名思义, 效率高, 但是兼容性...

for 循环计数器的类型是 PLS_INTEGER

ROWID 和 UROWID 用来代表某个表中某条记录的地址, ROWID 代表了表中一行记录的唯一物理地址, UROWID代表了一个索引组织表(iot)中一条记录的逻辑地址.

游标变量

强 ref cursor

declare

type book_data_t is ref cursor return book%rowtype;    -- 一种数据类型

book_curs_var book_data_t;

弱 ref cursor

declare

type book_data_t is ref cursor;   -- 类型只声明是一个游标, 并没有关联到任何一个特殊的记录结构

book_curs_var book_data_t;

book_curs_var_b sys_refcursor;

internet 数据类型, 例如 xml, url 等, oracle 提供支持.

Any 数据类型, 包括 AnyType, AnyData, AnyDataSet.

用户定义数据类型

声明一个变量

当你声明一个变量时, PLSQL会分配出一块内存空间:

name datatype [not null] [:= | default default_assignment];

例如:

declare

l_total_count number;

l_dollar_amount number(10, 2);

l_right_now date not null default system;

l_favorite_flavor varchar2(100) := ‘Anything with chocolate actually;

TYPE list_of_books_t IS table of book%rowtype index by binary_integer;  -- 自定义类型

oreilly_oracle_books list_of_books_t;

声明常量

常量, 必须直接提供缺省值.

name constant datatype [not null] := | default default_value;

例如:

declare

l_curr_year constant pls_integer := to_number(to_char(sysdate, ‘yyyy’));

l_steven constant person_ot :=

person_ot(‘human’, ‘Steven feuerstein’, 175, to_date(‘09-23-1958’, ‘mm-dd-yyyy’));

锚定

你在声明变量时通常都是采用"硬编码"即明确指定数据类型的方式, 如果要从数据库表或者其他PL/SQL程序结构获得数据, 一个更好的实践方式是把变量声明和对象"锚定"在一起, 所谓一个"锚定"的数据类型, 就是告诉 pl/sql 按照已经定义好的数据结构来设置变量的数据类型, 这个定义好的数据结构可能是: 另一个Pl/sql变量, 一个预定义的 type 或者 subtype, 一个数据库表或者表中一列, plsql 提供两种锚定方法:

标量锚定: %type

记录锚定: %rowtype

DECLARE

l_book book%rowtype;

begin

select * into l_book

from book

where isbn = ‘1-5692-335-9’

process_book(l_book);

end;

这种锚定是一种依赖关系, 即"被锚定" 元素发生改变, 使用锚定的代码就会标识为无效, 一旦代码被重新编译, 锚定又会重新建立.

not null 数据类型的锚: 当你声明变量时, 你可以要求这个变量时not null的, 如果其他变量用这个变量的%type属性声明的, 那么这个约束(not null) 也会传递给这个新的变量.

数据类型转换

推荐使用显示类型转换, 例如 to_char, to_number, to_date 等

即 使用显示函数进行转换.

cast 函数: 例如:

select employee_id, cast(hire_date as varchar2(30)) from employee;

或者:

declare

hd_display varchar2(30);

begin

hd_display := cast(sysdate as varchar2);

end;

convert 函数

convert(string_in in varchar2, new_char_set varchar2 [, old_char_set varchar2]) return varchar2

convert 仅仅是吧这个字符集中的字母或者符号替换成另一个字符集中对应的字母或者符号, 常用的两个字符集是 WE8 MSWIN1252 和 AL16UTF16

还有其他一些函数, 例如将16进制数转换成2进制数等等.

plsql programming 07 使用数据的更多相关文章

  1. plsql修改某一行数据

    plsql修改某一行数据时, 在查询语句后面加上for update,再点击

  2. PLSQL Developer导入Excel数据

    LSQL Developer导入Excel数据 最近处理将Excel数据导入Oracle的工作比较多.之前都是采用Sqlldr命令行导入的方式处理.每次导入不同格式的Excel表数据,都需要先把Exc ...

  3. PLSQL读取XML的数据

    最近公司做的几个项目,都是通过EBS与外部系统的Web Service进行数据的交互,而调用Web Service的时候,我们所传送的数据,都是按照约定的XML格式来传递,所以EBS接收到数据之后,需 ...

  4. plsql programming 17 过程, 函数与参数

    代码模块化, 即将一大块代码拆成若干小块(过程), 然后就可以在其他模块调用这些模块了, 这样, 重用性更好, 也方便管理. 过程: 过程是一个可以像执行 PL/SQL 语句一样调用的程序, 一个过程 ...

  5. plsql programming 16 动态SQL和动态PLSQL

    动态SQL 是指在执行时才构建 SQL 语句, 相对于静态 sql 的编译时就已经构建. 动态PLSQL 是指整个PL/SQL代码块都是动态构建, 然后再编译执行的. 作用: 1. 可以支持 DDL ...

  6. (转)PLSQL Developer导入Excel数据

    场景:近来在做加班记录的统计,主要是统计Excel表格中的时间,因为我对于Excel表格的操作不是很熟悉,所以就想到把表格中的数据导入到数据库中,通过脚本语言来统计,就很方便了!但是目前来看,我还没有 ...

  7. plsql 导入导出表、数据、序列、视图

     一.导出: 1.打开plsql-->工具---->导出用户对象(可以导出表结构和序列.视图) ps:如果上面不选中"包括所有者",这样到导出的表结构等就不包含所有 ...

  8. SpringMVC札集(07)——JSON数据

    自定义View系列教程00–推翻自己和过往,重学自定义View 自定义View系列教程01–常用工具介绍 自定义View系列教程02–onMeasure源码详尽分析 自定义View系列教程03–onL ...

  9. plsql programming 14 DML和事务管理

    我们可以把多个SQL语句集中在一起, 在逻辑上组成一个事务, 从而保证这些操作或者全部被保存到数据库(用sql的说法就是”提交”), 或者被整体驳回(用sql的说法是“回滚”). 事务: ACID 原 ...

随机推荐

  1. JavaScript:this是什么

    JavaScript:this是什么? 定义:this是包含它的函数作为方法被调用时所属的对象. 说明:这句话有点咬嘴,但一个多余的字也没有,定义非常准确,我们可以分3部分来理解它! 1.包含它的函数 ...

  2. u-boot支持LCD显示(基于TQ2440)

    平台简介 Linux版本:Linux-3.14 u-boot版本:u-boot-2015.04 硬件:TQ2440(内存:64MB  NandFlash:256MB) 作者:彭东林 邮箱:pengdo ...

  3. 校验知识:CRC32、MD5、SHA1概念及可靠性现状

    转:http://www.metsky.com/archives/337.html 昨天介绍了Windows 7的版本识别问题,不得不提到常用的CRC32.MD5.SHA1等校验算法可靠性问题,如果只 ...

  4. Linux查找并删除重复文件的命令行fdupes工具,dupeGuru图形工具

    查了几十个网页,找到这个接近满意的解决方案http://unix.stackexchange.com/questions/146197/fdupes-delete-files-aft... 不过正则里 ...

  5. pwn2own

    Pwn2Own是全球最著名的黑客大赛之一,由美国五角大楼入侵防护系统供应商TippingPoint的DVLabs赞助,今年已经是第六届. 1比赛规则 参赛黑客们的目标是4大主流网页浏览器——IE.Fi ...

  6. Centos7.4 建站系统和软件版本搭配

    一.系统和软件版本搭配 版本: 1.1.2 类型: 建站系统 适用于: Centos7.4 64bit 集成软件版本: nginx_versi=1.12.2 PHP=7.1.13 (已提供提供Zend ...

  7. poj_1284_原根

    一開始看题的时候第一想法就是暴力,可是无奈数据量有点大,看了题解之后才知道原来牵扯到数论上的一个叫做原根的东西,这个题的题意就是,给你一个奇素数,问题他的原根有多少.依据初等数论上所说,此时牵扯到了三 ...

  8. [转载]linux 更新yum源 改成阿里云源

    原文链接:https://www.cnblogs.com/bincoding/p/7892762.html 1.备份 mv /etc/yum.repos.d/CentOS-Base.repo /etc ...

  9. 手机号码月消费档次API

    手机号码月消费档次API,返回手机号的每月消费水平,身份证姓名不做一致性校验 文档:https://www.juhe.cn/docs/api/id/261 接口地址:http://v.juhe.cn/ ...

  10. Joomla详细安装图文教程

    Joomla 详细安装图文教程 第一步,配置网站信息 配置数据库:这里我选择MySQLi,可以根据自己的选择         安装-- 安装完成!