34,830
社区成员
data:image/s3,"s3://crabby-images/35646/35646e77d5e9223d889e78d064d3636ff11c3f85" alt=""
data:image/s3,"s3://crabby-images/bbc73/bbc73597d830ce9fb80945ee353e678cf2178724" alt=""
data:image/s3,"s3://crabby-images/16d1e/16d1e94d09a2f7edfe4ae05a784d76f095e5581d" alt=""
data:image/s3,"s3://crabby-images/6b0d4/6b0d465761431f9449ad37040a187e26a1813711" alt=""
- Create table aa(id int identity,oid int,date datetime)
- alter trigger Insert_aa on aa
- instead of insert
- as
- begin
- if not exists(select 1 from inserted a where exists(select 1 from aa where a.oid=oid
- and convert(varchar(10),a.date,120)=convert(varchar(10),date,120)))
- begin
- insert into aa(oid,date) select oid ,date from inserted
- end
- end
- insert into aa select 12,getdate()
- insert into aa select 12,getdate()
- insert into aa select 12,getdate()
- insert into aa select 12,getdate()
- select * from aa
- id oid date
- ----------- ----------- -----------------------
- 1 12 2007-10-19 00:00:00.000
- if exists (select * from dbo.sysobjects where id = object_id(N'[dbo].[t]') and OBJECTPROPERTY(id, N'IsUserTable') = 1)
- drop table [dbo].[t]
- GO
- CREATE TABLE [dbo].[t] (
- [dttime] [datetime] NOT NULL,
- dt as convert(varchar(10),dttime ,120),
- CONSTRAINT [IX_T] UNIQUE
- (
- dt ASC
- )
- ) ON [PRIMARY]
- insert t select getdate() --可以成功插入
- insert t select getdate() --被dt的唯一值要求所约束
- select * from t --结果,只插入了一条记录
- /*
- 违反了 UNIQUE KEY 约束 'IX_T'。不能在对象 't' 中插入重复键。
- 语句已终止。
- dttime dt
- ------------------------------------------------------ ----------
- 2007-10-18 21:37:03.373 2007-10-18
- */