PL/SQL字符串

PL/SQL字符串实际上是一个可选的尺寸规格字符序列。字符可以是数字,字母,空白,特殊字符或全部的组合。 PL/SQL提供了三种类型的字符串:

  • 固定长度字符串:在这样的字符串,程序员指定的长度,同时声明该字符串。该字符串是右填充空格以达到指定的长度。

  • 变长字符串:在这样的字符串,最大长度可达32,767,为字符串指定,并不需要填充。

  • 字符大对象(CLOB):这是可变长度的字符串,可以达到128兆兆字节。

PL/ SQL字符串可以是变量或字面值。字符串文字被引号围在内部。例如,

'This is a string literal. yiibai.com' Or 'hello world'

包括在字符串中单引号的文字,需要输入两个单引号彼此相邻,如:

'this isn''t what it looks like'

声明字符串变量

Oracle数据库提供了大量的字符串数据类型,如:CHAR,NCHAR,VARCHAR2,NVARCHAR2,CLOB和NCLOB。前面加上一个'N'的数据类型为“国家字符集”数据类型,即存储Unicode字符数据。

如果需要声明一个可变长度的字符串时,必须提供该字符串的最大长度。例如,VARCHAR2数据类型。下面的例子说明了声明和使用一些字符串变量:

DECLARE
name varchar2(20);
company varchar2(30);
introduction clob;
choice char(1);
BEGIN
name := 'John Smith';
company := 'Infotech';
introduction := ' Hello! I''m John Smith from Infotech.';
choice := 'y';
IF choice = 'y' THEN
dbms_output.put_line(name);
dbms_output.put_line(company);
dbms_output.put_line(introduction);
END IF;
END;
/

当上述代码在SQL提示符执行时,它产生了以下结果:

John Smith
Infotech Corporation
Hello! I'm John Smith from Infotech. PL/SQL procedure successfully completed

要声明一个固定长度的字符串,使用CHAR数据类型。在这里不必指定一个最大长度为固定长度的变量。如果超过了限制的长度,Oracle数据库会自动使用所需的最大长度。所以,下面的两个声明下面是相同的:

 red_flag CHAR(1) := 'Y';
red_flag CHAR := 'Y';

PL/SQL字符串函数和操作符

PL/ SQL提供了连接运算符(||)用于连接两个字符串。下表提供了用PL / SQL提供的字符串功能(函数):

S.N. 函数及用途
1 ASCII(x);
返回字符 x 的 ASCII 值
2 CHR(x);
返回字符 x 的 ASCII 值
3 CONCAT(x, y);
连接字符串x和y,并返回附加的字符串
4 INITCAP(x);
每个单词的首字母x中转换为大写,并返回该字符串
5 INSTR(x, find_string [, start] [, occurrence]);
搜索find_string在x中并返回它出现的位置
6 INSTRB(x); 
返回另一个字符串中字符串的位置,但返回以字节为单位的值
7 LENGTH(x); 
返回x中的字符数
8 LENGTHB(x); 
返回为单字节字符集的字节的字符串的长度
9 LOWER(x); 
在x转换为小写字母,并返回该字符串
10 LPAD(x, width [, pad_string]) ; 
X用空格向左填充,把字符串的总长度达宽字符
11 LTRIM(x [, trim_string]); 
从x的左修剪字符
12 NANVL(x, value); 
如果x匹配NaN的特殊值(非数字)则返回其值,否则返回x
13 NLS_INITCAP(x); 
相同INITCAP函数,但它可以使用不同的排序方法所指定NLSSORT
14 NLS_LOWER(x) ; 
同样的,不同的是它可以使用不同的排序方法所指定NLSSORT LOWER函数
15 NLS_UPPER(x); 
相同,不同之处在于它可以使用不同的排序方法所指定NLSSORT UPPER函数
16 NLSSORT(x); 
改变排序的字符的方法。任何NLS函数之前必须指定该参数;否则,默认的排序被使用
17 NVL(x, value); 
返回如果x为null返回null; 否则返回x
18 NVL2(x, value1, value2); 
如果x不为null返回value1; 如果x为null,则返回value2
19 REPLACE(x, search_string, replace_string); 
搜索x对于SEARCH_STRING并替换使用replace_string它
20 RPAD(x, width [, pad_string]); 
填充x到右侧
21 RTRIM(x [, trim_string]); 
从x右边修剪
22 SOUNDEX(x) ; 
返回包含x的拼音表示形式的字符串
23 SUBSTR(x, start [, length]); 
返回x的一个子开始于由start指定的位置。可选长度为子字符串
24 SUBSTRB(x); 
相同SUBSTR除外的参数均以字节代替字符的单字节字符的系统
25 TRIM([trim_char FROM) x); 
从左侧和右侧修剪x字符
26 UPPER(x); 
x转换为大写字母,并返回该字符串

以下实施例说明了一些上述函数和它们的用途:

示例1

DECLARE
greetings varchar2(11) := 'hello world';
BEGIN
dbms_output.put_line(UPPER(greetings)); dbms_output.put_line(LOWER(greetings)); dbms_output.put_line(INITCAP(greetings)); /* retrieve the first character in the string */
dbms_output.put_line ( SUBSTR (greetings, 1, 1)); /* retrieve the last character in the string */
dbms_output.put_line ( SUBSTR (greetings, -1, 1)); /* retrieve five characters,
starting from the seventh position. */
dbms_output.put_line ( SUBSTR (greetings, 7, 5)); /* retrieve the remainder of the string,
starting from the second position. */
dbms_output.put_line ( SUBSTR (greetings, 2)); /* find the location of the first "e" */
dbms_output.put_line ( INSTR (greetings, 'e'));
END;
/

当上述代码在SQL提示符执行时,它产生了以下结果:

HELLO WORLD
hello world
Hello World
h
d
World
ello World
2 PL/SQL procedure successfully completed.

示例2

DECLARE
greetings varchar2(30) := '......Hello World.....';
BEGIN
dbms_output.put_line(RTRIM(greetings,'.'));
dbms_output.put_line(LTRIM(greetings, '.'));
dbms_output.put_line(TRIM( '.' from greetings));
END;
/

当上述代码在SQL提示符执行时,它产生了以下结果:

......Hello World
Hello World.....
Hello World PL/SQL procedure successfully completed.

SQL记录-PLSQL字符串的更多相关文章

  1. SQL记录-PLSQL记录

    PL/SQL记录   PL/SQL记录就是可以容纳不同类型的数据项的数据结构.记录由不同字段,类似于数据库表的行. 例如,要保留跟踪图书馆中的书籍.可能要跟踪有关每本书下面的属性类似:标题,作者,主题 ...

  2. SQL记录-PLSQL基本语法与数据类型

    PL/SQL基本语法 PL/SQL是一种块结构的语言,这意味着PL/SQL程序被划分和编写代码的逻辑块.每块由三个子部分组成: S.N. 段和说明 1 声明 此部分开头使用关键字DECLARE.它是一 ...

  3. SQL记录-PLSQL变量与常量文字

    PL/SQL变量   变量是只不过是一个给定的存储区域,程序可以操纵的名称.PL/SQL每个变量具有一个特定的数据类型,它决定了大小和变量的存储器的值,可以说存储器和设置操作可以施加到可变内被存储的范 ...

  4. SQL记录-PLSQL游标

    PL/SQL游标 Oracle会创建一个存储区域,被称为上下文区域,用于处理SQL语句,其中包含需要处理的语句,例如所有的信息,行数处理,等等. 游标是指向这一上下文的区域. PL/SQL通过控制光标 ...

  5. SQL记录-PLSQL过程

    PL/SQL过程   子程序是一个程序单元/模块执行特定的任务.这些子程序被组合以形成更大的程序.这基本上是被称为“模块化设计”.子程序可以调用由另一个子程序或程序被称为调用程序. 子程序可以创建: ...

  6. SQL记录-PLSQL条件控制

    PL/SQL条件控制   决策结构需要程序员指定一个或多个条件要计算,或由程序进行测试,如果条件被确定为真那么一条或多条语句被执行,如果要被执行的其它语句条件被确定为假,则选其它执行块. 以下是从在大 ...

  7. SQL记录-PLSQL运算符

    PL/SQL运算符 运算符是一个符号,告诉编译器执行特定的数学或逻辑操作. PL/SQL语言有丰富的内置运算符,运算符提供的以下几种类型: 算术运算符 关系运算符 比较运算符 逻辑运算符 字符串运算符 ...

  8. SQL记录-PLSQL日期与时间

    PL/SQL日期及时间 PL/SQL提供两个日期和时间相关的数据类型: 日期时间(Datetime)数据类型 间隔数据类型 datetime数据类型有: DATE TIMESTAMP TIMESTAM ...

  9. SQL记录-PLSQL集合

    PL/SQL集合 集合是一个有序组具有相同的数据类型的元素.每个元素进行标识的唯一标表示其在集合中的位置. PL/SQL提供了三种集合类型: 索引表或关联数组 嵌套表 可变大小的数组或变长数组 Ora ...

随机推荐

  1. django请求的生命周期

    1. 概述 首先我们知道HTTP请求及服务端响应中传输的所有数据都是字符串. 在Django中,当我们访问一个的url时,会通过路由匹配进入相应的html网页中. Django的请求生命周期是指当用户 ...

  2. ElasticSearch入门 第三篇:索引

    这是ElasticSearch 2.4 版本系列的第三篇: ElasticSearch入门 第一篇:Windows下安装ElasticSearch ElasticSearch入门 第二篇:集群配置 E ...

  3. TICTOC: Header Only C++ Timer

    感觉最近的更新频率略高啊-哈哈- 这次的带来的是一个十分简单便利的C++计时库. 项目地址:https://github.com/miaoerduo/tictoc 欢迎Start和提MR. 项目中有详 ...

  4. 完爆Facebook/GraphQL,APIJSON全方位对比解析(三)-表关联查询

    相关阅读: 完爆Facebook/GraphQL,APIJSON全方位对比解析(一)-基础功能 完爆Facebook/GraphQL,APIJSON全方位对比解析(二)-权限控制 自APIJSON发布 ...

  5. C#图片处理(转zhjzwl/archive)

    基本原理: 获取每一个像素值,然后处理这些每一个像素值.   原始图片: ISINBAEVA ~~~~~~~~ 一. 底片效果 原理: GetPixel方法获得每一点像素的值, 然后再使用SetPix ...

  6. 转 git config命令使用

    . git config简介 我们知道config是配置的意思,那么git config命令就是对git进行一些配置.而配置一般都是写在配置文件里面,那么git的配置文件在哪里呢?互动一下,先问下大家 ...

  7. 记录Appium-desktop踩过的坑could not find devices

    最近了解到一个自动化入门的新工具appium-desktop,看网上各种文章,感觉这个工具是很简单的一个入门级工具,下载试用了一下. 官网下载,输入网址appium.io,点击下载. 一路傻瓜式安装, ...

  8. 怎么理解LAXCUS大操作系统系统在云计算体系中的定位

    最近一直在做laxcus大数据操作系统的分布式应用开发,因为做得多了,感触也多了.按照云计算三层定义,即iaas(基础设施即服务).paas(平台即服务).saas(软件即服务),laxcus属于pa ...

  9. mysql数据出现Unknown column 'user_uid' in 'field list' sql错误

    来源:https://blog.csdn.net/gnail_oug/article/details/53606608 在操作mysql数据库时提示com.mysql.jdbc.exceptions. ...

  10. 从C简单程序的汇编代码入手,以理解计算机工作原理。

    贺邦  原创作品转载请注明出处 <Linux内核分析>MOOC课程 http://mooc.study.163.com/course/USTC-1000029000#/info 知识准备 ...