文档章节

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

深圳大道
 深圳大道
发布于 2016/12/29 15:24
字数 640
阅读 5
收藏 0
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 demo  WHERE userid=@t1)
					BEGIN
						INSERT INTO demo(userid,username,STATUS) VALUES(@t1,@t2,@t3 ) 
					END
				ELSE
					BEGIN
						UPDATE demo SET  STATUS=@t3 WHERE userid=@t1
					END				
				Fetch Next From db_cursor Into @t1,@t2 ,@t3   				
			end   
	close db_cursor		--关闭游标    
	deallocate db_cursor   --释放游标
declare db_cursor4  scroll 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 for  select * 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

本文转载自:http://blog.csdn.net/smartsmile2012/article/details/9162165

深圳大道
粉丝 3
博文 877
码字总数 0
作品 0
深圳
架构师
私信 提问
数据库访问之Sqlite的不同之处

在我的Winform开发框架中,底层的数据访问支持多种不同的数据库,在数据库访问的开发过程中,发现Sqlite多数情况下,操作都和SqlServer或者说是和标准Sql差不多的。当然,Sqlite本身也有一些...

长平狐
2012/08/22
108
0
数据库访问之Sqlite的不同之处

在我的Winform开发框架中,底层的数据访问支持多种不同的数据库,在数据库访问的开发过程中,发现Sqlite多数情况下,操作都和SqlServer或者说是和标准Sql差不多的。当然,Sqlite本身也有一些...

长平狐
2012/06/11
80
0
OpenJWeb 1.8数据库管理工具功能说明

QQ:29803446 msn:baozhengw999@hotmail.com email:baozhengw@163.com 联系人:王先生 OpenJWeb 1.8数据库管理工具功能说明 由于使用sqlserver 的DTS跨数据库复制功能经常失败,所以openjweb开...

迷途d书童
2012/03/09
75
0
sqlserver,你的delete语句表名为什么不能别名?

前几天写了几行sql,用于清除环境里面的脏数据,平时开发用的是oracle数据库,看了下里面的语句,处理concat字符串拼接函数看起来稍微特殊点,其它都没有啥问题。百度了下,cancat可以用在收...

heshifk
2018/04/23
45
0
使用 Informatica 做将字符串转换成日期

数据源为 SQLServer 数据库,且源字段 varchar 类型。需要抽取到 Oracle 数据库中,并且转换为 date 类型。 由于源表和目标表是两种不同的数据库,且数据类型不同,所以无法在源表限定转换器...

DreamOver
2018/06/08
0
0

没有更多内容

加载失败,请刷新页面

加载更多

前端面试题汇总

一. HTML常见的兼容性 1.HTML5 标签在低版本浏览器不兼容 解决办法:使用html5shiv库,引入下列语句 <!--[if lte IE 8]> <script src="https://cdn.bootcss.com/html5shiv/r29/html5.js"></sc......

蓝小驴
41分钟前
10
0
OSChina 周四乱弹 —— 我气的脸都黑了!

Osc乱弹歌单(2019)请戳(这里) 【今日歌曲】 小小编辑推荐《Red Battle》- 高橋李依 / 豊崎愛生 《Red Battle》- 高橋李依 / 豊崎愛生 手机党少年们想听歌,请使劲儿戳(这里) @丶Lion ...

小小编辑
54分钟前
677
23
找OSG教程, B站就有

https://www.bilibili.com/video/av64849038?from=search&seid=11632913960900279653

洛克人杰洛
今天
6
0
学习记录(day07-Vue组件、自定义属性、自定义事件)

[TOC] 1.1.1什么是组件 一个vue文件就是一个组件 组件将html标签/css样式/对应JS打包成一个整体,也可以理解钻进一个具有样式和特效的自定义标签。 一、编写组件(提供方)<template> <di...

庭前云落
今天
5
0
使用Prometheus监控SpringBoot应用

通过之前的文章我们使用Prometheus监控了应用服务器node_exporter,数据库mysqld_exporter,今天我们来监控一下你的应用。(本文以SpringBoot 2.1.9.RELEASE 作为监控目标) 编码 添加依赖 使...

JAVA日知录
今天
9
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部