Sql server 如何获得新插入的ID

来源:百度知道 编辑:UC知道 时间:2024/05/31 05:38:41
表中有自增长的列:ID,表中还有另外一列Mark。程序运行过程中,变量marks值有可能为空。在插入新记录时,若marks为空,Mark列的值就等于该条新记录的ID,否则Mark列的值为marks。我想用一条Sql语句来做当上页提交过来的marks值等于空的情况,请问能实现吗。

用触发器
create trigger tr_1
for insert
on 表
as
update 表 set mark=(case mark when null then @@identity else mark end)
go

用触发器,insert后查询inserted表中的marks
CREATE trigger afterAdd on table1 for insert
as
declare @mark varchar(10)
select @mark=mark from inserted
--这样可以取出@mark的值了,接下去按你的意图写就可以了

应该是这样吧
create trigger tr_1
for insert
on 表
as
declare @id int
declare @mark varchar(20)
select @id=id, @mark=mark from inserted
if @mark is null
update 表 set mark='marks' where id=@id
go