OLEDB不使用SQL语句直接打开数据表

一般来说获取数据库表的方法是采用类似

select * from table_name

这样的sql语句。SQL语句必然伴随着数据库的解释执行,一般来说效率比较低下,而且使用SQL语句时需要数据库支持ICommandText对象,但是在OLEDB中它是一个可选接口,也就是有的数据库可能不支持,这个时候OLEDB给我们提供了一种方法让我们能够在不使用SQL的情况下操作数据库表对象。 直接打开表对象需要使用IOpenRowset接口。该接口属于Session对象。

打开数据库表的一般步骤

  1. 声明一个DBID结构对象
  2. 为结构对象的ekind(对象种类)字段赋值DBKIND_NAME值
  3. 为结构对象的uName.pwszName字段赋值为表名
  4. 调用IOpenRowset接口的OpenRowset方法,将DBID结构的指针传入,并让函数返回结果集对象

IOpenRowset接口属于Session,可以在使用CreateSession时让其直接打开这个接口,而且该接口是必须实现的接口,因此不用担心获取不到的情况,得到这个接口后就可以直接使用接口的OpenRowset方法。 OpenRowset函数原型如下:

HRESULT OpenRowset(
   IUnknown    *pUnkOuter,
   DBID        *pTableID, //打开表时使用该结构
   DBID        *pIndexID, //打开索引时使用这个参数
   REFIID       riid, //返回对象的GUID
   ULONG        cPropertySets, //给对应返回对象设置的属性集的个数
   DBPROPSET    rgPropertySets[], //给对应对象设置的属性集
   IUnknown   **ppRowset); // 返回的接口

从函数定义上来,这种方式还可以用来打开索引

使用实例

BOOL OpenTable(IOpenRowset *pIOpenRowset, IRowset* &pIRowset)
{
    DBID dbId = {0};
    dbId.eKind = DBKIND_NAME;
    dbId.uName.pwszName = OLESTR("aa26");

    DBPROP dbRowsetProp[4] = {0};
    DBPROPSET dbRowsetPropset[1] = {0};

    //运行直接使用对应接口函数对数据库进行增删改操作
    dbRowsetProp[0].colid = DB_NULLID;
    dbRowsetProp[0].dwOptions = DBPROPOPTIONS_REQUIRED;
    dbRowsetProp[0].dwPropertyID = DBPROP_UPDATABILITY;
    dbRowsetProp[0].vValue.vt = VT_I4;
    dbRowsetProp[0].vValue.intVal = DBPROPVAL_UP_CHANGE | DBPROPVAL_UP_DELETE | DBPROPVAL_UP_DELETE;
    //运行在删改的同时插入数据
    dbRowsetProp[1].colid = DB_NULLID;
    dbRowsetProp[1].dwOptions = DBPROPOPTIONS_REQUIRED;
    dbRowsetProp[1].dwPropertyID = DBPROP_CANHOLDROWS;
    dbRowsetProp[1].vValue.vt = VT_BOOL;
    dbRowsetProp[1].vValue.boolVal = VARIANT_TRUE;
    //打开IRowsetUpdate接口,实现延迟更新
    dbRowsetProp[2].colid = DB_NULLID;
    dbRowsetProp[2].dwOptions = DBPROPOPTIONS_REQUIRED;
    dbRowsetProp[2].dwPropertyID = DBPROP_IRowsetUpdate;
    dbRowsetProp[2].vValue.vt = VT_BOOL;
    dbRowsetProp[2].vValue.boolVal = VARIANT_TRUE;

    dbRowsetPropset[0].cProperties = 3;
    dbRowsetPropset[0].guidPropertySet = DBPROPSET_ROWSET;
    dbRowsetPropset[0].rgProperties = dbRowsetProp;

    HRESULT hRes = pIOpenRowset->OpenRowset(NULL, &dbId, NULL, IID_IRowset, 1, dbRowsetPropset, (IUnknown**)&pIRowset);
    return SUCCEEDED(hRes);
}

详细的代码请参考: 完整代码


本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏Ryan Miao

mysql插入日期 vs oracle插入日期

今天做oracle日期插入的时候突然开始疑惑日期是如何插入的。 用框架久了,反而不自己做简单的工作了。比如插入。 通常,新建一个表对象,然后绑定数据,前端for...

3069
来自专栏*坤的Blog

自写文件小工具类

1643
来自专栏分布式系统进阶

Librdkafka的基础数据结构 2 --- 定时器 原子操作与引用计数

引用了一个新的struct来将引用计数和调用信息结合起来, 使用链表来管理这个struct的对象. 每次对引用计数的操作都要操作这个链表.

881
来自专栏数据结构与算法

SPOJ1043 GSS1(线段树)

注意查询的时候不能按照以前的方式写,因为不知道变量的下界,最稳妥的办法就是判三种情况

951
来自专栏xiaoheike

Hibernate save, saveOrUpdate, persist, merge, update 区别

hibernate save()方法能够保存实体到数据库,正如方法名称save这个单词所表明的意思。我们能够在事务之外调用这个方法,这也是我不喜欢使用这个方法保...

1283
来自专栏图像识别与深度学习

蓝牙项目开发心得

3159
来自专栏MasiMaro 的技术博文

Windows内核中的内存管理

其中PAGED_CODE是一个WDK中提供的一个宏,只在debug版本中生效,用于判断当前的中断请求级别,当级别高于DISPATCH_LEVEL(包含这个级别)...

1042
来自专栏Golang语言社区

go语言的sql包原理与用法分析

go的sql包是在pkg/database中,里面的两个包sql和sql/driver可以一起看。建议看这个两个包之前可以先看看sql文件夹下的doc.txt。...

2984
来自专栏用户2442861的专栏

[疯狂Java]JDBC:PreparedStatement预编译执行SQL语句

    1) SQL语句和编程语言一样,仅仅就会普通的文本字符串,首先数据库引擎无法识别这种文本字符串,而底层的CPU更不理解这些文本字符串(只懂二进制机器指...

2452
来自专栏伦少的博客

打印(获取)HDFS路径下所有的文件名(包括子目录下的)

自己有个需求,如题,需要获取HDFS路径下所有的文件名,然后根据文件名用Spark进行后续操作。想了一下用Spark好像不太容易获取到,还要递归的去获取子目录下...

2681

扫码关注云+社区