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

posts - 45,  comments - 232,  trackbacks - 0

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

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

特點(diǎn):

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

l???????? 使用標(biāo)準(zhǔn) C++ 數(shù)據(jù)類型,屏蔽了 com 數(shù)據(jù)類型和異常,減少了復(fù)雜性。

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

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

異常的處理請參看: http://www.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 .讀取數(shù)據(jù)的例子:

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 .刪除數(shù)據(jù)的例子:

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 .更新數(shù)據(jù)的例子:

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 天下無雙 閱讀(2055) 評論(2)  編輯 收藏 引用 所屬分類: C/C++

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

呵呵,是說的我嗎?關(guān)于模板,我的看法是,在做庫的封裝時,可以無所顧忌地使用,以作最大優(yōu)化,在做業(yè)務(wù)邏輯時,盡量不要使用,以便于維護(hù)。

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


  回復(fù)  更多評論
  
# re: ADO數(shù)據(jù)庫操作的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);
}
要上手還是要一段時間 。  回復(fù)  更多評論
  

常用鏈接

留言簿(15)

隨筆分類

隨筆檔案

相冊

我的其它領(lǐng)域Blog

搜索

  •  

積分與排名

  • 積分 - 208093
  • 排名 - 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>
            亚洲欧美中文在线视频| 极品av少妇一区二区| 你懂的网址国产 欧美| 国产精品嫩草99a| 亚洲精品乱码久久久久久日本蜜臀| 国产欧美欧美| 亚洲性感激情| 亚洲小视频在线观看| 免费日韩av片| 免费欧美视频| 一区二区在线看| 欧美专区一区二区三区| 午夜精品久久久久久久| 欧美视频成人| 日韩视频在线观看国产| 99这里有精品| 欧美精品一区二区精品网| 欧美wwwwww| 亚洲动漫精品| 免费成人性网站| 欧美激情五月| 亚洲精品免费观看| 欧美激情一区二区三区不卡| 欧美成人资源| 亚洲精品视频在线观看网站| 欧美99久久| 亚洲国产一区在线观看| 日韩视频在线免费| 欧美日韩一区二区三区四区在线观看 | 久久www成人_看片免费不卡| 欧美在线观看一区二区| 国产日韩欧美电影在线观看| 午夜视频精品| 快播亚洲色图| 亚洲第一精品夜夜躁人人躁| 老司机一区二区| 亚洲日产国产精品| 亚洲婷婷综合色高清在线| 欧美午夜a级限制福利片| 亚洲视频一区二区| 欧美一级艳片视频免费观看| 国产日韩欧美夫妻视频在线观看| 香蕉久久国产| 欧美成va人片在线观看| 妖精视频成人观看www| 国产精品国产亚洲精品看不卡15| 亚洲视屏在线播放| 久久午夜电影| 亚洲精品一区二| 国产精品久久久久一区二区三区| 午夜欧美电影在线观看| 欧美成人午夜| 亚洲一区二区免费在线| 国产亚洲欧美一区二区| 美日韩精品免费观看视频| 洋洋av久久久久久久一区| 久久精品国产亚洲5555| 亚洲人成欧美中文字幕| 国产精品久久一卡二卡| 久久久久网址| 中文精品视频一区二区在线观看| 久久免费99精品久久久久久| 亚洲精品视频免费观看| 国产女主播一区二区| 免费观看亚洲视频大全| 亚洲免费综合| 亚洲国产欧美在线人成| 久久se精品一区精品二区| 亚洲精品在线视频观看| 国产午夜精品久久久久久久| 欧美黄色一级视频| 久久国产精品网站| 中文亚洲字幕| 亚洲国产精品va在线看黑人| 亚洲欧美综合国产精品一区| 亚洲国产成人91精品| 国产精品久久久99| 你懂的亚洲视频| 欧美一区二区三区四区在线| 日韩一区二区久久| 欧美激情中文不卡| 老司机aⅴ在线精品导航| 小处雏高清一区二区三区| 99热免费精品在线观看| 伊人久久成人| 国产午夜精品美女毛片视频| 欧美午夜精品久久久久久人妖| 久久综合久久美利坚合众国| 欧美亚洲综合在线| 亚洲午夜久久久久久久久电影院| 亚洲欧洲一区| 欧美福利精品| 免费观看亚洲视频大全| 久久久国产成人精品| 欧美中文在线观看| 亚洲欧洲av一区二区| 亚洲一区欧美二区| 亚洲午夜精品久久久久久浪潮| 亚洲精品国产视频| 最新国产乱人伦偷精品免费网站| 黄网站色欧美视频| 一色屋精品视频在线观看网站| 国产一区亚洲| 国内精品美女av在线播放| 国产一区亚洲一区| 国内精品伊人久久久久av影院| 国产日韩欧美精品综合| 国产美女一区二区| 国产精品自拍小视频| 国产精品午夜在线| 国产偷自视频区视频一区二区| 国产欧美大片| 国产日韩在线视频| 国产一区二区三区久久久久久久久| 国产精品一二| 国产亚洲精品一区二555| 国产一区在线观看视频| 精品av久久久久电影| 精品电影一区| 亚洲人成毛片在线播放| 夜夜嗨av色一区二区不卡| 亚洲视频精品| 欧美一区二区三区四区在线| 欧美一级视频精品观看| 久久久久久伊人| 欧美风情在线| av不卡免费看| 亚洲欧美国产三级| 久久亚洲欧美| 欧美日韩 国产精品| 国产精品入口福利| 精品电影在线观看| 一本一本大道香蕉久在线精品| 亚洲主播在线观看| 久久天堂国产精品| 最新日韩欧美| 亚洲欧美日韩爽爽影院| 久久综合色8888| 欧美日韩精品一二三区| 国产视频在线观看一区| 亚洲精品日韩一| 欧美一二三区在线观看| 欧美岛国在线观看| 亚洲私拍自拍| 女人天堂亚洲aⅴ在线观看| 欧美日韩一区二区三区四区在线观看 | 欧美精品激情在线| 国产欧美91| 99re8这里有精品热视频免费 | 亚洲裸体在线观看| 午夜一区二区三区不卡视频| 美女脱光内衣内裤视频久久网站| 欧美天堂在线观看| 国内精品久久久久久久影视蜜臀 | 亚洲国产成人精品女人久久久| 一本色道久久综合一区 | 亚洲欧美日韩一区二区三区在线观看| 久久精品日产第一区二区| 亚洲国产一区二区三区在线播 | 欧美国产免费| 国内精品久久久久久影视8| 一区二区欧美视频| 美国十次了思思久久精品导航| 99国内精品| 欧美成人午夜影院| 国产色综合天天综合网| 一区二区三区视频在线播放| 麻豆91精品| 欧美一区二区私人影院日本 | 亚洲国产成人91精品| 亚洲欧美日韩国产| 欧美三级中文字幕在线观看| 在线欧美日韩| 久久久噜噜噜久噜久久| 在线视频精品| 欧美日韩专区在线| 日韩视频一区二区在线观看 | 国产精品嫩草99av在线| 日韩一区二区福利| 欧美黑人多人双交| 久久久久在线观看| 国内精品99| 久久久www| 欧美一区二区三区在线播放| 国产精品久久久久av| 一区二区三区日韩精品| 亚洲黄色免费| 欧美大学生性色视频| 亚洲欧洲三级电影| 亚洲大胆人体视频| 玖玖综合伊人| 亚洲韩国日本中文字幕| 欧美成人精品在线视频| 久久艳片www.17c.com| 1769国产精品| 欧美激情第8页| 欧美精品免费在线观看| 一区二区高清| 在线综合欧美| 国产视频精品va久久久久久|