Loading...

Във форума е въведено ограничение, което позволява на потребителите единствено да разглеждат публикуваните въпроси.

baskam avatar baskam 1 Точки

[Exam Preparation] Database Basics - 19.  Close Reports изпит 22 Oct 2017

Здравейте,

Имам нужда от малко помощ за 19.   Close Reports от изпита Database Basics MS SQL Exam – 22 Oct 2017. Дава ми постоянно Compile time error, а не мога да разбера защо.

Това е заявката
CREATE TRIGGER T_ChaDngeStatus ON Reports AFTER UPDATE
AS
DECLARE @InsertedId INT =(SELECT Id FROM inserted)

IF((SELECT CloseDate FROM inserted) IS NOT NULL)
BEGIN
       UPDATE Reports SET StatusId =3
       WHERE @InsertedId=Id
END
 

Благодаря предварително.

Тагове:
0
Databases Basics
TeodorStefanovPld avatar TeodorStefanovPld 1274 Точки
Best Answer

много сложно няма смисъл толкова 

CREATE TRIGGER tr_closeDate ON Reports AFTER UPDATE
AS
BEGIN
        UPDATE Reports
        SET StatusId=3
        where Id IN(select id FROM inserted) AND Reports.CloseDate IS NOT NULL

END

ето го имаш да направиш само една проверка. мисля че if-a ти чупи нещата,дебъгера е отвратителен и е малко на налучкване тук за съжаление :( а и реално имаш ситуация при която ако са направили batch update или multiple  Updates ти ще вземеш само едно id и това ще ти изгърми. Какво правиш ако примерно съм направил update reports set closedate = getdate() where categoryId =2 може да имаш няколко такива reports а ти търсиш само един.

0
22/06/2018 21:27:30
baskam avatar baskam 1 Точки

Абсолютно си прав. Благодаря ти!

0
Можем ли да използваме бисквитки?
Ние използваме бисквитки и подобни технологии, за да предоставим нашите услуги. Можете да се съгласите с всички или част от тях.
Назад
Функционални
Използваме бисквитки и подобни технологии, за да предоставим нашите услуги. Използваме „сесийни“ бисквитки, за да Ви идентифицираме временно. Те се пазят само по време на активната употреба на услугите ни. След излизане от приложението, затваряне на браузъра или мобилното устройство, данните се трият. Използваме бисквитки, за да предоставим опцията „Запомни Ме“, която Ви позволява да използвате нашите услуги без да предоставяте потребителско име и парола. Допълнително е възможно да използваме бисквитки за да съхраняваме различни малки настройки, като избор на езика, позиции на менюта и персонализирано съдържание. Използваме бисквитки и за измерване на маркетинговите ни усилия.
Рекламни
Използваме бисквитки, за да измерваме маркетинг ефективността ни, броене на посещения, както и за проследяването дали дадено електронно писмо е било отворено.