在论坛中出现的比较难的sql问题:1(字符串分拆+行转列问题 SQL遍历截取字符串)
原文:在论坛中出现的比较难的sql问题:1(字符串分拆+行转列问题 SQL遍历截取字符串)
最近,在论坛中,遇到了不少比较难的sql问题,虽然自己都能解决,但发现过几天后,就记不起来了,也忘记解决的方法了。
所以,觉得有必要记录下来,这样以后再次碰到这类问题,也能从中获取解答的思路。
求SQL遍历截取字符串
http://bbs.csdn.net/topics/390648078
从数据库中读取某一张表(数据若干),然后将某一字段进行截取。
比如:
字段A 字段B
a/a/c x
a/b/c x
切出来就变成:
字段1 字段2 字段3 字段B
a a c x
b b c x
数据不止一条 ,是遍历切取,求完整sql(从读取到遍历到截取到输出),求教。
另外还需要把列头进行排序,结果也需要按照字段1,字段2...进行排序
我的解法:
-
if object_id('[tb]') is not null drop table [tb]
-
go
-
-
create table [tb](A varchar(40),B varchar(10))
-
-
insert [tb]
-
select 'xx/xx/xx/xx/xx/xx','x' union all
-
select 'yy/yy/yy/yy/yy/yy','x'
-
go
-
-
if OBJECT_ID('tempdb..#temp1') is not null
-
drop table #temp1
-
-
if OBJECT_ID('tempdb..#temp2') is not null
-
drop table #temp2
-
-
select *,IDENTITY(int,1,1) id into #temp1
-
from tb
-
-
declare @sql nvarchar(3000)
-
declare @orderby nvarchar(100)
-
set @sql = '';
-
set @orderby = '';
-
-
;with t
-
as
-
(
-
select ID,
-
SUBSTRING(t.A, number ,CHARINDEX('/',t.a+'/',number)-number) as v,
-
b,
-
row_number() over(partition by id order by @@servername) as rownum
-
from #temp1 t,master..spt_values s
-
where s.number >=1
-
and s.type = 'P'
-
and SUBSTRING('/'+t.A,s.number,1) = '/'
-
)
-
-
select * into #temp2
-
from t
-
-
-
select @sql = @sql + ',max(case when rownum = '+CAST(rownum as varchar)+
-
' then v else null end) as 列'+CAST(rownum as varchar) ,
-
@orderby = @orderby + ',列'+CAST(rownum as varchar)
-
-
-
from #temp2
-
group by rownum
-
order by rownum --加了排序
-
-
-
-
-
set @sql = 'select '+STUFF(@sql,1,1,'')+ ',b' +
-
' from #temp2 group by id,b order by '+
-
stuff(@orderby,1,1,'')
-
-
--select @sql
-
-
exec(@sql)
-
/*
-
列1 列2 列3 列4 列5 列6 b
-
xx xx xx xx xx xx x
-
yy yy yy yy yy yy x
-
*/
在论坛中出现的比较难的sql问题:1(字符串分拆+行转列问题 SQL遍历截取字符串)的更多相关文章
- 在论坛中出现的比较难的sql问题:19(row_number函数 行转列、sql语句记流水)
原文:在论坛中出现的比较难的sql问题:19(row_number函数 行转列.sql语句记流水) 最近,在论坛中,遇到了不少比较难的sql问题,虽然自己都能解决,但发现过几天后,就记不起来了,也忘记 ...
- 在论坛中出现的比较难的sql问题:46(日期条件出现的奇怪问题)
原文:在论坛中出现的比较难的sql问题:46(日期条件出现的奇怪问题) 最近,在论坛中,遇到了不少比较难的sql问题,虽然自己都能解决,但发现过几天后,就记不起来了,也忘记解决的方法了. 所以,觉得有 ...
- 在论坛中出现的比较难的sql问题:45(用户在线登陆时间的小时、分钟计算问题)
原文:在论坛中出现的比较难的sql问题:45(用户在线登陆时间的小时.分钟计算问题) 最近,在论坛中,遇到了不少比较难的sql问题,虽然自己都能解决,但发现过几天后,就记不起来了,也忘记解决的方法了. ...
- 在论坛中出现的比较难的sql问题:44(触发器专题 明细表插入数据时调用主表对应的数据)
原文:在论坛中出现的比较难的sql问题:44(触发器专题 明细表插入数据时调用主表对应的数据) 最近,在论坛中,遇到了不少比较难的sql问题,虽然自己都能解决,但发现过几天后,就记不起来了,也忘记解决 ...
- 在论坛中出现的比较难的sql问题:42(动态行转列 考勤时间动态列)
原文:在论坛中出现的比较难的sql问题:42(动态行转列 考勤时间动态列) 所以,觉得有必要记录下来,这样以后再次碰到这类问题,也能从中获取解答的思路.
- 在论坛中出现的比较难的sql问题:41(循环替换 循环替换关键字)
原文:在论坛中出现的比较难的sql问题:41(循环替换 循环替换关键字) 所以,觉得有必要记录下来,这样以后再次碰到这类问题,也能从中获取解答的思路.
- 在论坛中出现的比较难的sql问题:40(子查询 销售和历史库存)
原文:在论坛中出现的比较难的sql问题:40(子查询 销售和历史库存) 最近,在论坛中,遇到了不少比较难的sql问题,虽然自己都能解决,但发现过几天后,就记不起来了,也忘记解决的方法了. 所以,觉得有 ...
- 在论坛中出现的比较难的sql问题:39(动态行转列 动态日期列问题)
原文:在论坛中出现的比较难的sql问题:39(动态行转列 动态日期列问题) 最近,在论坛中,遇到了不少比较难的sql问题,虽然自己都能解决,但发现过几天后,就记不起来了,也忘记解决的方法了. 所以,觉 ...
- 在论坛中出现的比较难的sql问题:38(字符拆分 字符串检索问题)
原文:在论坛中出现的比较难的sql问题:38(字符拆分 字符串检索问题) 最近,在论坛中,遇到了不少比较难的sql问题,虽然自己都能解决,但发现过几天后,就记不起来了,也忘记解决的方法了. 所以,觉得 ...
随机推荐
- Linux中 mv(文件移动)
mv命令的功能有以下两种: source target mv 参数1 参数2 1.对文件或目录重新命名 如果源文件和目标文件在同一个目录下,mv的作用就是改文件名. 2.将文件从一个目录移到另一个目录 ...
- angular 中父子路由
1. 创建组件引入组件 import { NewsaddComponent } from './components/newsadd/newsadd.component'; import { News ...
- 简易的CRM系统案例之SpringMVC+JSP+MySQL+hibernate框架版本
继续对上一版本进行改版,变成SpringMVC框架 简易的CRM系统案例之易的CRM系统案例之JSP+MySQL+SSH框架版本 src/spring.xml <?xml version=&qu ...
- attrib命令能用批处理实现文件夹批量显示吗?
attrib H:\* -s -h -a -r /s /d 加上/s /d参数就行了.(H表示你的U盘盘符)
- 学成在线_nginx遇到的问题
下载nginx:http://nginx.org/en/download.html 下载了最新的稳定版本 安装目录内运行nginx.exe 一直运行不起来.进程里面也没有这个进程.我把本机的IIS的8 ...
- Java中四个作用域的可见范围
作用域 当前类 同一包 子孙类 其他包 public √ √ √ √ protected √ √ √ × friendly或default(即没有修饰符时的权限) √ √ × × private √ ...
- 异步回收fork出的子进程(僵尸进程)
#include <stdio.h> #include <stdlib.h> #include <signal.h> #include <unistd.h&g ...
- oracle-复制表结构和表数据
1.复制表结构和表数据 create table table_new as select * from table_old 2.复制表结构 create table table_new as sele ...
- Ubuntu构建LVS+Keepalived高可用负载均衡集群【生产环境部署】
1.环境说明: 系统版本:Ubuntu 14.04 LVS1物理IP:14.17.64.2 初始接管VIP:14.17.64.13 LVS2物理IP:14.17.64.3 初始接管VIP:14 ...
- FineReport点击输入框直接展示下拉框列表
引用自帆软官方文档-http://help.finereport.com/doc-view-1899.html 1. 描述 下拉框以及下拉复选框默认状态,必须点击最右侧的三角才可以实现下拉,不够人性化 ...
