1

現在の行の2つのテキストフィールドを次の行の同じフィールドに連結したい

だからテーブルが

field1  field2  field3

text1    text3  order1
text2    text4  order1

私はこれをしたい:

if (field3.current_row = field3.next_row)
     SELECT field1 + getNextRow(field1) as "Concatenated Field" FROM table

これは可能ですか?

4

2 に答える 2

3

すでにSQLServer2012を使用している場合は、次の操作を実行できます

SELECT field1 + lead(field1) over (order by field1) as "Concatenated Field"
from table
于 2012-04-05T16:13:18.100 に答える
2

あなたはこれに似た何かをすることができます:

create table #temp
(
    field1 varchar(50),
    field2 varchar(50)
)

insert into #temp values ('text1', 'text3')
insert into #temp values ('text2', 'text4')

;with cte as
(
    select *, row_number()over(order by field1) as rownum
    from #temp
)
SELECT *
FROM 
(
    select c1.field1 + ' ' + (SELECT field1 FROM cte c2 WHERE c2.rownum = c1.rownum + 1) as ConcField
    from cte c1
) c
where c.concfield is not null

drop table #temp
于 2012-04-05T16:08:56.727 に答える