news 2026/6/22 23:37:37

汇编语言全接触-39.获得结果

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
汇编语言全接触-39.获得结果

在本章中,我们来学习如何获得SQL语句的执行结果。

我们称由查询返回的一组记录为一个 结果集(result set) (或在VB中被称为recordset).检索结果通常分为以下几个步骤:

确认一个结果集是否可用。

将结果集的列绑定在适当的变量上。

取得行

完成对结果集的操作后,我们必须调用SQLCloseCursor来销毁它.

确认一个结果集是否可用

有时在执行SQL语句后,我们就已经知道结果集是否可用了。如果执行的语句并不是返回结果集的类型,我们就知道结果集不可用了。但有时我们不太清楚使用的SQL语句是什么类型,比如说,让用户自行输入SQL语句。这时,我们必须确认是否有结果集被建立,这可以通过SQLNumResultCols函数实现。如果结果集存在,则该函数返回结果集中的列数(字段数)。语法如下:

SQLNumResultCols proto StatementHandle:DWORD, pNumCols:DWORD

StatementHandle 语句句柄

pNumCols 指向一个双字的指针,其中包含了结果集的列数。

如果 pNumCols指向的值为0,那么表明结果集不存在。

绑定列

与绑定一个变量到SQL语句的参数相同,我们连接(绑定)一个变量到结果集中的某一列。这里要用到的函数是SQLBindCol,语法如下:

SQLBindCol proto StatementHandle:DWORD,

ColumnNumber:DWORD,

TargetType:DWORD,

TargetValuePtr:DWORD,

BufferLength:DWORD,

pStrLenOrIndPtr:DWORD

StatementHandle 语句句柄

ColumnNumber 结果集中要绑定的列序数.列序数从1开始.列0是书签(bookmark)列.

TargetType The 指示 TargetValuePtr指向的变量(缓冲区)的类型的常数。

TargetValuePtr 指向将要捆绑到列的变量或缓冲区的指针。当调用SQLFetch来获得结果集中的行时,本参数指向的变量或缓冲区将被填入被绑定的列的值。

BufferLength 由TargetValuePtr指向的缓冲区的长度。

pStrLenOrIndPtr 参见前章SQLBindParameter

例子:

.data?

buffer db 21 dup(?)

DataLength dd ? ;调用SQLFetch后,被填入缓冲区的字符串的长度

.code

.....

invoke SQLBindCol, hStmt, 1, SQL_C_CHAR, addr buffer, 21, addr DataLength

取得一行

非常简单.先调用SQLFetch 检索结果集的一列到绑定的变量中。当SQLFetch调用完成,游标(cursor)被更新(updated).可以认为游标就是一个记录指针(record pointer). 它指明了SQLFetch调用后将返回哪一行。比如说,如果结果集有4列,当结果集建立时,游标指向第一行.当调用了SQLFetch 后,游标被加1。所以如果调用了SQLFetch 4次,就没有更多的行可被提交了。游标会显示指向文件尾(EOF). SQLFetch语法如下:

SQLFetch proto StatementHandle:DWORD

当没有行可提交时,这个函数返回 SQL_NO_DATA.

例子:

.data?

buffer db 21 dup(?)

DataLength dd ?

.code

.....

invoke SQLBindCol, hStmt, 1, SQL_C_CHAR, addr buffer, 21, addr DataLength

invoke SQLFetch, hStmt

译者废话:还记得地球的经纬吗?我们通过SQLBindCol来定位经度(列),用游标来定义纬度(行),用SQLFetch来获得坐标,而结果集就是地球。大航海时代2的同好们不应忘记呀!(船长,我们找不到水......顺便问一句,这是地球吗%$#@&*^:-)

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/23 19:33:48

经典算法题型之编辑距离(二)

解题思路简要概括题意,使用最少的操作使得「word1」与「word2」相同。很明显所要进行的操作是从左至右线性增长的,不难联想到最长公共子序列(LCS),因此我们令 f[i][j] 表示最少的操作使得 「word1」的前 i 个字符与「w…

作者头像 李华
网站建设 2026/6/23 10:38:41

Linly-Talker支持静音时段自动关闭麦克风吗?

Linly-Talker 支持静音时段自动关闭麦克风吗? 在数字人系统日益走向实时化、智能化的今天,一个看似微小却影响深远的问题浮出水面:当用户没有说话时,系统是否应该持续监听?这个问题背后,牵涉到资源效率、识…

作者头像 李华
网站建设 2026/6/23 5:25:56

Linly-Talker如何优化内存占用?轻量化改进措施

Linly-Talker如何优化内存占用?轻量化改进措施 在虚拟主播、智能客服和数字员工逐渐走入日常生活的今天,用户对交互体验的要求越来越高——不仅要“能对话”,还要“反应快”“不卡顿”“能在手机或普通电脑上跑得动”。然而现实是&#xff0c…

作者头像 李华
网站建设 2026/6/23 10:24:53

[Java]PTA:jmu-Java-06异常-finally

代码中向系统申请资源,到最后都要将资源释放。现有一Resource类代表资源类,包含方法:open(String str)打开资源,声明为抛出Exception(包含出错信息)。close()方法释放资源,声明为抛出RuntimeException(包含出错信息)现…

作者头像 李华
网站建设 2026/6/23 11:46:13

9、高级 Active Directory 配置与复制管理全解析

高级 Active Directory 配置与复制管理全解析 1. 命令行管理复制活动介绍 在 Active Directory 环境中,通过命令行工具管理复制是一项重要技能。下面以 Activity 2 - 7 为例,详细介绍如何使用 repadmin 和 dcdiag 这两个命令行程序来管理复制。 - 活动概述 - 所需…

作者头像 李华
网站建设 2026/6/23 21:32:40

Magistral-Small-1.2:多模态推理新升级

Mistral AI推出Magistral-Small-1.2模型,首次实现240亿参数级模型的多模态能力与本地高效部署,标志着轻量化大模型在推理与视觉理解领域的重要突破。 【免费下载链接】Magistral-Small-2509-FP8-torchao 项目地址: https://ai.gitcode.com/hf_mirrors…

作者头像 李华