亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

Sql Server 中的計算列

Sql Server 中的計算列

慕姐8265434 2018-07-23 07:08:37
請問能不能在計算列中使用Sum()函數計算出另一個表中字段的合計比如有以下兩個表A和B, B.ParentId 的外鍵是A.Id,A.Num是計算列,我想在A.Num 列中寫一個公式,自動得出B中所有ParentId=A.Id的Num字段的總和。 表A: Id Num 表B: Id ParentId Num
查看完整描述

3 回答

?
達令說

TA貢獻1821條經驗 獲得超6個贊

計算列不能引用其他表的列,但是可以通過函數來實現,先建立下面這個函數:
create function DingXue(@id int)
??? returns int
as
begin
??? declare @sum int
??? select @sum=sum(num) from b where?id=@id
??? return @sum
end

然后創建表:
create table A(Id int identity(1,1), Num as dbo.DingXue(Id), tt int)
create table B(Id int identity(1,1), ParentId int, Num int)

測試如下:
insert into A(tt) values(1)
insert into B(ParentId,Num) values(1,1234)
insert into B(ParentId,Num) values(1,4321)
select * from A
select * from B

=================

A表里的tt只是為了增加A表里的記錄 :)

======================

其實我一直覺得數據庫里沒有必要存放計算列,因為“計算”這種事情,讓程序來做會更簡單,非要數據庫來做,也可以直接使用 select a.id, sum(b.num) as num from a inner join b on a.id=b.parentid 這種方式來實現

另外,也可以在B表加觸發器來實現,介理相對于函數來說,我對觸發器的抵觸情緒更嚴重一些,呵呵,所以這里提供函數方式的實現


查看完整回答
反對 回復 2018-07-25
?
鴻蒙傳說

TA貢獻1865條經驗 獲得超7個贊

update num =d.total  from  c inner join  (select a.aid, sum(b.num) as total from a inner join b on a.aid=b.aid group by a.aid) d on c.id = d.id

查看完整回答
反對 回復 2018-07-25
?
慕村9548890

TA貢獻1884條經驗 獲得超4個贊

建議不要這樣使用,如果你非要這樣用,可以試著自己寫一個自定義函數

查看完整回答
反對 回復 2018-07-25
  • 3 回答
  • 0 關注
  • 1459 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號