青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

posts - 45,  comments - 232,  trackbacks - 0

工程下載: http://m.shnenglu.com/Files/dyj057/AdoDbv1.0-2007-1-25.rar

前幾日看到有位大哥發布的 ADO 數據庫的封裝,到處是模板,不免有些頭暈,想起自己寫的 ADO 數據庫封裝了,首先聲明沒有模板。但根據我 3 年使用的經驗,確實很實用,

特點:

l???????? 多線程安全的。

l???????? 使用標準 C++ 數據類型,屏蔽了 com 數據類型和異常,減少了復雜性。

l???????? 操作簡單,直觀

1 .下面是使用它進行存儲過程的例子代碼:

異常的處理請參看: http://m.shnenglu.com/dyj057/archive/2007/01/24/17944.html

#include "AdoConn.h"

#include "AdoStoredProc.h"

#include "comm_exception.h"

using namespace C2217::StdLib;

using namespace C2217::Data;

void main()

{

?????? try

?????? {

????????????? CAdoConn _conn("Provider=SQLOLEDB;Data Source=192.9.207.214;Initial Catalog=ibmsweb;User ID=sa; Password=sa;");

????????????? _conn.Open();

????????????? CAdoStoredProc sp(_conn,"Accounts_Roles_Create");

?

????????????? CAdoStringPara para("Description", "Para9", 50);

????????????? sp.AddPara(&para);

?

????????????? int count =0? ;//sp.ExecuteNonQuery();

????????????? cout << " affected cout " << count <<endl;

??????

????????????? CAdoStringPara *pStringPara = dynamic_cast<CAdoStringPara *>(sp["Description"]);

????????????? if(pStringPara)

????????????? {

???????????????????? cout << pStringPara->getValue() <<endl;

????????????? }

?

????????????? sp.ClearParameters();

?

????????????? //Read to dataset

????????????? CAdoRecordSet readResult;

????????????? sp.setSpName("Accounts_Users_Select_All");

????????????? cout << "Read affected item cout : " << sp.Execute(readResult);

?

????????????? //cout << "Read Count :" << readResult.getRecordCount() <<endl;

?????? }

?????? catch(comm_exception &e)

?????? {

????????????? SET_CATCH_POS(e);

????????????? std::cout << e;

?????? }

?????? catch(const exception &e)

?????? {

????????????? cout << e.what();

?????? }

}

2 .讀取數據的例子:

const CAdoConn &? _conn? =S_DeviceDb::instance()->GetAdoConn();

?????? CString sql;

?????? sql.Format("select * from %s where tag_name = '%s' ",

????????????? m_tableName, GetName() );

?????? CAdoRecordSet result;

?????? int count = _conn.Execute(sql, result);

?????? if(count ==1)

?????? {

????????????? result.MoveFirst();

????????????? SetDescription( result.readStr("description").c_str());

????????????? SetUnits( result.readStr("uints").c_str());

????????????? SetType( result.readStr("data_type").c_str());

????????????? SetWritebale( result.readInt("writeable"));

????????????? SetExpress( result.readStr("cacu_express").c_str() );

????????????? SetDeviceAddress( result.readInt("device_address"));

????????????? SetRegisterAddress( result.readInt("register_address"));

????????????? SetDataLen( result.readInt("data_length"));

????????????? SetBitsStartIndex( result.readInt("start_bit_index"));

????????????? SetBitsCount( result.readInt("bit_count"));

?????? }

3 .刪除數據的例子:

const CAdoConn &? _conn? =S_DeviceDb::instance()->GetAdoConn();

?????? CString sql;

?????? sql.Format("delete from %s where tag_name = '%s'", m_tableName, GetName() );

?????? _conn.ExecuteNonQuery( sql);

4 .更新數據的例子:

const CAdoConn & ?_conn? =S_DeviceDb::instance()->GetAdoConn();

?????? CString sql;

?????? sql.Format("update %s set description='%s',? uints='%s', data_type='%s',\

???????????????????? ?? writeable=%d, cacu_express='%s', device_address=%d, register_address=%d, data_length =%d,\

???????????????????? ?? start_bit_index = %d, bit_count = %d where tag_name = '%s' ", m_tableName, GetDescription(), GetUnits(), GetType(),

???????????????????? ?? IsWriteable(), GetExpress(), GetDeviceAddress(), GetRegisterAddress(), GetDataLen(), GetBitsStartIndex(), GetBitsCount(), GetName() );

??????

?????? VERIFY(_conn.ExecuteNonQuery(sql));

posted on 2007-01-26 09:53 天下無雙 閱讀(2054) 評論(2)  編輯 收藏 引用 所屬分類: C/C++

FeedBack:
# re: ADO數據庫操作的C++封裝
2007-01-31 15:07 | eXile
前幾日看到有位大哥發布的 ADO 數據庫的封裝,到處是模板,不免有些頭暈....

呵呵,是說的我嗎?關于模板,我的看法是,在做庫的封裝時,可以無所顧忌地使用,以作最大優化,在做業務邏輯時,盡量不要使用,以便于維護。

我做的封裝,如下所示,表中有哪些字段,什么類型,一目了然,在此引入模板我覺得是必要的。
struct TUser
{
AdoCol<int> m_id;
AdoCol<std::string> m_name;
AdoCol<int> m_type;
AdoCol<AdoBLOB> m_blob;
};


  回復  更多評論
  
# re: ADO數據庫操作的C++封裝
2007-01-31 15:19 | 天下無雙
我明白你的意思,如果程序員對模板不是很熟悉,如像這樣的代碼:
template <class RowT>
void Bind(RowT& r)
{
MY_STATIC_ASSERT(field_count == RowT::size);

r.BindField(fid, "id", &m_id);
r.BindField(fname, "name", &m_name);
r.BindField(ftype, "type", &m_type);
}
要上手還是要一段時間 。  回復  更多評論
  

常用鏈接

留言簿(15)

隨筆分類

隨筆檔案

相冊

我的其它領域Blog

搜索

  •  

積分與排名

  • 積分 - 207982
  • 排名 - 129

最新評論

閱讀排行榜

評論排行榜

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            亚洲精品在线免费观看视频| 在线看片成人| 欧美日本一区| 在线精品福利| 欧美一区激情| 99精品欧美一区二区三区| 欧美va亚洲va日韩∨a综合色| 国产日韩精品一区二区浪潮av| 这里只有精品丝袜| 亚洲精品乱码| 久久综合伊人77777| 国产乱码精品一区二区三区五月婷| 一区二区三区精密机械公司| 亚洲国内自拍| 欧美日韩免费看| 亚洲综合成人婷婷小说| 日韩亚洲在线观看| 欧美性感一类影片在线播放 | 亚洲国产一区二区三区在线播| 久久婷婷av| 亚洲人久久久| 日韩视频免费| 国产伦精品一区二区三区视频黑人 | 国产一区白浆| 亚洲永久精品国产| 国产精品久久久91| 国产亚洲成精品久久| 国产日韩在线视频| 亚洲激情视频在线播放| 日韩一区二区福利| 久久黄色小说| 亚洲国产激情| 一区二区激情视频| 久久久久久久波多野高潮日日| 欧美伦理91| 韩国av一区二区三区四区| 一二三区精品福利视频| 久久久久久久一区二区| 99视频一区| 久久亚洲高清| 国产主播喷水一区二区| 亚洲综合电影| 999在线观看精品免费不卡网站| 亚洲免费视频中文字幕| 欧美电影免费观看高清完整版| 国产精品综合不卡av| 99热免费精品在线观看| 欧美成年人视频网站| 午夜视黄欧洲亚洲| 国产精品美女www爽爽爽| 亚洲精品四区| 欧美寡妇偷汉性猛交| 久久成人av少妇免费| 国产精品一区二区久久久| 亚洲精选一区| 欧美第十八页| 久久综合伊人77777蜜臀| 国产一区二区欧美日韩| 亚洲女人天堂av| 日韩一级在线| 欧美另类专区| 国产精品99久久久久久久vr| 亚洲另类一区二区| 欧美精品国产精品日韩精品| 亚洲国产视频一区二区| 蜜桃av噜噜一区| 久久嫩草精品久久久久| 一区二区三区在线高清| 西西裸体人体做爰大胆久久久| 欧美在线播放| 欧美性猛片xxxx免费看久爱| 在线视频日本亚洲性| 亚洲精品免费网站| 欧美精品免费视频| 一区二区三区鲁丝不卡| 亚洲免费大片| 国产精品对白刺激久久久| 亚洲欧美日韩国产成人| 亚洲欧美日韩视频二区| 国产亚洲va综合人人澡精品| 久久亚洲春色中文字幕| 久久天天躁夜夜躁狠狠躁2022| 精品动漫3d一区二区三区| 裸体一区二区三区| 欧美成人免费在线| 日韩视频在线播放| 在线亚洲欧美| 激情五月***国产精品| 亚洲丰满少妇videoshd| 久久亚洲电影| 亚洲精品少妇网址| 亚洲一区在线播放| 影音先锋亚洲视频| 99精品99| 激情视频一区二区| 亚洲美女色禁图| 国产精品国产三级国产aⅴ无密码| 久久99在线观看| 老司机免费视频久久| 亚洲一区二区三区视频| 久久国产精品久久久| 一本色道久久综合亚洲精品不卡| 亚洲一区二区黄| 亚洲成人在线视频播放| 亚洲毛片在线观看| 激情综合久久| 中日韩视频在线观看| 亚洲成人直播| 亚洲欧美精品在线| 99re8这里有精品热视频免费 | 亚洲精品国产精品乱码不99按摩 | 亚洲裸体视频| 欧美一区亚洲一区| 亚洲一区二区精品在线观看| 久久久久国产成人精品亚洲午夜| 一区二区三区精品视频在线观看| 欧美在线亚洲| 亚洲免费人成在线视频观看| 久久影音先锋| 久久久久久久久久码影片| 欧美日韩精品在线观看| 美国十次成人| 国产女人18毛片水18精品| 亚洲精美视频| 精品成人在线| 欧美一区二区三区在线观看视频| 99视频一区| 欧美激情精品久久久久久免费印度 | aaa亚洲精品一二三区| 国产亚洲在线观看| 亚洲天堂久久| 亚洲深夜福利视频| 欧美激情第一页xxx| 久久综合网络一区二区| 国产一区激情| 欧美一级视频精品观看| 欧美伊久线香蕉线新在线| 国产精品国产三级国产aⅴ入口| 亚洲美女色禁图| 在线综合欧美| 欧美日韩国产综合新一区| 亚洲精品乱码久久久久久| 亚洲国产专区校园欧美| 久久久久国产免费免费| 久久在线精品| 亚洲激情视频网| 欧美黄色片免费观看| 亚洲日韩视频| 一本色道久久88精品综合| 欧美激情亚洲| 国产精品99久久99久久久二8 | 久久精品成人一区二区三区| 欧美激情综合五月色丁香小说 | 亚洲日韩中文字幕在线播放| 最新中文字幕亚洲| 久久午夜色播影院免费高清| 久久精品视频亚洲| 国产一区二区欧美| 久久躁日日躁aaaaxxxx| 亚洲三级色网| 亚洲男女自偷自拍| 国产亚洲欧美日韩精品| 美女日韩欧美| 99精品视频免费观看视频| 欧美一区1区三区3区公司| 国产在线视频欧美一区二区三区| 久久久久久久尹人综合网亚洲| 免播放器亚洲一区| 99精品国产一区二区青青牛奶| 国产精品高清免费在线观看| 欧美亚洲综合另类| 亚洲国产91色在线| 亚洲自拍偷拍网址| 精品99一区二区| 欧美日韩一级片在线观看| 亚洲视频在线观看三级| 久久视频这里只有精品| 日韩一级片网址| 国产亚洲欧美日韩精品| 欧美日韩国产123| 久久久水蜜桃av免费网站| 一本色道久久综合精品竹菊| 欧美激情91| 欧美日韩国产综合新一区| 亚洲欧美精品在线观看| 欧美国产第一页| 午夜精彩国产免费不卡不顿大片| 伊人成人网在线看| 欧美午夜影院| 免费中文字幕日韩欧美| 午夜欧美不卡精品aaaaa| 亚洲精品日韩激情在线电影| 久久久久久久精| 亚洲欧美在线高清| 日韩视频在线播放| 一区在线免费| 国产一区二区视频在线观看| 欧美电影在线播放| 久久精品免费电影| 亚洲国产日韩欧美在线图片|