Mam kilka problemów, próbując rozwiązać wyzwalacz SQL, aby automatycznie ustawić użytkownika, aby zablokował & utworzyć rekord bloku zawierający datę w innej tabeli, jeśli ich Termin płatności jest równy ustawionej dacie.T-SQL Wstaw wyzwalacz do wstawienia, aktualizuj jeśli warunek na wielu tabelach
Problem jest, że gdy spust jest wyłączony przez wkładkę, instrukcje drukowania są wykonywane i wkładka występuje, ale wkładka w tabeli nie ma, lub oświadczenie zmiana? Czy ktoś może wyjaśnić, dlaczego?
Uwaga: Zarówno wkładka oraz instrukcję aktualizacji są w porządku, gdy wykonywane przez siebie.
KONTA TABELA
CREATE TABLE [dbo].[Account](
[AccountNo] [int] IDENTITY(1,1) NOT NULL,
[CustomerNo] [int] NOT NULL,
[PaymentNo] [int] NULL,
[CreditNo] [int] NULL,
[BlockID] [dbo].[number] NULL,
[Balence] [dbo].[currency] NOT NULL,
[AmountDue] [dbo].[currency] NOT NULL,
[DueDate] [dbo].[dates] NULL,
[AutherisedBy] [nvarchar](50) NOT NULL,
[DateCreated] [date] NOT NULL,
BLOCKEDUSER TABELA
CREATE TABLE [dbo].[BlockedUsers](
[BlockID] [int] IDENTITY(1,1) NOT NULL,
[DateEnforced] [dbo].[dates] NOT NULL,
[Blocked] [dbo].[switch] NOT NULL,
TRIGGER
ALTER TRIGGER [dbo].[Add_Blocked_User]
ON [dbo].[Account]
FOR INSERT
AS
BEGIN
SET NOCOUNT ON;
Declare @ID int
Select @ID = [AccountNo] from inserted
If(Select [DueDate] from inserted) = '2011-01-01'
INSERT INTO dbo.BlockedUsers(DateEnforced,Blocked)
VALUES (GETDATE(),1)
PRINT 'New Block Date Added'
UPDATE Account
Set BlockID = IDENT_CURRENT('BlockID')
where @ID = @ID
PRINT 'Account Blocked'
END
GO
pełni Przykład pracy: Zakończony korzystania Pomoc Poniżej.
ALTER TRIGGER [dbo].[Add_Blocked_User]
ON [dbo].[Account]
AFTER INSERT
AS
BEGIN
SET NOCOUNT ON;
Declare @ID int
Select @ID = [AccountNo] from inserted
If(Select [DueDate] from inserted)Not Between (select CONVERT(date, getdate() - 30)) And (select CONVERT(date, getdate()))
Begin
INSERT INTO dbo.BlockedUsers(DateEnforced,Blocked)
VALUES (GETDATE(),1)
PRINT 'New Block Date Added'
UPDATE Account
Set BlockID = (Select Max(BlockID) From BlockedUsers)
where [AccountNo] = (Select [AccountNo] from inserted)
PRINT 'Account Blocked'
End
END
GO
Twój spust pęknie, gdy dwa lub więcej wierszy dodaje się za pomocą jednego rachunku. –