OLEDB不使用SQL语句直接打开数据表
一般来说获取数据库表的方法是采用类似
select * from table_name
这样的sql语句。SQL语句必然伴随着数据库的解释执行,一般来说效率比较低下,而且使用SQL语句时需要数据库支持ICommandText对象,但是在OLEDB中它是一个可选接口,也就是有的数据库可能不支持,这个时候OLEDB给我们提供了一种方法让我们能够在不使用SQL的情况下操作数据库表对象。
直接打开表对象需要使用IOpenRowset接口。该接口属于Session对象。
打开数据库表的一般步骤
- 声明一个DBID结构对象
- 为结构对象的ekind(对象种类)字段赋值DBKIND_NAME值
- 为结构对象的uName.pwszName字段赋值为表名
- 调用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);
}
详细的代码请参考: 完整代码
OLEDB不使用SQL语句直接打开数据表的更多相关文章
- 使用Sql语句快速将数据表转换成实体类
开发过程中经常需要根据数据表编写对应的实体类,下面是使用sql语句快速将数据表转换成对应实体类的代码,使用时只需要将第一行'TableName'引号里面的字母换成具体的表名称就行了: declare ...
- mysql中通过sql语句查询指定数据表的字段信息
mysql数据库在安装完成时,自动创建了information_schema.mysql.test这三个数据库.其中,information_schema记录了创建的所有数据库的相关信息,因此可以 ...
- 如何用SQL语句查询Excel数据?
如何用SQL语句查询Excel数据?Q:如何用SQL语句查询Excel数据? A:下列语句可在SQL SERVER中查询Excel工作表中的数据. 2007和2010版本: SELECT*FROMOp ...
- 使用SQL语句清空数据库所有表的数据
使用SQL语句清空数据库所有表的数据 近来发现数据库过大,空间不足,因此打算将数据库的数据进行全面的清理,但表非常多,一张一张的清空,实在麻烦,因此就想利用SQL语句一次清空所有数据.找到了三种方法进 ...
- 经典SQL语句大全之数据开发
数据开发 1.按姓氏笔画排序:Select * From TableName Order By CustomerName Collate Chinese_PRC_Stroke_ci_as //从少到多 ...
- sql 语句 获取某张表某列字段最短的某几行数据
sql 语句 获取某张表某列字段最短的某几行数据 SELECT C_name,C_code FROM Catalog where LEN(C_code)=LEN((SELECT top 1 C_cod ...
- phpmyadmin 打开数据表较多,数据量较大的数据库时出现超时的解决办法
用phpmyadmin打开数据表较多,数据量较大的数据库时,会出现超时,或者等半天打开了说数据库没有表.并且即便打开了,再进行其他浏览,编辑,sql等操作,页面也是相当慢的,慢等几乎无法忍受.这里慢也 ...
- Sql Server系列:数据表操作
表是用来存储数据和操作数据的逻辑结构,用来组织和存储数据,关系数据库中的所有数据都表现为表的形式,数据表由行和列组成.SQL Server中的数据表分为临时表和永久表,临时表存储在tempdb系统数据 ...
- 使用一个T-SQL语句批量查询数据表占用空间及其行数
原文:使用一个T-SQL语句批量查询数据表占用空间及其行数 要找到数据库中数据表占用的空间和存在的行数.可以使用sp_spaceused搭配数据表的名称.就可以产生该表耗用的空间和现有行数. 如: U ...
随机推荐
- Puppet全面详解
1. 概述 puppet是一个开源的软件自动化配置和部署工具,它使用简单且功能强大,正得到了越来越多地关注,现在很多大型IT公司均在使用puppet对集群中的软件进行管理和部署,如google利用p ...
- P3230 [HNOI2013]比赛
$ \color{#0066ff}{ 题目描述 }$ 沫沫非常喜欢看足球赛,但因为沉迷于射箭游戏,错过了最近的一次足球联赛.此次联 赛共N支球队参加,比赛规则如下: (1) 每两支球队之间踢一场比赛. ...
- mysql 面试题
1.一张表,里面有ID自增主键,当insert了17条记录之后,删除了第15,16,17条记录,再把Mysql重启,再insert一条记录,这条记录的ID是18还是15 ? 2.Mysql的技术特 ...
- 微信获取用户信息的两个接口和两个ACCESS_TOKEN
有一段时间没有搞微信开发了 ,今天突然要改一下程序! 回头一看 微信的帮助文档太tm的稀烂的,太难懂了,这做个笔记以后看着方便 微信有2个ACCESS_TOKEN, 1,基础接口的token 获取接口 ...
- Hibernate复合主键的注解
[转自] http://blog.csdn.net/happylee6688/article/details/17636801 最近做项目用到了Hibernate框架,采用了纯面向对象的思想,使用OR ...
- linux下忘记mysql的root密码
一.处理方案 #1. 结束当前正在运行的mysql进程 /etc/init.d/mysql stop #2. 用mysql安全模式运行并跳过权限验证 mysqld_safe --user=mysql ...
- 【总结】kali(amd64)中安装nessus
下载nessus: http://www.tenable.com/products/nessus/select-your-operating-system 注册nessus家庭版 http://www ...
- follow Up — 20181101
406. Minimum Size Subarray Sum public class Solution { /** * @param nums: an array of integers * @pa ...
- 2019.3.25 SQL语句(进阶篇1)
运算符 基本的加减乘除取余都可以在SQL中使用 新建Employee1表并添加数据 create table Employee1 (eid int primary key auto_increment ...
- 引导篇之HTTP事务
一个完整的HTTP事务流图: HTTP报文格式: 起始行:在请求报文中用来说明要做些什么,在响应报文中说明出现了什么情况 首部:起始行后面有0个或多个首部字段.每个首部字段都包含一个名字和一个值,为了 ...