gpt4 book ai didi

sql - 如何在SQL Server中更好地复制一组数据

转载 作者:行者123 更新时间:2023-12-03 00:10:22 24 4
gpt4 key购买 nike

我有几个相关的表,我希望能够在更新引用时复制某些行。

我想复制 Table1 中的一行,以及 Table2 和 Table3 中的所有相关行,并且我正在尝试找出一种无需迭代行的有效方法。

例如,我有一张篮子 table :

+----------+---------------+
| BasketId | BasketName |
+----------+---------------+
| 1 | Home Basket |
| 2 | Office Basket |
+----------+---------------+

每个篮子里都有水果:

+---------+----------+-----------+
| FruitId | BasketId | FruitName |
+---------+----------+-----------+
| 1 | 1 | Apple |
| 2 | 1 | Orange |
| 3 | 2 | Mango |
| 4 | 2 | Pear |
+---------+----------+-----------+

每种水果都有一些特性:

+------------+---------+--------------+
| PropertyId | FruitId | PropertyText |
+------------+---------+--------------+
| 1 | 2 | Is juicy |
| 2 | 2 | Hard to peel |
| 3 | 1 | Is red |
+------------+---------+--------------+

对于此示例,我的属性特定于单个水果行,这些“苹果”属性并不是所有篮子中所有苹果的属性,仅适用于该特定篮子中的特定苹果。

我想做的是复制一个篮子。因此,给定篮子 1,我想创建一个新篮子,复制它包含的水果行,并复制指向这些水果的属性。最后我希望得到这样的数据:

+----------+---------------+
| BasketId | BasketName |
+----------+---------------+
| 1 | Home Basket |
| 2 | Office Basket |
| 3 | Friends Basket|
+----------+---------------+

+---------+----------+-----------+
| FruitId | BasketId | FruitName |
+---------+----------+-----------+
| 1 | 1 | Apple |
| 2 | 1 | Orange |
| 3 | 2 | Mango |
| 4 | 2 | Pear |
| 5 | 3 | Apple |
| 6 | 3 | Orange |
+---------+----------+-----------+

+------------+---------+--------------+
| PropertyId | FruitId | PropertyText |
+------------+---------+--------------+
| 1 | 2 | Is juicy |
| 2 | 2 | Hard to peel |
| 3 | 1 | Is red |
| 4 | 6 | Is juicy |
| 5 | 6 | Hard to peel |
| 6 | 5 | Is red |
+------------+---------+--------------+

复制篮子及其水果非常简单,但在我看来,复制水果的属性会导致迭代行,我希望 TSQL 中有更好的解决方案。

有什么想法吗?

最佳答案

为什么不加入 FruitName 来获取包含新旧 FruitId 的表?考虑到会同时添加信息......这可能不是最好的选择,但你不会使用任何周期。

INSERT INTO BASKET(BASKETNAME)
VALUES ('COPY BASKET')

DECLARE @iBasketId int
SET @iBasketId = @@SCOPE_IDENTITY;


insert into Fruit (BasketId, FruitName)
select @iBasketId, FruitName
from Fruit
where BasketId = @originalBasket

declare @tabFruit table (originalFruitId int, newFruitId int)

insert into @tabFruit (originalFruitId, newFruitId)
select o.FruitId, n.FruitId
from (SELECT FruitId, FruitName from Fruit where BasketId = @originalBasket) as o
join (SELECT FruitId, FruitName from Fruit where BasketId = @newBasket) as n
on o.FruitName = n.FruitName


insert into Property (FruitId, PropertyText)
select NewFruitId, PropertyText
from Fruit f join @tabFruit t on t.originalFruitId = f.FruitId

关于sql - 如何在SQL Server中更好地复制一组数据,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31866942/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com