SQL server 2008 怎样根据从表中的一些条件删除主表中的某些元组
主表:Goods:
data:image/s3,"s3://crabby-images/806b6/806b62009a5adc21dfe2684cbbe697e4a62d46a2" alt=""
从表:Purchase:
data:image/s3,"s3://crabby-images/7094f/7094fe8106b892ed0e66ef39161ee891942acd39" alt=""
从表Purchase中有如下语句:
PRIMARY KEY (Gno),
FOREIGN KEY (Gno) REFERENCES Goods(Gno)
删除所有Purchase中Num少于20个的商品信息,不包括Purchase中没有的商品(就是删除商品号Gno为1,2,5的)
------解决方案--------------------
这样呢,试试:
declare @temp table(gno varchar(30))
--先删除明细,会把删除的字段值,放到@temp表变量中
delete purchase
output deleted.gno into @temp
where num<20
--再删除主表
delete goods where Gno in (select Gno from @temp)