日期:2014-05-18 浏览次数:20593 次
select id,name=left(name,len(name)-charindex('-',name)),
name2=REVERSE(left(REVERSE(name),len(name)-charindex('-',REVERSE(name))))
from tb
------解决方案--------------------
select
id,
name=left(name,len(name)-charindex('-',name)),
name2=REVERSE(left(REVERSE(name),len(name)-charindex('-',REVERSE(name))))
from
tb
------解决方案--------------------
declare @t table(
id int
,name varchar(30)
);
insert into @t
SELECT 1, '12-32A-DDD' UNION ALL
select 2, '32-22F-FDD-SD' UNION ALL
select 3, '1-32K-F-S-DD-Q-10'
;
WITH t1 AS
(
SELECT ID, Name+'-' as name
FROM @t
),
t2 as
(
SELECT ID, CONVERT(VARCHAR(30),LEFT(name,CHARINDEX('-',name)-1)) AS Subname
,STUFF(name, 1, CHARINDEX('-',name), '') AS name, 1 AS Level
FROM t1
UNION ALL
SELECT t1.ID, CONVERT(VARCHAR(30),LEFT(t2.name,CHARINDEX('-',t2.name)-1))
,STUFF(t2.name, 1, CHARINDEX('-',t2.name), ''), t2.Level+1
FROM t2 JOIN
t1 ON t2.ID=t1.ID and t2.name>''
)
SELECT ID
, MIN(CASE WHEN name>'' then subname else Null end) As name
, MIN(CASE WHEN name='' then subname else Null end) As name2
FROM t2
where level=1 or name=''
group by ID
/*
(3 行受影响)
ID name name2
----------- ------------------------------ ------------------------------
1 12 DDD
2 32 SD
3 1 10
警告: 聚合或其他 SET 操作消除了空值。
*/