首页 > 数据库技术 > 详细

SQL中拆分字符串substr及统计字符出现频数replace用法实例讲解

时间:2015-11-29 17:59:57      阅读:424      评论:0      收藏:0      [点我收藏+]

一、拆分字符串为若干行

例一:要求将表emp中的‘king‘按照每行一个单词拆成四行

注意:substr(str,pos):截取pos位置开始的字符;

        substr(str,pos,len):从pos位置开始,选出接下去的len个字符

表emp:

eid  ename
1 ring
2 king
3 ting
4 ping

 

 

 

 

首先,建立表tmp(基干表,为了配合表一使用):

tid
1
2
3
4
5

 

 

 

 

 

然后,select emp.ename,tmp.tid from emp,tmp where emp.ename=‘king’;/*没有主键和外键,生成king的笛卡尔集/

ename tid

king    1
king    2
king    3
king    4
king    5
最后:select substr (ename,tid,1) as a from (select emp.ename,tmp.tid from emp,tmp where emp.ename=‘king’) as e where e.tid <= length(e.ename);

结果:

a:

k

i

n

g

若select substr (ename,tid) as b, substr(ename,length(ename)-tid+1).......结果将会出现

b     c

king g

ing   ng

ng    ing

g      king

 

 

二、计算字符在字符串中出现的次数

replace函数:replace(要搜索的字符串表达式,要查找的字符串,替换字符串)

例二:计算10,clark,manager中逗号的个数

select (length(‘10,clark,manager‘)-length(replace(‘10,clark,manager‘,‘,‘,‘‘))/length(‘,‘)) as c from tablename;

 

SQL中拆分字符串substr及统计字符出现频数replace用法实例讲解

原文:http://www.cnblogs.com/smallcrystal/p/5005067.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!