日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 运维知识 > 数据库 >内容正文

数据库

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

發布時間:2023/12/20 数据库 25 豆豆
生活随笔 收集整理的這篇文章主要介紹了 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, //返回對象的GUIDULONG 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); }

    詳細的代碼請參考: 完整代碼


    轉載于:https://www.cnblogs.com/lanuage/p/8830903.html

    總結

    以上是生活随笔為你收集整理的OLEDB不使用SQL语句直接打开数据表的全部內容,希望文章能夠幫你解決所遇到的問題。

    如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

    主站蜘蛛池模板: 国产91亚洲精品 | 动漫美女被到爽流 | 成人毛片视频免费看 | 男人日女人免费视频 | 国产又粗又猛又色 | 欧美国产日韩在线观看成人 | 国产91熟女高潮一区二区 | 超碰福利在线观看 | 国产一区二区三区四区视频 | 国产大片黄 | 午夜影片 | hitomi一区二区三区精品 | 欧美69囗交视频 | 红桃视频隐藏入口 | 神马午夜在线观看 | 熟妇女人妻丰满少妇中文字幕 | 天天躁日日躁狠狠躁 | 国产99久久久国产精品成人免费 | 摸大乳喷奶水www视频 | 亚洲一区二区三区成人 | www国产精品内射老熟女 | 人妻少妇被粗大爽9797pw | www.色播.com| 加勒比视频在线观看 | 牛牛精品一区 | 无遮挡边吃摸边吃奶边做 | 日本在线观看网站 | 桃色网站在线观看 | 吃奶在线观看 | 日韩最新中文字幕 | av影视天堂 | 老鸭窝成人 | www婷婷av久久久影片 | 性av在线| 国产在线观看精品 | 懂色一区二区二区av免费观看 | 亚洲免费黄色网址 | 波多野结衣a级片 | aaa影院 | 日韩三级一区 | 亚洲成人黄色 | 国产乱妇无码大片在线观看 | 中文字幕日韩在线播放 | 精品在线视频一区二区三区 | 国产成人99久久亚洲综合精品 | 日韩免费小视频 | 不卡一二三| 黄频在线播放 | 国产精品一品二区三区的使用体验 | 最新国产精品自拍 | 天堂网视频在线观看 | 麻豆精品国产 | 69福利视频 | 午夜小视频在线播放 | 国产无遮挡aaa片爽爽 | 久久96| 黄在线网站 | 黄色片网站在线免费观看 | 天天躁日日躁狠狠躁av麻豆 | 成人av亚洲 | 激情综合视频 | 热久久最新网址 | 成人av在线网站 | 亚洲成人av免费在线观看 | 国产99久久久欧美黑人 | 777精品久无码人妻蜜桃 | 国产素人在线 | 日韩精品123 | 五月婷婷综 | 96看片 | 国产精品手机在线观看 | 中文字幕精品一区 | 日本一区视频在线观看 | www.久草.com| 日日草夜夜操 | 国产精品久久免费视频 | 无码精品国产一区二区三区免费 | 国产一级做a爰片在线看免费 | 午夜精品福利视频 | 91在线播放国产 | 国产成人无码精品久久久久 | 亚洲精品lv | 99国产免费 | melody在线高清免费观看 | 黄色小视频在线免费观看 | 欧美日韩伊人 | 可以看av的网站 | 亚洲色图一区二区 | 国产中文字幕在线视频 | 日本激情网址 | 成人网免费看 | 11一12免费毛片 | 一道本在线播放 | 偷拍亚洲综合 | jizz欧美性20 | 茄子视频懂你更多在线观看 | 国产精品伦理 | 97人妻精品一区二区三区免费 | aa级黄色片|