首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 数据库 > SQL Server >

求一存储过程写法,TOP解决方法

2013-03-19 
求一存储过程写法,TOPA表有字段:USERIDNICKNAMEB表有字段:USERIDMONEY要求查询 前15名并且 判断B表是否已

求一存储过程写法,TOP
A表有字段:USERID    NICKNAME
B表有字段:USERID    MONEY

要求查询 前15名  并且 判断B表是否已经重复USERID

谢谢
[解决办法]
create proc aa
as
begin
select top 15 * into #a from A 
while exists(select 1 from #a)
begin
 declare @USERID=USERID from #a
 if not exists(select 1 from B where USERID=USERID )
   insert into B(..)select..from #a
 delete #a where USERID=USERID
end
end
go
[解决办法]



declare @tab table(userid int,nickname varchar(20))
insert into @tab select top 15 * from a order by GETDATE()
insert into b select sel.userid,0 from(
select b.userid from b right join @tab on a.userid=@tab.userid where b.userid is null
)as sel

这个应该可以满足你的要求了。

热点排行