SQL Server 数据库SQL语句中CURSOR(游标)的使用

本文主讲SQL Server数据库中 游标CURSOR 的使用,欢迎阅读~


前言

将SQL嵌入到高级语言中混合编程,SQL语句负责操纵数据库,高级语言语句负责控制逻辑流程。
数据库工作单元与源程序工作单元之间的通信主要包括:
(1) 向主语言传递SQL语句的执行状态信息,使主语言能够据此信息控制程序流程,主要用SQL通信区( SQL Communication Area, SQLCA)实现。
(2) 主语言向SQL语句提供参数,主要用主变量(host variable) 实现。
(3) 将SQL语句查询数据库的结果交主语言处理,主要用主变量和游标(cursor) 实现。
ps:SQL语句中使用的主语言程序变量简称为主变量,根据其作用的不同又可分为输入主变量和输出主变量


为什么要使用游标

👀SQL语言是面向集合的,一条SQL语句可以产生或处理多条记录;而主语言是面向记录的,一组主变量一次只能存放一条记录。
所以仅仅使用主变量并不能完全满足SQL语句向应用程序输出数据的要求,为此嵌入式SQL引入了游标的概念,用来协调这两种不同的处理方式~
游标是系统为用户开设的数据缓冲区,存放SQL语句的执行结果,每个游标区都有一个名字。
用户可以用SQL语句逐一从游标中获取记录,并赋给主变量,交由主语言进一步处理~


使用游标的SQL语句

一般情况下,SELECT语句查询结果是多条记录,因此需要用游标机制将多条记录一次一条地送给主程序处理,从而把对集合的处理转换为对单个记录的处理
使用游标的步骤:
(1)说明游标
DECLARE语句为一条SELECT语句定义游标:

EXEC SQL DECLARE<游标名> CURSOR FOR <SELECT 语句>;

ps:定义游标仅仅是一条说明性语句, 这时关系数据库管理系统并不执行SELECT语句

  • 16
    点赞
  • 41
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值