练习字符处理函数(数据库表都是从1开始),我们用到一张“伪表” dual:

dual :dual 是一张只有一个字段,一行记录的表。dual 表也称之为'伪表',因为他不存储主题数据。如果我们不需要从具体的表来取得表中数据,而是单纯地为了得到一些我们想得到的信息,并要通过 select 完成时,就要借助 dual 表来满足结构化查询语言的格式。

CONCAT(arg1,arg2):连接值在一起 (CONCAT 函数有两个输入参数)

arg1:字符串类型。字符拼接的值。

arg2:字符串类型。字符拼接的值。

SQL> select concat('yxf','wj') from dual;

SUBSTR(arg1,arg2,arg3):截取子串(如果没有arg3,则是默认从arg2截取到末尾)。

arg1:字符串类型。原字符串,

arg2:整数类型。开始位置(开始位置可以是一个负数,-1 表示原串的最后一位,-2 则表示倒是第二位以此类推),

arg3:整数类型。截取个数。

SQL> select substr('yxfbjsxt',1,5) from dual;

SQL> select substr('yxfbjsxt',-1,5) from dual;

SQL> select substr('yxfbjsxt',1) from dual;

LENGTH(arg1):以数字值显示一个字符串的长度。

arg1:字符串类型。计算长度的字符串。

SQL> select length('yxfbjsxt') from dual;

INSTR(arg1,arg2):找到一个给定字符的数字位置(没找到则返回0)。

arg1:字符串类型。原字符串。

arg2:字符串类型。查找内容。

SQL> select instr('yxfbjsxt','wj') from dual;

SQL> select instr('yxfbjsxt','sxt') from dual;

INSTR(arg1,arg2,arg3,arg4):指定查找位置以及出现的次数。

arg1:字符串类型。原字符串。

arg2:字符串类型。查找内容。

arg3:整数类型。开始位置。

arg4:整数类型。第几次出现。

SQL> select instr('yxfbjsxt','x',1,2) from dual;

LPAD(arg1,arg2,arg3):用给定的字符左填充字符串到给定的长度。

arg1:字符串类型。原字符串。

arg2:整数类型。总长度。

arg3:字符串类型。填充的子字符串。

SQL> select lpad('yxfbjsxt',9,'250') from dual;

SQL> select lpad('yxfbjsxt',20,'250') from dual;

RPAD(arg1,arg2,arg3):用给定的字符右填充字符串到给定的长度。

arg1:字符串类型。原字符串。

arg2:整数类型。总长度。

arg3:字符串类型。填充的子字符串。

SQL> select rpad('yxfbjsxt',20,'250') from dual;

TRIM(arg1):从一个字符串中去除头(leading)或尾(trailing)或头尾两侧(both)的字符 (默认为头尾两侧) 如果 trim_character 或 trim_source 是一个文字字符,必须放在单引号中。

arg1 需要操作的字符串FROM 为关键字。

格式 1:需要去掉的内容 FROM 原字符串

SQL> select trim('h' from 'hellhowdh') from dual;

格式 2:leading|trailing|both 需要去掉的内容 FROM 原字符串(both的用法和上面的用法是一样的,上面就是默认波让后用                   法,去除头尾。)。

去头:

SQL> select trim(leading 'h' from 'hellhowdh') from dual;

去尾:

SQL> select trim(trailing 'h' from 'hellhowdh') from dual;

实例1:显示所有工作岗位名称从第 4 个字符位置开始包含字符串 REP 的雇员的信息,将雇员的姓和名连接显示在一起,还显                 示雇员名的长度,以及名字中字母 a 的位置。

SQL> select concat(first_name,Last_name),length(last_name),instr(last_name,'a') from employees where substr(job_id,4)='REP';

解析:先看题目中的需要显示的信息:1.雇员的姓和名连接显示在一起   2.显示雇员名的长度 3.名字中字母 a 的位置 这三个是我们需要提取的显示信息。然后确定是从哪张表查,最后用where子句去完成的查询要求:工作岗位名称从第 4 个字符位置开始包含字符串 REP 的雇员的信息。

实例2:显示名字是以 n 结束的雇员的数据,将雇员的姓和名连接显示在一起,还显示雇员名的长度,以及名字中字母 a 的位                   置。(以n结尾,有俩种方法去查找。1.用模糊查询 ‘%n’,2.用字符截取函数,只截取最后一个字母                                                   substr(last_name,-1)).

SQL> select concat(first_name,last_name) "name",length(concat(first_name,last_name)),instr(concat(first_name,last_name),'a') from employees where last_name like '%n';
SQL> select concat(first_name,last_name) "姓名:",length(concat(first_name,last_name)) "姓名长度:",instr(concat(first_name,last_name),'a') "姓名中a,出现的位置:" from employees where substr(last_name,-1)='n';

解析:首先明确显示的的内容:1.雇员的姓和名连接显示在一起 2.显示雇员名的长度 3.名字中字母 a 的位置。。再用where子句去查询对雇员的要求。显示名字是以 n 结束的雇员的数据。

实例3:将手机号中间四位用星号代替。

select replace(PHONE_NUMBER ,substr(PHONE_NUMBER ,5,4),'****') from employees;

解析:用到了嵌套函数:代替肯定是需要用replace函数,在replace函数中嵌套一个substr截取函数。

数据库Oracle字符处理函数的更多相关文章

  1. Oracle字符分隔函数(split)

    为了让 PL/SQL 函数返回数据的多个行,必须通过返回一个 REF CURSOR 或一个数据集合来完成.REF CURSOR 的这种情况局限于可以从查询中选择的数据,而整个集合在可以返回前,必须进行 ...

  2. 【转帖】循序渐进Oracle:数据库的字符集和字符集文件

    循序渐进Oracle:数据库的字符集和字符集文件 https://blog.csdn.net/Enmotech/article/details/100869162 2019年09月15日 18:23: ...

  3. Oracle的字符替换函数translate用法

    参考文档如下:http://www.banping.com/2009/05/18/oracle_function_translate/ Oracle提供了一个字符替换函数translate,不同于re ...

  4. Atitit 数据库 标准库  sdk 函数库 编程语言 mysql oracle  attilax总结

    Atitit 数据库 标准库  sdk 函数库 编程语言 mysql oracle  attilax总结 1.1. 常见的编程语言以及数据库 sql内部函数库标准化库一般有以下api1 1.2. 各个 ...

  5. 数据库Oracle函数之单行函数的介绍

    函数介绍: 函数:是数据库产品中提供的能够处理查询结果的方法. 函数能够用于下面的目的: • 执行数据计算 • 修改单个数据项 • 格式化显示的日期和数字 • 转换列数据类型 • 函数有输入参数,并且 ...

  6. 数据库Oracle 数字,字符,日期之间的相互转换

    数据类型转换分为俩种 . 隐式数据类型转换:当源数据的类型和目标数据的类型不同的时候,如果没有转换函数,就会发生隐式转换,也称自动转换. 对于直接赋值转换:  对于表达式赋值: 隐式转换的问题: 性能 ...

  7. Oracle的overlaps函数转换其他数据库语法

    首先,来介绍一下Oracle的overlaps函数的用法: overlaps函数是用来判断两个时间段是否有重叠的 比如说计算 (a,b),(c,d) 就可以写成: select * from dual ...

  8. Oracle substr() 字符截取函数

    1.substr函数格式   (俗称:字符截取函数) 格式1: substr(string string, int a, int b); 格式2:substr(string string, int a ...

  9. Oracle instr() 字符查找函数

    instr()函数的格式  (俗称:字符查找函数) 格式一:instr( string1, string2 )    /   instr(源字符串, 目标字符串) 格式二:instr( string1 ...

随机推荐

  1. python Django框架正式准备工作

    之前由于不太了解数据库方面的知识,但经过一段时间的web应用的开发学习,成功的用其他框架连接了数据库,并完成了相关操作,数据爬取也初识了,更了解了python这门语言的语法,但路还很长,因此现在才能正 ...

  2. 史上最详细的C语言和Python的插入排序算法

    史上最详细的C语言和Python的插入排序算法插入排序原理:所谓插入排序,就像我们在打牌(斗地主)时,整理我们自己手中自己的牌一样,就像是2,1,3,9,J,K,5,4,这四张牌.我们要把它其中的几张 ...

  3. LeetCode 5264 在受污染的二叉树中查找元素 Find Elements in a Contaminated Binary Tree

    地址 https://leetcode-cn.com/contest/weekly-contest-163/problems/find-elements-in-a-contaminated-binar ...

  4. 手把手教你如何在阿里云ECS搭建Python TensorFlow Jupyter

    前段时间在阿里云买了一台服务器,准备部署网站,近期想玩一些深度学习项目,正好拿来用.TensorFlow官网的安装仅提及Ubuntu,但我的ECS操作系统是 CentOS 7.6 64位,搭建Pyth ...

  5. 利用SSH隧道技术穿越内网访问远程设备

    本文为作者原创,转载请注明出处:https://www.cnblogs.com/leisure_chn/p/11899478.html 通常,我们用于调试的计算机无法远程访问位于局域网中的待调试设备. ...

  6. nyoj 1112-求次数 (string, substr(begin, length), map, pair)

    1112-求次数 内存限制:64MB 时间限制:1000ms 特判: No 通过数:3 提交数:8 难度:2 题目描述: 题意很简单,给一个数n 以及一个字符串str,区间[i,i+n-1] 为一个新 ...

  7. 使用iis反向代理.net core应用程序

    .net core 其实是自宿主性质的web应用程序,而不再是web网站,所以.net core是可以直接单独作为系统服务部署.但是实际情况中,为了同个一个端口能支持多个web应用和统一管理,还是应该 ...

  8. 领扣(LeetCode)设计哈希映射 个人题解

    不使用任何内建的哈希表库设计一个哈希映射 具体地说,你的设计应该包含以下的功能 put(key, value):向哈希映射中插入(键,值)的数值对.如果键对应的值已经存在,更新这个值. get(key ...

  9. runlevel init

    init概念存在于cnetos7以下,配置文件/etc/inittab init 以及 文本和图形界面切换(可以用ctrl+alt+n 或者 init3 5切换,不是重启切) 命令init N 0 关 ...

  10. Linux虚拟机扩容根分区CentOs6.9 VMware14

    1.首先关闭虚拟机点击编辑虚拟机设置 2.点击想要扩容的硬盘点击扩容 3.增加容量 输入想增加的容量,因为我本身是30G写到35G是加了5G不是增加30G.(此处为了演示只增加5G) 4.开启虚拟机 ...