WEB开发网
开发学院软件开发VC ADO第一次亲密接触 -- ADO开发实践之一 阅读

ADO第一次亲密接触 -- ADO开发实践之一

 2006-07-22 11:16:52 来源:WEB开发网   
核心提示: (2)利用Command对象来执行SQL命令_CommandPtr m_pCommand;m_pCommand.CreateInstance("ADODB.Command");_variant_t vNULL;vNULL.vt = VT_ERROR;vNULL.scod

(2)利用Command对象来执行SQL命令

_CommandPtr m_pCommand;
 m_pCommand.CreateInstance("ADODB.Command");
 _variant_t vNULL;
 vNULL.vt = VT_ERROR;
 vNULL.scode = DISP_E_PARAMNOTFOUND;///定义为无参数
 m_pCommand->ActiveConnection = m_pConnection;///非常关键的一句,将建立的连接赋值给它
 m_pCommand->CommandText = "SELECT * FROM users";///命令字串
 m_pRecordset = m_pCommand->Execute(&vNULL,&vNULL,adCmdText);///执行命令,取得记录集

在这段代码中我们只是用Command对象来执行了SELECT查询语句,Command对象在进行存储过程的调用中能真正体现它的作用。下次我们将详细介绍。

(3)直接用Recordset对象进行查询取得记录集

例如

m_pRecordset->Open("SELECT * FROM users",_variant_t((IDispatch *)m_pConnection,true),adOpenStatic,adLockOptimistic,adCmdText);

Open方法的原型是这样的:

HRESULT Recordset15::Open ( const _variant_t & Source, const _variant_t & ActiveConnection, enum CursorTypeEnum CursorType, enum LockTypeEnum LockType, long Options )

其中:

①Source是数据查询字符串

②ActiveConnection是已经建立好的连接(我们需要用Connection对象指针来构造一个_variant_t对象)

③CursorType光标类型,它可以是以下值之一,请看这个枚举结构:

enum CursorTypeEnum

{

adOpenUnspecified = -1,///不作特别指定

adOpenForwardOnly = 0,///前滚静态光标。这种光标只能向前浏览记录集,比如用MoveNext向前滚动,这种方式可以提高浏览速度。但诸如BookMark,RecordCount,AbsolutePosition,AbsolutePage都不能使用

上一页  1 2 3 4 5 6  下一页

Tags:ADO 第一次 亲密

编辑录入:爽爽 [复制链接] [打 印]
赞助商链接