文章导航PC6首页软件下载单机游戏安卓资源苹果资源

pc软件新闻网络操作系统办公工具编程服务器软件评测

安卓新闻资讯应用教程刷机教程安卓游戏攻略tv资讯深度阅读综合安卓评测

苹果ios资讯苹果手机越狱备份教程美化教程ios软件教程mac教程

单机游戏角色扮演即时战略动作射击棋牌游戏体育竞技模拟经营其它游戏游戏工具

网游cf活动dnf活动lol周免英雄lol礼包

手游最新动态手游评测手游活动新游预告手游问答

您的位置:首页精文荟萃破解文章 → ODBC 获得结果

ODBC 获得结果

时间:2004/10/15 1:03:00来源:本站整理作者:蓝点我要评论(0)

 

 


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


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



  1. 确认一个结果集是否可用。
  2. 将结果集的列绑定在适当的变量上。
  3. 取得行

完成对结果集的操作后,我们必须调用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的同好们不应忘记呀!(船长,我们找不到水......顺便问一句,这是地球吗%$#@&*^:-)


    
    
     
    
    
     

相关阅读 Windows错误代码大全 Windows错误代码查询激活windows有什么用Mac QQ和Windows QQ聊天记录怎么合并 Mac QQ和Windows QQ聊天记录Windows 10自动更新怎么关闭 如何关闭Windows 10自动更新windows 10 rs4快速预览版17017下载错误问题Win10秋季创意者更新16291更新了什么 win10 16291更新内容windows10秋季创意者更新时间 windows10秋季创意者更新内容kb3150513补丁更新了什么 Windows 10补丁kb3150513是什么

文章评论
发表评论

热门文章 去除winrar注册框方法

最新文章 比特币病毒怎么破解 比去除winrar注册框方法 华为无线路由器HG522-C破解教程(附超级密码JEB格式文件京东电子书下载和阅读限制破解教UltraISO注册码全集(最新)通过Access破解MSSQL获得数据

人气排行 华为无线路由器HG522-C破解教程(附超级密码JEB格式文件京东电子书下载和阅读限制破解教UltraISO注册码全集(最新)qq相册密码破解方法去除winrar注册框方法(适应任何版本)怎么用手机破解收费游戏华为无线猫HG522破解如何给软件脱壳基础教程