SqlServer和Oracle中一些常用的sql语句7 游标

2016-12-30 09:54:43来源:oschina作者:深圳大道人点击

第七城市
declare db_cursor5 scroll cursor for select amazonOrderid,Name,AddressLine1 from dbo.OrdersAddress --声明游标
declare @t varchar(max)--定义变量
declare @t1 varchar(max)
declare @t2 varchar(max)
open db_cursor5--打开游标
Fetch Next From db_cursor5 Into @t,@t1 ,@t2--提取游标中的数据保存到变量中
while(@@fetch_status= 0)
begin
Fetch Next From db_cursor5 Into @t,@t1 ,@t2
/*这里放置循环操作逻辑*/
print (@t+'--------'+@t1+'--------'+@t2)
end
close db_cursor5--关闭游标
deallocate db_cursor5--释放游标
/*
105-3393966-8059426--------casey brown--------9453 PICKFORD PL
115-3011976-1227434--------Therese Hecker--------2210 Glenwood Rd
105-3393966-8059426--------casey brown--------9453 PICKFORD PL
105-3393966-8059426--------casey brown--------9453 PICKFORD PL
*/
ALTER PROC [dbo].[SynchData_SP]AS
declare db_cursor scroll cursor for select [userid],[username],[status] from demotemp--声明游标
declare @t1 int--定义变量
declare @t2 varchar(max)
declare @t3 varchar(max)
open db_cursor --打开游标
Fetch Next From db_cursor Into @t1,@t2 ,@t3--提取游标中的数据保存到变量中
while(@@fetch_status= 0)
begin
/*目标表存在则修改,不存在则新增*/
IF NOT EXISTS (SELECT userid FROM demoWHERE userid=@t1)
BEGIN
INSERT INTO demo(userid,username,STATUS) VALUES(@t1,@t2,@t3 )
END
ELSE
BEGIN
UPDATE demo SETSTATUS=@t3 WHERE userid=@t1
END
Fetch Next From db_cursor Into @t1,@t2 ,@t3
end
close db_cursor --关闭游标
deallocate db_cursor --释放游标
declare db_cursor4scroll cursor for select * from供应商--声明游标
open db_cursor4--打开游标
fetch first from db_cursor4 --读取游标中的第一条数据记录
fetch next from db_cursor4--读取游标中的下一条数据记录
fetch last from db_cursor4--读取游标中的最后一条数据记录
fetch prior from db_cursor4 --读取游标中的上一条数据记录
fetch absolute 2 from db_cursor4 --读取游标中的第二条数据记录
fetch relative 2 from db_cursor4 --读取游标当前记录下方的第二条数据记录
close db_cursor4--关闭游标
deallocate db_cursor4--释放游标
--利用变量输出游标中的字段值
declare db_cursor5 scroll cursor for select 职工号,姓名,工资 from 职工 --声明游标
declare @t varchar(10)--定义变量
declare @t1 varchar(10)
declare @t2 int
open db_cursor5--打开游标
fetch absolute 4 from db_cursor5 into @t,@t1,@t2 --提取游标中的数据保存到变量中
select @t as 职工号,@t1 as 职工名,@t2 as 工资 --输出变量中的值
close db_cursor5--关闭游标
deallocate db_cursor5--释放游标
--利用游标判断记录是否存在
declare db_cursor8 cursor scroll forselect * from 职工 where 职工号='zg2'
open db_cursor8
if @@fetch_status=0 --if条件语句
print '存在该记录'
else
print '不存在该记录'
close db_cursor8
deallocate db_cursor8
--在存储过程中使用游标
create procedure db_mypro
@x int
as
begin
declare mycursor scroll cursor
for
select * from 职工
open mycursor
fetch absolute @x from mycursor
close mycursor
deallocate mycursor
end
--显示职工表中的第五条记录
execute db_mypro 5
第七城市

最新文章

123

最新摄影

微信扫一扫

第七城市微信公众平台