Bạn có thể tạo một hàm do người dùng xác định cho:
CREATE FUNCTION dbo.CountUses(@pictureId INT)
RETURNS INT
AS
BEGIN
RETURN
(SELECT Count(id)
FROM PictureUse
WHERE PictureId = @PictureId)
END
Sau đó, cột được tính toán có thể được thêm vào như sau:
ALTER TABLE dbo.Picture
ADD NofUses AS dbo.CountUses(Id)
Tuy nhiên, tôi muốn thực hiện một quan điểm cho điều này:
CREATE VIEW PictureView
AS
SELECT Picture.Id,
PictureName,
Picture.CreateDate,
Count(PictureUse.Id) NofUses
FROM Picture
JOIN PictureUse
ON Picture.Id = PictureUse.PictureId
GROUP BY Picture.Id,
PictureName,
Picture.CreateDate