理解什么是游标,什么是指针

游标(cursor)

         是系统为用户开设的一个数据缓冲区,存放SQL语句的执行结果。每个游标区都有一个名字,用户可以用SQL语句逐一从游标中获取记录,并赋给主变量,交由主语言进一步处理。

                主语言是面向记录的,一组主变量一次只能存放一条记录,仅使用主变量并不能完全满足SQL语句向应用程序输出数据的要求。嵌入式SQL引入了游标的概念,用来协调这两种不同的处理方式。在数据库开发过程中,当你检索的数据只是一条记录时,你所编写的事务语句代码往往使用SELECT INSERT 语句。但是我们常常会遇到这样情况,即从某一结果集中逐一地读取一条记录。那么如何解决这种问题呢?游标为我们提供了一种极为优秀的解决方案。

 

     优点:

 

在数据库中,游标是一个十分重要的概念。游标提供了一种对从表中检索出的数据进行操作的灵活手段,就本质而言,游标实际上是一种能从包括多条数据记录的结果集中每次提取一条记录的机制。游标总是与一条SQL 查询语句相关联因为游标由结果集(可以是零条、一条或由相关的选择语句检索出的多条记录)和结果集中指向特定记录的游标位置组成。当决定对结果集进行处理时,必须声明一个指向该结果集的游标。如果曾经用C 语言写过对文件进行处理的程序,那么游标就像您打开文件所得到的文件句柄一样,只要文件打开成功,该文件句柄就可代表该文件。对于游标而言,其道理是相同的。可见游标能够实现按与传统程序读取平面文件类似的方式处理来自基础表的结果集,从而把表中数据以平面文件的形式呈现给程序。

我们知道关系数据库管理系统实质是面向集合的,在MS SQL SERVER 中并没有一种描述表中单一记录的表达形式,除非使用where 子句来限制只有一条记录被选中。因此我们必须借助于游标来进行面向单条记录的数据处理。由此可见,游标允许应用程序对查询语句select 返回的行结果集中每一行进行相同或不同的操作,而不是一次对整个结果集进行同一种操作;它还提供对基于游标位置而对表中数据进行删除或更新的能力;而且,正是游标把作为面向集合的数据库管理系统和面向行的程序设计两者联系起来,使两个数据处理方式能够进行沟通。

缺点:

游标速度较慢。数据量比较大时,占内存。

 

指针(Pointer)

在计算机科学中,指针(Pointer)是编程语言中的一个对象,利用地址,它的值直接指向(points to)存在电脑存储器中另一个地方的值。由于通过地址能找到所需的变量单元,可以说,地址指向该变量单元。因此,将地址形象化的称为“指针”。意思是通过它能找到以它为地址的内存单元[1]  在高级语言中,指针有效地取代了在低级语言,如汇编语言与机器码,直接使用通用暂存器的地方,但它可能只适用于合法地址之中。指针参考了存储器中某个地址,通过被称为反参考指针的动作,可以取出在那个地址中存储的值。作个比喻,假设将电脑存储器当成一本书,一张内容记录了某个页码加上行号的便利贴,可以被当成是一个指向特定页面的指针;根据便利粘贴面的页码与行号,翻到那个页面,把那个页面的那一行文字读出来,就相当于是对这个指针进行反参考的动作。[2] 

在信息工程中指针是一个用来指示一个内存地址的计算机语言的变量或中央处理器(CPU)中寄存器(Register)【用来指向该内存地址所对应的变量或数组】。指针一般出现在比较接近机器语言的语言,如汇编语言或C语言面向对象的语言如Java一般避免用指针。指针一般指向一个函数或一个变量。在使用一个指针时,一个程序既可以直接使用这个指针所储存的内存地址,又可以使用这个地址里储存的函数的值。

 

 

 

 

 

 

  • 2
    点赞
  • 15
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: SQL Server 中的游标是一种特殊的工具,可以用于在存储过程中逐行处理结果集。游标可以将结果集的行视为单独的数据单元,并允许在这些行上进行迭代处理。 举个例子,假设你有一张表,表中有许多用户订单记录。你想要写一个存储过程来遍历每一条记录,并对每一条记录执行相同的操作。你可以使用游标来实现这个目的。 游标有两种类型:静态游标和动态游标。静态游标在定义时就将结果集载入内存中,然后在内存中进行遍历。动态游标则是在执行时才载入结果集,并且在遍历过程中不会将数据载入内存。 使用游标的时候,需要注意一些注意事项: - 游标操作是资源密集型操作,应该尽量避免使用游标。在大多数情况下,使用 SET 操作或者 JOIN 操作可以达到同样的目的。 - 如果必须使用游标,应该尽量避免使用动态游标。静态游标在执行时更加高效。 - 在使用游标时,应该注意避免数据竞争的情况发生,因为游标操作可能导 ### 回答2: SQL Server中的游标是一种用于处理查询结果集的数据库对象。它可被看作是一个指向结果集中当前行的指针,并能够在结果集中移动以逐行处理数据。 游标在存储过程中使用的好处是可以处理一些复杂的业务逻辑,例如需要在多个表之间进行数据的逐行处理、更新或删除操作等。使用游标可以实现对结果集中的每一行进行逐个处理,同时还能够在需要时控制游标的移动和操作。 游标的使用过程通常包括以下几个步骤: 1. 声明游标:在存储过程中先声明一个游标变量,并指定查询语句以获取结果集。 2. 打开游标:使用OPEN语句打开游标,使其指向结果集的第一行。 3. 取得数据:使用FETCH语句获得当前游标所指向的行的数据,并进行相应的处理操作。 4. 移动游标:使用FETCH NEXT语句将游标移动到结果集中的下一行,以便后续处理。 5. 关闭游标:使用CLOSE语句关闭游标,释放相应的资源。 6. 释放游标:使用DEALLOCATE语句释放游标所占用的内存。 需要注意的是,在使用游标时应尽量避免使用全局游标,并在处理完每一行数据后及时关闭和释放游标以节省资源的占用。 总而言之,SQL Server中的游标是一种用于处理查询结果集的工具,能够以逐行的方式对结果集中的数据进行处理操作,以满足复杂的业务需求。 ### 回答3: SQL Server存储过程中的游标是用于处理查询结果集的一种指针机制。它允许我们按行处理查询结果,让我们可以在结果集上进行循环操作。 游标在存储过程中的使用需要以下几个步骤:首先,声明一个游标并将其与一个SELECT语句相关联;然后,打开游标并将其绑定到查询结果集;接下来,通过FETCH语句将游标定位到结果集中的某一行,并可以在该行上进行操作;最后,当我们不再需要游标时,需要关闭游标以释放资源。 存储过程中的游标可以用于各种目的,例如逐行处理结果集、在结果集中进行搜索、进行数据的插入、更新或删除等。但是,由于游标的操作需要占用内存和执行时间,过度使用游标可能会导致性能问题。因此,在使用游标时,需要注意控制结果集的大小,并合理优化游标的使用。 总之,SQL Server存储过程中的游标是一种用于按行处理查询结果集的机制。它可以在存储过程中对结果集进行循环操作,提供了一种灵活而强大的处理数据的方式。但是,需要注意合理使用游标,以避免可能的性能问题。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值