Показать сообщение отдельно
Старый 10.04.2007, 13:24     # 5
Kvarx
Member
 
Регистрация: 26.09.2005
Адрес: Питер
Сообщения: 336

Kvarx Известность не заставит себя ждатьKvarx Известность не заставит себя ждать
Мне по курсовику надо написать много триггеров для MSSQL Server 2005 EE. Начал с самого простого, но не получается. Есть табличка:
Код:
CREATE TABLE [dbo].[articles](
	[iid] [int] IDENTITY(1,1) NOT NULL,
	[name] [varchar](50) COLLATE Cyrillic_General_CI_AS NULL,
(
А триггер такой написал:
Код:
CREATE TRIGGER trigger1 ON dbo.articles
AFTER INSERT
AS
DECLARE @article_id int
select @article_id = 0
SELECT TOP 1 @article_id = A.iid FROM dbo.articles A, inserted i WHERE A.name = i.name
IF @article_id > 0
BEGIN
	RAISERROR ('MyError', 16,1)
	ROLLBACK TRANSACTION
END 
GO
Чтоб одинаковые строки не добавлять. Он срабатывает теперь для любого инсерта.

Последний раз редактировалось Kvarx; 10.04.2007 в 13:24. Причина: орфография
Kvarx вне форума