1、遍历字符串
2、计算字符在字符串中出现的次数
3、从字符串中删除不需要的字符
4、将字符和数字数据分离
5、判别字符串是不是字母数字型的
6、提取姓名的大写首字母缩写
7、按字符串中的部分内容排序
8、按字符串中的数值排序
9、根据表中的行创建一个分隔列表
10、按字母顺序排列字符串
11、判别可作为数值的字符串
12、提取第n个分隔的子串
13、分解IP地址

1、遍历字符串
1)、select * from t10 order by id asc;
        ID
———-
         1
         2
         3
         4
         5
         6
         7
         8
         9
        10
2)、
select substr(e.ename, iter.id, 1) as c
from (select 'abcdefg' ename from dual) e,
     (select * from t10 order by id) iter
where iter.id <= length(e.ename)
说明,t10表只是个辅助表而已,书上称之为“基干表”。在这里有一点需要注意的就是这里的字符串'abcdefg'长度是小于10的,所以在这里使用t10可以实现我们的需求。假若字符串长度大于10,那么就不行了。所以我们应该保证基干表中的行数要大于字符串的长度才行。

2、计算字符在字符串中出现的次数
例如:'10,cleak,manager'计算在这字符串中有多少个逗号。
思路:首先计算出原字符串的长度,然后计算去掉逗号后字符串的长度,这两者的差就是逗号在该字符串中出现的次数。
区别:length求得是字符长度,lengthb求得是字节长度。
方法一
select lengthb('10,cleak,manager')-lengthb(replace('10,cleak,manager', ',', '')) count from dual;
方法二
select lengthb(translate('10,cleak,manager', ','||'10,cleak,manager', ',')) count from dual;
方法三,适用于11g以上
select regexp_count('10,cleak,manager', ',') count from dual;

3、从字符串中删除不需要的字符
例如,现在要求从ENAME列中删除元音字母(a,e,i,o,u),从SAL列中删除0。
说明,REPLACE、TRANSLATE函数用法
select ename,
       –先使用translate()把元音字母都转换为一个符号',',完了再使用replace去掉符号','
       replace(translate(ename, upper('aeiou'), ','), ',', '') as sub_ename,
       sal,
       replace(sal, 0, '') as sub_sal
  from emp;

4、将字符和数字数据分离
例如,select ename||sal as data from emp,现在要求把data分开为两列,字符部分一列,数字部分一列。
说明,LPAD(String a, int length, String addString),作用:把addString添加到a的左边,length是返回值的长度。
select replace(translate(data, '1234567890', '0000000000'), '0', '') as ename,
       to_number(replace(translate(lower(data),
                                   lower('abcdefghijklmnopqrstuvwxyz'),
                                   rpad('z', 26, 'z')),
                         'z',
                         '')) as sal
  from (select ename || sal as data from emp);

5、判别字符串是不是字母数字型的
create view V as
   select ename as data
   from emp
   where deptno=10
union all
    select ename||', $'||cast(sal as varchar2(10))||'.00' as data
    from emp
    where deptno=20
union all
    select ename||cast(sal as varchar2(20)) as data
    from emp
    where deptno=30

现在要求查询出为字母数字型的行,也就是说4-8要去掉,因为其中除了字母和数字还包含了其他字符。
select data
  from v
 where translate(lower(data),
                 '0123456789abcdefghijklmnopqrstuvwxyz',
                 rpad('z', 36, 'z')) = rpad('z', length(data), 'z');

6、提取姓名的大写首字母缩写
例如,Stewie Griffin,要返回结果如:S.G.

select replace(replace(translate(replace('Stewie Griffin','.',''),
                                 'abcdefghijklmnopqrstuvwxyz',
                                 rpad('#',26,'#')),'#',''),
               ' ',
               '.')||'.'
from dual

7、按字符串中的部分内容排序
select ename, substr(ename, length(ename)-1, 2) subename from emp order by substr(ename, length(ename)-1, 2)

8、按字符串中的数值排序
select data,
to_number(replace(translate(data,replace(translate(data,'0123456789','##########'),'#'),rpad('#',20,'#')),'#')) num
from V order by
to_number(replace(translate(data,replace(translate(data,'0123456789','##########'),'#'),rpad('#',20,'#')),'#'))

9、根据表中的行创建一个分隔列表
SELECT DEPTNO, LTRIM(SYS_CONNECT_BY_PATH(ENAME, ','), ',') EMPS
  FROM (SELECT DEPTNO,
               ENAME,
               ROW_NUMBER() OVER(PARTITION BY DEPTNO ORDER BY EMPNO) RN,
               COUNT(*) OVER(PARTITION BY DEPTNO) CNT
          FROM EMP)
 WHERE LEVEL = CNT
 START WITH RN = 1
CONNECT BY PRIOR DEPTNO = DEPTNO
       AND PRIOR RN = RN – 1

10、按字母顺序排列字符串
————————-
ADAMS      AADMS
ALLEN      AELLN
BLAKE      ABEKL
CLARK      ACKLR
FORD       DFOR
JAMES      AEJMS
JONES      EJNOS
KING       GIKN
MARTIN     AIMNRT
MILLER     EILLMR
SCOTT      COSTT
OLD_NAME   NEW_NAME

sql语句
SELECT OLD_NAME, NEW_NAME
  FROM (SELECT OLD_NAME, REPLACE(SYS_CONNECT_BY_PATH(C, ' '), ' ') NEW_NAME
          FROM (SELECT E.ENAME OLD_NAME,
                       ROW_NUMBER() OVER(PARTITION BY E.ENAME ORDER BY SUBSTR(E.ENAME, ITER.POS, 1)) RN,
                       SUBSTR(E.ENAME, ITER.POS, 1) C
                  FROM EMP E, (SELECT ROWNUM POS FROM EMP) ITER
                 WHERE ITER.POS <= LENGTH(E.ENAME)
                 ORDER BY 1)
         START WITH RN = 1
        CONNECT BY PRIOR RN = RN – 1
               AND PRIOR OLD_NAME = OLD_NAME)
 WHERE LENGTH(OLD_NAME) = LENGTH(NEW_NAME);

11、判别可作为数值的字符串

12、提取第n个分隔的子串

13、分解IP地址
SELECT IP,
       SUBSTR(IP, 1, INSTR(IP, '.', 1, 1) – 1) A,
       SUBSTR(IP,
              INSTR(IP, '.', 1, 1) + 1,
              INSTR(IP, '.', 1, 2) – INSTR(IP, '.', 1, 1) – 1) B,
       SUBSTR(IP,
              INSTR(IP, '.', 1, 2) + 1,
              INSTR(IP, '.', 1, 3) – INSTR(IP, '.', 1, 2) – 1) C,
       SUBSTR(IP, INSTR(IP, '.', 1, 3) + 1) D
  FROM (SELECT '192.168.112.101' AS IP FROM DUAL);

SQL Cookbook—字符串的更多相关文章

  1. MSSQL Server数据库的四种连接方法和sql连接字符串

    MSSQL Server数据库的四种连接方法和sql连接字符串 分类: [ 03 ] C#(131) [ 07 ] SQL Server(68) [ 01 ] .NET(189) 今天用SQL Ser ...

  2. sql 解析字符串添加到临时表中 sql存储过程in 参数输入

    sql 解析字符串添加到临时表中  sql存储过程in 参数输入 解决方法 把字符串解析 添加到 临时表中 SELECT * into #临时表   FROM dbo.Func_SplitOneCol ...

  3. Sql Sever 字符串截取汉字

    最近需要在SQL的字符串中截取汉字,利用unicode函数判断字符的unicode编码,根据编码范围过滤掉非汉字字符. 写成了一个function /*@str 需要获取汉字的字符串*/ create ...

  4. sql server 字符串替换函数REPLACE

    sql server 字符串替换函数REPLACE函数的使用 <pre name="code" class="sql">--参数1:需要替换字符的母 ...

  5. 《SQL CookBook 》笔记-第一章-检索记录

    目录 第一章 检索记录 1.1检索所有行和列 1.2筛选行 1.3查找满足多个查询条件的行 1.4筛选列 1.5创建列的别名 1.6 在where子句中引用别名列 1.7 串联多列的值 1.8 在se ...

  6. SQL 操作字符串

    SQL操作字符串相对来说比较难一点,现在总结几个常用的SQL 对字符串的操作: declare @dd nvarchar(12) set @dd='2015-03-13' print @dd decl ...

  7. sql server字符串的类型

    sql server字符串分为不同的类型,下面就将为您介绍几个sql server字符串的常见类型,希望对您学习sql server字符串能有所帮助. nchar 此数据类型可存储1~4000个定长U ...

  8. SQL中字符串截取、连接、替换等函数的用法

    一.SQL中SUBSTRING函数的用法1.功能:返回字符.二进制.文本或图像表达式的一部分2.语法:SUBSTRING ( expression, start, length )3.QL 中的 su ...

  9. C# 过滤sql特殊字符串方法

    1. /// <summary>    /// 过滤不安全的字符串    /// </summary>    /// <param name="Str" ...

随机推荐

  1. 通过python实现wc基本功能

    ---恢复内容开始--- 1.Github项目地址: https://github.com/zhg1998/ww/blob/master/wc.py 2.项目相关要求: 写一个命令行程序,模仿已有wc ...

  2. js常用的校验代码 (整理)

    /* 用途:检查输入手机号码是否正确 输入:str:字符串 返回:如果通过验证返回true,否则返回false */ function checkMobile(str){ var regu =/^[1 ...

  3. django view function

    view function 的几种返回值 return HttpResponse(html) return HttpResponseNotFound(html) raise Http404(" ...

  4. 爬虫开发12.selenium在scrapy中的应用

    selenium在scrapy中的应用阅读量: 370 1 引入 在通过scrapy框架进行某些网站数据爬取的时候,往往会碰到页面动态数据加载的情况发生,如果直接使用scrapy对其url发请求,是绝 ...

  5. day04.1-三元表达式与列表解析

    1. 三元表达式 name = input("请输入:") res = "英雄" if name=="令狐冲" else "伪君子 ...

  6. 深入了解java虚拟机(JVM) 第三章 内存区域----堆空间

    一.堆的含义 jvm堆的区域主要是用来存放对象的实例,它的空间大小是JVM内存区域中占比重最大的,也是jvm最大的内存管理模块,最重要的是,这个区域是垃圾收集器主要管理的区域,这意味着我们在考虑垃圾回 ...

  7. 【bzoj4887】:[Tjoi2017]可乐 矩阵乘法,快速幂

    [bzoj4887]:[Tjoi2017]可乐 题目大意:一张无相连通图(n<=30),从1号点开始走,每秒可以走到相邻的点也可以自爆,求第t秒(t<=1e6)后所有的方案数是多少对201 ...

  8. dict字典;dict的操作

    一.字典: 1. 字典 dict 用{}来表示 键值对数据 {key:value} 唯一性 键   都必须是可哈希的 不可变的数据类型就可以当做字典中的键 值   没有任何限制 1.1  字典的创建: ...

  9. Windows便签快捷键

    Win+R 是运行的快捷件打 StikyNot 回车 快捷键 功能Ctrl+N 新建一张便笺Ctrl+D 删除当前便笺Ctrl+E 居中对齐Ctrl+R 右对齐Ctrl+J 左对齐Ctrl+I 斜体C ...

  10. Numpy中扁平化函数ravel()和flatten()的区别

    在Numpy中经常使用到的操作由扁平化操作,Numpy提供了两个函数进行此操作,他们的功能相同,但在内存上有很大的不同. 先来看这两个函数的使用: from numpy import * a = ar ...