--数据插入之前对插入数据进行验证 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
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
你想说什么?给出具体例子验证的话,在after 和instead of 都可以 after中,不符合要求时使用rollback tran instead of 时直接忽略掉对表的操作就可以了
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
数据字典是关于数据的信息的集合,也就是对数据流图中包含的所有元素的定义的集合. 组成 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
instead of insert
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
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
after中,不符合要求时使用rollback tran
instead of 时直接忽略掉对表的操作就可以了
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
组成
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