分享
 
 
 

Ado 实现C++对象的存取

王朝vc·作者佚名  2006-01-17
窄屏简体版  字體: |||超大  

Ado 实现C++对象的存取

作者:江上飞鸟

下载源代码

其实我最讨厌写东西了,最近忙死了,呵呵,前一段时间在做一个图形程序时,需要把C++对象保存到数据库里,刚开始真让我头疼啊,琢磨了一个下午,终于给做出来了,废话不说了,还是把自己的一些体会与各位同任一起分享!!!!

一、新建一个继承于 CObject 的子类 CLine;

头文件:Line.h

class CLine : public CObject?

{

private :

LOGPEN m_logPen; //画笔

COLORREF m_crBackColor;

CArray<CPoint, CPoint &> m_PointArray; //标记类对应框

public:

int GetSize();

CPoint GetPoint(int pos);

void DrawLine(CDC *pDC,CPoint pt1,CPoint pt2,CRect rc);

void DrawBackGround(CDC *pDC,CRect rect);

void DrawPoint(CDC *pDC, CRect rect);

void SetWidth(int iWidth);

COLORREF GetColor();

void SetColor(COLORREF color);

COLORREF GetBkColor();

void SetBkColor(COLORREF color);

void AddPoint(CPoint point);

void Clear();

CLine();

virtual ~CLine();

virtual void Serialize(CArchive &ar);

CLine& operator=(CLine &src);

DECLARE_SERIAL(CLine)??

};

实现文件:Line.cpp

//////////////////////////////////////////////////////////////////////

// Line.cpp: implementation of the CLine class.

//

//////////////////////////////////////////////////////////////////////

#include "stdafx.h"

#include "TestAdo.h"

#include "Line.h"

#ifdef _DEBUG

#undef THIS_FILE

static char THIS_FILE[]=__FILE__;

#define new DEBUG_NEW

#endif

IMPLEMENT_SERIAL(CLine,CObject,1)

CLine::CLine()

{

Clear();

}

CLine::~CLine()

{

}

//重写 =

CLine& CLine::operator=(CLine &src)

{

if(this!=&src)

{

m_logPen = src.m_logPen;

m_crBackColor = src.m_crBackColor;

}

return *this;?

}

//串行化操作

void CLine::Serialize(CArchive &ar)

{

if (ar.IsStoring())

{

ar << DWORD(m_crBackColor);

ar.Write(&m_logPen, sizeof(LOGPEN));

}

else

{

DWORD dw;

ar >> dw; m_crBackColor = COLORREF(dw);

ar.Read(&m_logPen, sizeof(LOGPEN));

}

m_PointArray.Serialize(ar);

}

void CLine::Clear()

{

m_crBackColor = RGB(255,255,255);

m_logPen.lopnStyle = PS_SOLID;

m_logPen.lopnWidth.x = 1;

m_logPen.lopnWidth.y = 1;

m_logPen.lopnColor = RGB(0, 0, 0);

m_PointArray.RemoveAll();

}

void CLine::AddPoint(CPoint point)

{

m_PointArray.Add(point);

}

void CLine::SetColor(COLORREF color)

{

m_logPen.lopnColor = color;

}

COLORREF CLine::GetColor()

{

return m_logPen.lopnColor;

}

void CLine::SetBkColor(COLORREF color)

{

m_crBackColor = color;

}

COLORREF CLine::GetBkColor()

{

return m_crBackColor;

}

void CLine::SetWidth(int iWidth)

{

m_logPen.lopnWidth.x = iWidth;

m_logPen.lopnWidth.y = iWidth;

}

//绘线条

void CLine::DrawPoint(CDC *pDC, CRect rect)

{

int len = m_PointArray.GetSize();

if (len <=0) return;

CPen pen;

pen.CreatePenIndirect(&m_logPen);

CPen *pOldPen = pDC->SelectObject(&pen);

CPoint pt = m_PointArray.GetAt(0);

pDC->MoveTo(pt);

for (int i=1; i< len; i++)

{

pt = m_PointArray.GetAt(i);

pDC->LineTo(pt);

}

pDC->SelectObject(pOldPen);

pOldPen = NULL;

pen.DeleteObject();

}

void CLine::DrawBackGround(CDC *pDC, CRect rect)

{

CBrush brushCtl;

brushCtl.CreateSolidBrush(GetBkColor());

pDC->Rectangle(rect);

pDC->FillRect(rect,&brushCtl) ;

brushCtl.DeleteObject();

}

void CLine::DrawLine(CDC *pDC,CPoint pt1, CPoint pt2, CRect rc)

{

CPen pen;

pen.CreatePenIndirect(&m_logPen);

CPen *pOldPen = pDC->SelectObject(&pen);

pDC->MoveTo(pt1);

pDC->LineTo(pt2);

pDC->SelectObject(pOldPen);

pOldPen = NULL;

pen.DeleteObject();

}

CPoint CLine::GetPoint(int pos)

{

if (pos>=0 && pos<m_PointArray.GetSize())?

{

return m_PointArray.GetAt(pos);

}

return CPoint(0,0);

}

int CLine::GetSize()

{

return m_PointArray.GetSize();

}

二、用Ado接口打开数据库

BOOL CTestAdoDlg::OpenDb(CString filename)

{

HRESULT hr=S_OK;

hr=m_pCon.CreateInstance("ADODB.Connection");

if (hr!=S_OK)

{

return FALSE;

}

try

{

_bstr_t sCon;

sCon=_bstr_t(filename); //路径名

sCon="Provider=Microsoft.Jet.OLEDB.4.0;Data Source="+sCon;

hr=m_pCon->Open(sCon,"","",adModeUnknown);

if (hr!=S_OK)

{

return FALSE;

}

///////////////////////

hr=m_pSet.CreateInstance("ADODB.Recordset");

if (hr!=S_OK)

{

return FALSE;

}

m_pSet->CursorLocation=adUseClient;

hr=m_pSet->Open("SELECT * FROM object_table",_variant_t((IDispatch*)m_pCon,TRUE),

adOpenStatic,adLockOptimistic,adCmdText);

if (hr!=S_OK)

{

return FALSE;

}

return TRUE;

///////////////////////

}

catch(_com_error &e)

{

CString errorMessage;

errorMessage.Format("连接数据库失败!错误信息:%s",e.ErrorMessage());

return FALSE;

}

return FALSE;

}

(注意:在StdAfx.h中要加入:#import "C:\Program Files\Common Files\SYSTEM\ADO\msado15.dll" no_namespace rename("EOF","adoEOF")

来引入ado库,还有在 BOOL CTestAdoApp::InitInstance() 加入 AfxOleInit();///初始化COM库)

三、CLine对象的保存

void CTestAdoDlg::OnButtonSave()

{

//m_List

if (!m_bState) return;

UpdateData();

try

{

m_pSet->AddNew();

m_pSet->PutCollect("name", _variant_t(m_sName));

//保存图形对象

CMemFile memFile;

CArchive ar(&memFile, CArchive::store);

m_Line.Serialize(ar);

ar.Close();

DWORD dwSize = memFile.GetLength();

LPBYTE lpInfo = memFile.Detach();

VARIANT varBLOB;

SAFEARRAY *psa;

SAFEARRAYBOUND rgsabound[1];

rgsabound[0].lLbound = 0;

rgsabound[0].cElements = dwSize;

psa = SafeArrayCreate(VT_UI1, 1, rgsabound);

for (long i = 0; i < (long)dwSize; i++)

{

SafeArrayPutElement (psa, &i, lpInfo++);

}

varBLOB.vt = VT_ARRAY | VT_UI1;

varBLOB.parray = psa;

m_pSet->GetFields()->GetItem("object")->AppendChunk(varBLOB);

m_pSet->Update();

m_List.AddString(m_sName);

}

catch(_com_error &e)

{

CString str=(char *)e.Description();

MessageBox(str+"\r保存数据库出问题!","提示",MB_OK|MB_ICONWARNING);

return ;

}

}

四、CLine对象的读取

void CTestAdoDlg::OnSelchangeListData()

{

int iPos = m_List.GetCurSel();

if (iPos<0) return ;

m_pSet->MoveFirst();

int i=0;

while (i< iPos)

{

m_pSet->MoveNext();

i++;

}

long lDataSize = m_pSet->GetFields()->GetItem(_variant_t("object"))->ActualSize;

if(lDataSize <= 0) return;

_variant_t varBLOB;

VariantInit (&varBLOB);

varBLOB = m_pSet->GetFields()->GetItem(_variant_t("object"))->GetChunk(lDataSize);

if(varBLOB.vt == (VT_ARRAY | VT_UI1))

{

BYTE *pBuf = new BYTE[lDataSize + 1];

if(pBuf)

{

SafeArrayAccessData(varBLOB.parray,(void **)&pBuf);

SafeArrayUnaccessData (varBLOB.parray);

CMemFile memfile;

memfile.Attach(pBuf,lDataSize);

memfile.SeekToBegin();

CArchive ar(&memfile, CArchive::load);

m_Line.Serialize(ar);

ar.Close();

memfile.Detach();

CRect rc = GetRect(IDC_STATIC_RECT);

InvalidateRect(rc);

}

}

VariantClear (&varBLOB);

}

五、结束语

以上充分利用了串行化来实现c++对象保存到数据库,对以上方法稍做扩展对图象的保存到数据库,甚至多个图象文件保存到数据库和文件。

(很抱歉:我实在不想写文字说明了,如果有什么问题不清楚,跟我联系好了!!哎)

QQ:36201365

e-mail:ldh5118@sohu.com

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
2023年上半年GDP全球前十五强
 百态   2023-10-24
美众议院议长启动对拜登的弹劾调查
 百态   2023-09-13
上海、济南、武汉等多地出现不明坠落物
 探索   2023-09-06
印度或要将国名改为“巴拉特”
 百态   2023-09-06
男子为女友送行,买票不登机被捕
 百态   2023-08-20
手机地震预警功能怎么开?
 干货   2023-08-06
女子4年卖2套房花700多万做美容:不但没变美脸,面部还出现变形
 百态   2023-08-04
住户一楼被水淹 还冲来8头猪
 百态   2023-07-31
女子体内爬出大量瓜子状活虫
 百态   2023-07-25
地球连续35年收到神秘规律性信号,网友:不要回答!
 探索   2023-07-21
全球镓价格本周大涨27%
 探索   2023-07-09
钱都流向了那些不缺钱的人,苦都留给了能吃苦的人
 探索   2023-07-02
倩女手游刀客魅者强控制(强混乱强眩晕强睡眠)和对应控制抗性的关系
 百态   2020-08-20
美国5月9日最新疫情:美国确诊人数突破131万
 百态   2020-05-09
荷兰政府宣布将集体辞职
 干货   2020-04-30
倩女幽魂手游师徒任务情义春秋猜成语答案逍遥观:鹏程万里
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案神机营:射石饮羽
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案昆仑山:拔刀相助
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案天工阁:鬼斧神工
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案丝路古道:单枪匹马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:与虎谋皮
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:李代桃僵
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:指鹿为马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:小鸟依人
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:千金买邻
 干货   2019-11-12
 
推荐阅读
 
 
 
>>返回首頁<<
 
靜靜地坐在廢墟上,四周的荒凉一望無際,忽然覺得,淒涼也很美
© 2005- 王朝網路 版權所有