簡體   English   中英

使用count()從tableA插入tableB到tableB

[英]INSERT INTO from tableA to tableB with count()

將行從一個表插入到另一個表,我嘗試使用count(*)來確保表OBJ_LINES中的line_no列設置為1,2,3,4 ..,依此類推。

INSERT INTO OBJ_LINES(
id,
line_no)
SELECT (1,
(select count(*)+1 FROM OBJ_LINES WHERE id = 1)
FROM TEMPLATE_LINES tmp
WHERE tmp.id = 37;

(語法Sybase數據庫)如果TEMPLATE_LINES表包含多個行,則會收到重復錯誤,因為count()似乎僅被評估一次,而不是針對TEMPLATE_LINES表中發現的每一行。

如何根據給定ID的當前行數編寫sql以設置“動態” line_no?

INSERT INTO OBJ_LINES(
id,
line_no)
SELECT (1,
number(*)
FROM TEMPLATE_LINES tmp
WHERE tmp.id = 37;

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM