DB String Split sample
以sqlserver为例进行说明,代码稍加修改,可以用于ORACLE。
字符串的拆分和聚合是数据库开发人员比较常见的任务。
关于字符串的聚合和拆分,sqlserver的标准解决方案是for xml path.
oracle 11g提供了listagg函数方便获取。
今天就字符串的拆分进行分析。重点在于思路。
示例数据.
1,’a,b,c,d,e,f,g’
需要把数据拆分成标准的行。
1,a
1,b
第一步:
一行变多行, 需要增加副本,如何增加条数? 而且条数刚好和分隔符的个数+1个相同。
可以使用数据辅助表 join 原表,需要注意的是如何写on的条件,来达到要求。
第二步:只要办成了第一步,第二步就简单明了了,截取字符串,如何截取合适的长度?
有了思路,就可以写出代码,细节处再慢慢调整即可。以下写入我的代码。
第二种思路是使用递归CTE。
第一步写基准查询,查出每一个待拆分的字符串中第一个分隔符出现的位置,作为截取字符串的结束位置,而
显然1是开始位置。
第二步递归步骤,根据第一步,[end]+1 as start, 再把第一个的[end+1]作为查询的起点,查找下一个分隔符出现的位置作为结束位置。
结束条件就是从N开始查找待分隔的字符串没有分隔符了。
方法二写起来简单明了,但是如果待分隔的字符串过长,则递归的次数会容易超过数据库默认的递归最大次数,会报错。而且大量的递归
消费内存和执行效率不高,慎用。sqlserver中可以用hintOPTION(MAXRECURSION N)来处理这个问题。
--USE TEMPDB;
--GO
--CREATE TABLE MYTEST(ID INT,NAMELIST VARCHAR(200));
--INSERT INTO MYTEST VALUES(1,'A,B,C,D,E,F,G,H,I,J,K');
--INSERT INTO MYTEST VALUES(2,'X,Y,Z');
--INSERT INTO MYTEST VALUES(3,'QQ');
--SELECT * FROM MYTEST;
方法一代码如下:
WITH NUMS(N) AS(
SELECT ROW_NUMBER() OVER(ORDER BY OBJECT_ID) AS N FROM SYS.ALL_OBJECTS
)
SELECT ID,
SUBSTRING(
NAMELIST,
NUMS.N,
CHARINDEX(',',NAMELIST+',',N)-N
) AS NAME
FROM
MYTEST
JOIN
NUMS
ON
LEN(MYTEST.NAMELIST)>NUMS.N-1
AND SUBSTRING(','+MYTEST.NAMELIST+',',N,1)=','
ORDER BY ID, NAMELIST ,N
CTE方法拆分字符串的示例代码:
--CTE
WITH CTE AS
(
SELECT ID, 1 AS [START],CHARINDEX(',',NAMELIST+',') AS [END],NAMELIST FROM MYTEST
UNION ALL
SELECT ID,[END]+1 AS START,CHARINDEX(',',NAMELIST+',',[END]+1) AS [END],NAMELIST FROM CTE
WHERE CHARINDEX(',',NAMELIST+',',[END]+1)>0
)
SELECT ID,SUBSTRING(NAMELIST,START,[END]-[START]) AS [NAME] FROM CTE
ORDER BY ID,NAME OPTION(MAXRECURSION 1000);
由于oracle和sqlserver部分字符串函数实现不同,用oracle的函数可以写出更优雅简单的方法。欢迎大家尝试。
DB String Split sample的更多相关文章
- Java里String.split需要注意的用法
我们常常用String的split()方法去分割字符串,有两个地方值得注意: 1. 当分隔符是句号时("."),需要转义: 由于String.split是基于正则表达式来分割字符串 ...
- 字符串切分 String.Split 和 Regex.Split
当切割字符串的是单个字符时可使用String.Split string strSample="ProductID:20150215,Categroy:Food,Price:15.00&quo ...
- Java String.split()小点
java String.split(); 别的不说,单说其中一个问题,这个函数去切分空字符串时,得到的结果: public static void main(String[] args) {// St ...
- Lua 自定义函数string.split
function string.split(str, delimiter) if str==nil or str=='' or delimiter==nil then return ...
- C# string.Split对于换行符的分隔正确用法
C# string.Split对于换行符的分隔正确用法 tmpCase "11117144-8c91-4817-9b92-99ec2f9d784a\r\n23D95A26-012C-4332 ...
- String.split()用法以及特殊分隔符注意,ps:|
转载:http://www.cnblogs.com/mingforyou/archive/2013/09/03/3299569.html 在java.lang包中有String.split()方法,返 ...
- C# String.split()用法小结。String.Split 方法 (String[], StringSplitOptions)
split()首先是一个分隔符,它会把字符串按照split(' 字符')里的字符把字符串分割成数组,然后存给一个数组对象. 输出数组对象经常使用foreach或者for循环. 第一种方法 string ...
- java String.split()函数的用法分析
java String.split()函数的用法分析 栏目:Java基础 作者:admin 日期:2015-04-06 评论:0 点击: 3,195 次 在java.lang包中有String.spl ...
- Lua自己实现string.split功能
local function split(str, d) --str是需要查分的对象 d是分界符 local lst = { } local n = string.len(str)--长度 local ...
随机推荐
- 关于c#的一些笔记
序: 在vs中,可以生成三种项目: 第一种:控制台项目:用于练习C#语法 第二种:桌面程序项目:比如我们经常看到的桌面程序(CS). 第三种:web项目:用于开发网站 1.我们先来说一下.net和C ...
- js禁止复制页面文字
做项目的时候有客户提出要求,不能用用户浏览他发表的文章时复制他的文章 一种比较简单的方法,禁止用户选中页面的文字和禁止用户右键菜单 document.oncontextmenu = new Funct ...
- Fluent NHibernate and Mysql,SQLite,PostgreSQL
http://codeofrob.com/entries/sqlite-csharp-and-nhibernate.html https://code.google.com/archive/p/csh ...
- floyd离散,最小环
Description 杭州有N个景区,景区之间有一些双向的路来连接,现在8600想找一条旅游路线,这个路线从A点出发并且最后回到A点,假设经过的路线为V1,V2,....VK,V1,那么必须满足K& ...
- PHP获取APK的包信息
这段时间太忙了,一个月没有写博客了,稍微闲下来就感觉把在开发中遇到的问题记录下来 php上传安卓apk包的时候,需要获取安卓apk包内的信息 <?php /*解析安卓apk包中的压缩XML文件, ...
- [python拾遗]列表
python列表拾遗 1.列表可以修改,使用 ‘+’ 将一个新列表附加在原列表的尾部: >>> a = [1,'a'] >>> b = a + [2,'b'] &g ...
- HTTP路由
HTTP路由 HTTP路由(译者注:Play的路径映射机制)组件负责将HTTP请求交给对应的action(一个控制器Controller的公共静态方法)处理. 对于MVC框架来说,一个HTTP请求可以 ...
- 自定义XML动态配置程序
概述 1 在做程序开发时,我们往往要用到如下两个基本模块 1> 设置程序的基础参数,如分页的参数.邮件参数等: 2> 在基于表驱动开发时,即把一些判断的逻辑放在表数据中: 2 在这两个基本 ...
- CSS之绝对定位那些事
1.垂直居中 有时我们会使用margin: 0 auto;作居中使用.但有的时候我们需要垂直居中,例如在div里面垂直居中显示一张加载中的gif图. 下面这种写法就可以完美实现: 垂直居中的子容器 { ...
- SCOM Visio监控 与sharepoint 2010 整合
激活sharepoint 2010的企业版网站功能 在sharepoint 前端服务器安装:OpsMgrDataModule.msi,安装好后可以看到如下东东: 在Sharepoint前端服务器中启动 ...