OLEDB不使用SQL语句直接打开数据表
生活随笔
收集整理的這篇文章主要介紹了
OLEDB不使用SQL语句直接打开数据表
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
一般來說獲取數據庫表的方法是采用類似
select * from table_name這樣的sql語句。SQL語句必然伴隨著數據庫的解釋執行,一般來說效率比較低下,而且使用SQL語句時需要數據庫支持ICommandText對象,但是在OLEDB中它是一個可選接口,也就是有的數據庫可能不支持,這個時候OLEDB給我們提供了一種方法讓我們能夠在不使用SQL的情況下操作數據庫表對象。
直接打開表對象需要使用IOpenRowset接口。該接口屬于Session對象。
打開數據庫表的一般步驟
IOpenRowset接口屬于Session,可以在使用CreateSession時讓其直接打開這個接口,而且該接口是必須實現的接口,因此不用擔心獲取不到的情況,得到這個接口后就可以直接使用接口的OpenRowset方法。
OpenRowset函數原型如下:
從函數定義上來,這種方式還可以用來打開索引
使用實例
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语句直接打开数据表的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: dotnet Core学习之旅(二):安
- 下一篇: Django REST framewor