Sql server 如何获得新插入的ID

表中有自增长的列:ID,表中还有另外一列Mark。程序运行过程中,变量marks值有可能为空。在插入新记录时,若marks为空,Mark列的值就等于该条新记录的ID,否则... 表中有自增长的列:ID,表中还有另外一列Mark。程序运行过程中,变量marks值有可能为空。在插入新记录时,若marks为空,Mark列的值就等于该条新记录的ID,否则Mark列的值为marks。我想用一条Sql语句来做当上页提交过来的marks值等于空的情况,请问能实现吗。 展开
 我来答
沃幻玉07S
2006-11-06 · TA获得超过323个赞
知道小有建树答主
回答量:219
采纳率:0%
帮助的人:252万
展开全部
用触发器,insert后查询inserted表中的marks
CREATE trigger afterAdd on table1 for insert
as
declare @mark varchar(10)
select @mark=mark from inserted
--这样可以取出@mark的值了,接下去按你的意图写就可以了
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
冯益斌
2006-11-06 · TA获得超过1019个赞
知道小有建树答主
回答量:869
采纳率:100%
帮助的人:1001万
展开全部
应该是这样吧
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
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
abingpow
2006-11-06 · TA获得超过2206个赞
知道大有可为答主
回答量:2830
采纳率:0%
帮助的人:2274万
展开全部
用触发器
create trigger tr_1
for insert
on 表
as
update 表 set mark=(case mark when null then @@identity else mark end)
go
本回答被提问者采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 1条折叠回答
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式