sql 触发器 的问题 在关键字 'update' 附近有语法错误。

createtriggerautoset_stuff_num/*新职员注册自动生成人员编号*/onstaff_infoforinsertasbegindeclare@re... create trigger autoset_stuff_num /*新职员注册自动生成人员编号*/
on staff_info
for insert
as
begin
declare
@regnum tinyint,
@currentdate datetime,
@showcode varchar(10),
@year_code char(1),
@client_type_code char(2),
@len tinyint ,
@power char(2)
select @currentdate=getdate()
select top 1 @regnum=序号
from staff_info
where 部门=(select 部门 from inserted)
order by 序号 desc
if @regnum=null select @regnum=1
select @len=len(@regnum)
select @year_code=char(year(@currentdate)-2011+65)
set @client_type_code=case(select 权限 from inserted)
when('低') then 'LO'
when('中') then 'ME'
when('高') then 'HI'
when('最高') then 'SH'
end
select @showcode=(@client_type_code+@year_code+convert(varchar(2),month(@currentdate))+convert(varchar(2),day(@currentdate))+
case when @len<3 then replicate('0',3-len(@regnum)) else'' end+ convert(varchar(3),@regnum)
update stuff_info
set 序号=@regnum,
注册日期=@currentdate,
人员编号=@showcode,
登录密码='0000',
用户名=(select 姓名 from inserted)
where 姓名 =(select 姓名 from inserted)
end
展开
 我来答
释荷出艾
2020-05-19 · TA获得超过2.9万个赞
知道大有可为答主
回答量:1.1万
采纳率:26%
帮助的人:589万
展开全部
先不说你脚本中的笔误
你在触发器里并没有对表2进行操作呀
update
表1
set
realname=@realname
where
uid=@uid
这个是你写错了吧?应该是表2才对。
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
Daniel_bad
2011-12-29 · TA获得超过635个赞
知道小有建树答主
回答量:382
采纳率:100%
帮助的人:218万
展开全部
--少了个括号,看我注释
select @showcode=(@client_type_code+@year_code+
convert(varchar(2),month(@currentdate)) --这里少括号
+convert(varchar(2),day(@currentdate))+
case when @len<3 then replicate('0',3-len(@regnum)) else'' end+ convert(varchar(3),@regnum)
本回答被提问者采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
ireray5
2011-12-28 · TA获得超过396个赞
知道小有建树答主
回答量:557
采纳率:0%
帮助的人:363万
展开全部
update stuff_info
set 序号=@regnum,
注册日期=@currentdate,
人员编号=@showcode,
登录密码='0000',
用户名=b.姓名
from stuff_info a inner join inserted b
on a.姓名 = b.姓名
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
百度网友cf38862
2011-12-28 · 超过77用户采纳过TA的回答
知道小有建树答主
回答量:205
采纳率:0%
帮助的人:141万
展开全部
UPDATE A stuff_info
SET 序号=@regnum,
注册日期=@currentdate,
人员编号=@showcode,
登录密码='0000',
用户名=B.[姓名]
FROM stuff_info A JOIN inserted B ON (A.[姓名]=B.[姓名])
追问
no 不行~
追答
UPDATE A  SET 	序号=@regnum,
注册日期=@currentdate,
人员编号=@showcode,
登录密码='0000',
用户名=B.[姓名]
FROM stuff_info A JOIN inserted B ON (A.[姓名]=B.[姓名])
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
csuxp2008
2011-12-28 · TA获得超过6485个赞
知道大有可为答主
回答量:4704
采纳率:50%
帮助的人:2474万
展开全部
把最外层的begin...end拿掉试试,结尾加个go
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 1条折叠回答
收起 更多回答(3)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

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

类别

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

说明

0/200

提交
取消

辅 助

模 式