如果是after insert,自然是之后;如果是instead of insert,则是之前...

解决方案 »

  1.   


    instead of insert
      

  2.   

    --数据插入之前对插入数据进行验证
    create trigger tri_name
    on 表
    instead of insert
    as
    begin
       if exists(select * from inserted where ...)
       insert into 表(a,b,c) select a,b,c from inserted where ....
    end
      

  3.   

    create trigger trig_insert_t on t
    for insert as
    if not exists(select 1 from t a,inserted b where a.name=b.name and a.id<>b.id)
    insert t1 select * from inserted
    if exists(select 1 from t a,inserted b where a.id<>b.id and a.name=b.name and not exists(select 1 from t where name=a.name and id>a.id) and datediff(ss,a.dat,b.dat)>=20)
    insert t1 select * from inserted
      

  4.   

    你想说什么?给出具体例子验证的话,在after 和instead of 都可以
    after中,不符合要求时使用rollback tran
    instead of 时直接忽略掉对表的操作就可以了
      

  5.   

    create trigger trig_insert_t on t
    for insert as
    if not exists(select 1 from t a,inserted b where a.name=b.name and a.id<b.id)
    insert t1 select * from inserted
    if exists(select top 1 a.*  from t a,inserted b where a.name=b.name and a.id<b.id and datediff(ss,a.dat,b.dat)>=20 order by id desc) 
        insert t1 select * from inserted
      

  6.   

    数据字典是关于数据的信息的集合,也就是对数据流图中包含的所有元素的定义的集合. 
    组成 
    1数据流 
    2数据流分量,即数据元素 
    3数据存储 
    4处理 
    数据字典 
    数据库的重要部分是数据字典。它存放有数据库所用的有关信息,对用户来说是一组只读的表。数据字典内容包括: 数据库中所有模式对象的信息,如表、视图、簇、及索引等。 分配多少空间,当前使用了多少空间等。 列的缺省值。 约束信息的完整性。 用户的名字。 用户及角色被授予的权限。 用户访问或使用的审计信息。 其它产生的数据库信息。 数据库数据字典是一组表和视图结构。它们存放在SYSTEM表空间中。 数据库数据字典不仅是每个数据库的中心。而且对每个用户也是非常重要的信息。用户可以用SQL语句访问数据库数据字典。-------------------------------------
    摘自“中国风”Roy_88的
    自己看看--2005實現數據庫表字段屬性統計(2000里的系統表sysproperties描述表不存在,2005里用sys.extended_properties視圖替代)
    select 
        [表名]=c.Name,
        [表说明]=isnull(f.[value],''),
        [列名]=a.Name,
        [列序號]=a.Column_id,
        [標識]=case when is_identity=1 then '√' else '' end,
        [主鍵]=case when exists(select 1 from sys.objects x join sys.indexes y on x.Type=N'PK' and x.Name=y.Name 
                            join sysindexkeys z on z.ID=a.Object_id and z.indid=y.index_id and z.Colid=a.Column_id)
                        then '√' else '' end,
        [類型]=b.Name,
        [字節數]=case when a.[max_length]=-1 and b.Name!='xml' then 'max/2G' 
                when b.Name='xml' then '2^31-1字節/2G'
                else rtrim(a.[max_length]) end,
        [長度]=case when ColumnProperty(a.object_id,a.Name,'Precision')=-1 then '2^31-1'
                    else rtrim(ColumnProperty(a.object_id,a.Name,'Precision')) end,
        [小數]=isnull(ColumnProperty(a.object_id,a.Name,'Scale'),0),
        [是否為空]=case when a.is_nullable=1 then '√' else '' end,
        [列说明]=isnull(e.[value],''),
        [默認值]=isnull(d.text,'')    
    from 
        sys.columns a
    left join
        sys.types b on a.user_type_id=b.user_type_id
    inner join
        sys.objects c on a.object_id=c.object_id and c.Type='U'
    left join
        syscomments d on a.default_object_id=d.ID
    left join
        sys.extended_properties e on e.major_id=c.object_id and e.minor_id=a.Column_id and e.class=1 
    left join
        sys.extended_properties f on f.major_id=c.object_id and f.minor_id=0 and f.class=1