繁体   English   中英

SQL每行一次插入到表2列

[英]SQL Insert to table 2 column at a time on each row

我陷入了一个需要在另一个表中插入数据的问题,但是我插入了两列,然后停留在同一行,然后插入下两列,依此类推。

我有以下表格数据

在此处输入图片说明

我有一个要填充两列的表格,但想要输入数据,例如:

Row 1:(Row1A,Row1B)
Row 2:(Row1C,Row1D)
Row 3:(Row1E,Row1D)
Row 4:(Row2A,Row2B)
Row 5:(Row2C,Row2D)
Row 6:(Row2E,Row2F)

我可以使用循环来实现上述目的,但是我想知道另一种可以提高性能的方法。 有没有办法做到这一点?

编辑:订单需要正确。 我需要先将第一行列添加到表中,然后再移至第二行。

我会用apply

insert into t2(col1, col2)
    select col1, col2
    from data d cross apply
         (values (varchar1, varchar2), (varchar3, varchar4), (varchar5, varchar6)
         ) v(col1, col2);

表格代表无序集。 因为您只有两列,所以没有一列可以指定顺序。 如果您这样做了,那么order by将允许您拥有一个identity列来捕获订单。 看起来像:

insert into t2(col1, col2)
    select col1, col2
    from data d cross apply
         (values (varchar1, varchar2, 1), (varchar3, varchar4, 2), (varchar5, varchar6, 3)
         ) v(col1, col2, priority)
    order by d.id, v.priority;

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM