sp_cursoropen的动态传参用法

本文介绍如何在 SQL Server 中通过 sp_cursoropen 使用动态 SQL 传递参数,并详细解释了 scroll_options 参数的设置方法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

 

sp_cursoropen的动态传参用法

 

 

------------------------------------------------------------------------

-- Author:  happyflystone 

-- Date  :  2009-04-29 12:23:00

-- Ver:     Microsoft SQL Server 2005 - 9.00.2047.00 (Intel X86)

--      Apr 14 2006 01:12:25

--          Copyright (c) 1988-2005 Microsoft Corporation

--          Standard Edition on Windows NT 5.0 (Build 2195: Service Pack 4)

--        转载注明出处

--        blog.youkuaiyun.com/happyflystone

------------------------------------------------------------------------

 

测试环境准备:

 

CREATE TABLE T2(A INT,B INT)

INSERT INTO T2 SELECT 3,4

INSERT INTO T2 SELECT 2,6

INSERT INTO T2 SELECT 8,2

INSERT INTO T2 SELECT 1,4

GO

 

常规下直接取得T2表的所有数据,相信大家都会吧,下面我简单测试一下

 

DECLARE   @cursor   INT  

DECLARE   @rowcount   INT

EXEC sp_cursoropen  @cursor OUTPUT, N'SELECT * FROM t2', 2, 8193

EXEC sp_cursorfetch @cursor, 2, 0, 4

EXEC   sp_cursorclose   @cursor

/*

a           b

----------- -----------

a           b

----------- -----------

3           4

2           6

8           2

1           4

*/

 

好,下面就是如果要想仅返回a = 2的记录呢?我们看帮助

Syntax

sp_cursoropen [@cursor =] cursor_handle OUTPUT,
    [@stmt =] 'stmt'
    [, [@scrollopt =] scroll_options OUTPUT]
    [, [@ccopt =] concurrency_options OUTPUT]
    [, [@rowcount =] rowcount OUTPUT]

[
    {, [@paramdef =] N'parameter_name data_type [,...n]' }
    {, [@param1 =] value1 [,...n] }

]

 

看来也不难呀,动态SQL写了那么多照着写就是了,好,我们试试看

 

 

DECLARE   @cursor   INT  

DECLARE   @rowcount   INT

EXEC sp_cursoropen @cursor OUTPUT , N'SELECT * FROM t2 where a=@id'

                        , 2 , 8193 , @rowcount  output ,N'@id int' ,@id=2

EXEC sp_cursorfetch @cursor, 2, 0, 4

EXEC   sp_cursorclose   @cursor

 

/*

正在直接执行SQL;无游标。

消息137,级别15,状态2,第1

必须声明标量变量"@id"

消息16909,级别16,状态1,过程sp_cursorfetch,第1

sp_cursorfetch: 所提供的游标标识符值(0)无效。

消息16909,级别16,状态1,过程sp_cursorclose,第1

sp_cursorclose: 所提供的游标标识符值(0)无效。

*/

 

看来没有得到我们想的结果吧,这原因出在哪儿哟?

下面我先给出正常结果:

 

DECLARE   @cursor   INT  

DECLARE   @rowcount   INT

EXEC sp_cursoropen @cursor OUTPUT                       

                        , N'SELECT   *   FROM   t2   where   a=@id'

                        , 135170

                        , 8193

                        , @rowcount  output

                      ,N'@id int'

                        ,@id=2

EXEC sp_cursorfetch @cursor, 2, 0, 4

EXEC   sp_cursorclose   @cursor

 

/*

a           b

----------- -----------

 

a           b

----------- -----------

2           6

*/

 

DECLARE   @cursor   INT  

DECLARE   @rowcount   INT

EXEC   sp_cursoropen      @cursor   OUTPUT                       

                        , N'SELECT   *   FROM   t2   where   a=@id'

                        , 4098

                        , 8193

                        , @rowcount  output

                      ,N'@id int'

                        ,@id=2

EXEC sp_cursorfetch @cursor, 2, 0, 4

EXEC   sp_cursorclose   @cursor

 

/*

a           b

----------- -----------

 

a           b

----------- -----------

2           6

*/

大家一定要问这个4098 135170哪来的呀,这就是根据配置项给合出来的一个值,事由上在网上提供的资料也有不对的地方,那个作者使用的是2 ,而2仅是表明这个光标是动态,对于参数没有定义接收,也就是2不能让它知道SQL语句要接受参数值。

 

结论:其实我们只是没有注意到这个第三个参数的设置而已,根据参数列进行组合达到自己的目的,我们先看看这个参数的说明:

[@scrollopt =] scroll_options OUTPUT

Is the cursor scroll type. scroll_options is int with a default of 1 (keyset-driven), and can be a combination of these values (exactly one of the first 5 must be specified).

Value

Description

0x0001

Keyset-driven cursor.

0x0002

Dynamic cursor.

0x0004

Forward-only cursor.

0x0008

Static cursor.

0x0010

Fast forward-only cursor.

0x1000

Parameterized query.

0x2000

Auto fetch.

0x4000

Auto close.

0x8000

Check acceptable types

0x10000

Keyset-driven acceptable.

0x20000

Dynamic acceptable.

0x40000

Forward-only acceptable.

0x80000

Static acceptable.

0x100000

Fast forward-only acceptable.

On return, @scrollopt contains the type of cursor actually created, which may not match what was requested.

对于上面的例子我们是要有参数传送的,好我们看这个 0x1000 Parameterized query

参数化查询,正是我们所想要的,当然于0x0002 Dynamic cursor.

这是个是必须的啦,两个相加,0x1002 =è 4098 OK正好是我上面所用的参数吧,

 

用Androidstudio的2024.1.2版本编程实现“日记本”,项目名称为diary03。主要功能:登录、注册功能,登录页面有记住密码选项;日记的增删改查等功能;要求能显示每一个日记的记录时间、记录内容;在日记本中添加图片时能调用摄像头拍照和从相册选择图片。 功能可自由扩充,页面美观,有良好的交互性;实现日记的创建、编辑、删除与查询等核心功能,输入密码时隐藏密码;使用SQLite数据库进行本地数据持久化存储;当前登录的用户信息储存在Sharedpreferences轻型数据类中,按钮实现页面跳转;项目整体色调为清新简约的淡蓝色。 要求:1、包含三张具有核心功能的表,有主键和其他字段约束;2、xml文件布局层次清晰,有样式的应用效果,使用较丰富且常见简单的控件;3、在控件上尽可能多的定义事件,比如列表上的单击事件,下拉列表的选择事件,菜单上的按钮事件等;4、正确利用activity生命周期的方和组件间通信机制,完成页面的跳转和数据的递,客户端app能正确参,能根据参数实现activity所需功能。 注意:1、整个项目都使用常见且简单的方,不要太复杂,完成功能达到要求即可,不使用lambda函数。2、展示完整的项目结构和完整而详细的代码文件以及项目运行指南,并详细展示每个文件的全部内容(包括java-com.example.diary03下的Java文件和layout文件夹、values文件夹下的文件),按照实现逻辑,拆分代码的核心模块,每个模块进行逐一解释,尽量通过比喻、类比等表达方式,帮助我理解代码中的抽象概念或复杂逻辑。
最新发布
06-07
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值