0

テーブル tb1(col1, col2) があり、col2 は varchar(50) です。例えば、

col1    col2
item1   abc
item2   a
item3   ed

col2 を解析し、次のような一時テーブルを作成するストアド プロシージャを作成します。

col1    col2
item1   a
item1   b
item1   c
item2   a
item3   e
item3   d

誰か助けてくれませんか?

4

2 に答える 2

2

文字列の最大長がわかっている場合、最も簡単な方法は単純な結合を行うことです。

select col1, substring(col2, 1, 1) as col2
from t
where len(col2) >= 1 union all
select col1, substring(col2, 2, 1) as col2
from t
where len(col2) >= 2 union all
select col1, substring(col2, 3, 1) as col2
from t
where len(col2) >= 3 union all

長さが長すぎない場合は、次のようにしてクエリを簡素化できます。

select col1, substring(col2, nums.seqnum) as col2
from t cross join
     (select row_number() over (order by (select NULL)) as seqnum
      from Infromation_Schema.columns
     ) nums
where len(col2) <= nums.seqnum

または、T-SQL の while ループでこれを行うこともできます。

于 2012-09-11T17:50:55.883 に答える
1

これを試して:

単一のクエリを使用して取得できます

SELECT COL1,SUBSTRING(COL2,NUMBER+1,1) AS COL2
FROM   YOURTABLE T
JOIN   MASTER..SPT_VALUES M
ON     LEN(COL2)>NUMBER
WHERE  M.TYPE='P'
于 2012-09-11T16:29:55.073 に答える