导航:首页 > 编程语言 > mfcado数据库编程

mfcado数据库编程

发布时间:2023-06-17 12:23:59

㈠ 请教:MFC多线程数据库编程ado,数据库访问冲突。

用多线程同步技术,即一个线程将要取得数据区锁定,另一个线程此时不能存取此块的数据。
看看多线程同步的书。

例如:
void CCalibPage1::OnTimer(UINT nIDEvent)
{
// TODO: Add your message handler code here and/or call default
UpdateData();

m_nCounter++;

double r;

CSingleLock sLock(&(gpMainFrm->m_mutex));
sLock.Lock();//此处锁定
double v = gSpindleRevolution;
sLock.Unlock();//存取后释放。

if(m_bCalibStart)
{
r = m_CalibValue/v;

m_szTestValue0.Format("%f",v);
// m_szTestValue.Format("%f", (v * r));
m_szRatio.Format("%f", r);//
UpdateData(false);
}
else if(m_bVerify)
{
m_szTestValue.Format("%f",v*gcConfig.calib[PCL833_CHANNEL].ratio);
UpdateData(false);
}

if(m_nCounter > 30)
{
KillTimer(11);
m_bCalibStart = false;
m_bVerify = false;
MessageBox(_T("标定完成!"),_T("CNCTest"));
UpdateButtonStatus();
}

CPropertyPage::OnTimer(nIDEvent);
}

参见:
http://ke..com/view/2808915.htm

㈡ 如何进行MFC数据库编程

MFC数据库编程包含如下:
首先,你要选择使用什么方式连接数据库,有ODBC,ADO等,
其他,就是sql语句操作数据库了,对后是怎么存储操作数据。

㈢ 数据库编程用ADO好,还是ODBC好

这要看具体情况,如果对数据库的底层访问很看重,则用ODBC,如果只是需要一个数据库的接口,而具体细节不是很重要的话,则用ADO。大多数情况下,使用ADO。
ODBC:
直接使用ODBC API编写应用程序需要编制大量代码,Visual C++提供了MFC ODBC类,其中封装了ODBC API,因此,使用MFC来创建ODBC的应用程序非常简便。主要的MFC ODBC类如下所示。
CDatabase类:一个CDatabase对象表示一个到数据源的连接,通过它可以操作数据源。应用程序可使用多个CDatabase对象,构造一个对象并调用OpenEx()成员函数打开一个连接。接着构造CRecordSet对象以操作连接的数据源,并向 CDatabase对象传递记录集构造程序指针。完成后用Close()成员函数销毁CDatabase对象。一般情况下并不需要直接使用CDatabase对象,因为CRecordSet对象可以实现大多数的功能。但是在进行事务处理时,CDatabase就起到关键作用。事务(Transaction)指的是将一系列对数据源的更新放在一起,同时提交或一个也不提交,为的是确保多用户对数据源同时操作时的数据正确性。
CRecordSet类:一个CRecordSet对象代表一个从数据源选择的一组记录的集合——记录集。记录集有两种形式,snapshot和dynaset,前者表示数据的静态试图,后者表示记录集和其他用户对数据库的更新保持同步。通过CRecordSet对象,用户可以对数据库中的记录进行各种操作。
CRecordView类:CRecordView对象是在空间中显示数据库记录的视图。这种视图是一种直接连到CRecordSet对象的格式视图,它从一个对话框模板资源创建,并将CRecordSet对象的字段显示在对话框模板的控件中。对象利用DDX和RFX机制,使格式上的控件和记录集的字段之间数据移动自动化,也就是说,用户不用编写一行代码就可以实现简单的数据库记录查看操作。
CDBException:由Cexception类派生,以3个继承的成员变量反映对数据库操作时的异常。
m_nRetCode:以ODBC返回代码(SQL_RETURN)的形式表明造成异常的原因。
m_strError:字符串,描述造成抛出异常的错误原因。
m_strStateNativeOrigin:字符串,用以描述以ODBC错误代码表示的异常错误。
MFC数据库类成员函数都能抛出CDBException类型异常,所以在代码对数据库进行操作后监测异常是正确的做法。
ADO:
ADO技术是基于OLE DB的访问接口,它继承了OLE DB技术的优点,并且,ADO对OLE DB的接口作了封装,定义了ADO对象,使程序开发得到简化。ADO技术属于数据库访问的高层接口。ADO基于COM,提供编程语言可利用的对象,除了面向VC++,还提供面向其他各种开发工具的应用,如VB、VJ等。ADO在服务器应用方面非常有效,特别是对于动态服务器页面(ASP,Active Server Page)的支持。
ADO对象结构类似于OLE DB,但并不依靠对象层次。大多数情况下,用户只需要创建并使用需要处理的对象。ADO 最主要的优点是易于使用、速度快、内存支出少和磁盘遗迹小。ADO 在关键的应用方案中使用最少的网络流量,并且在前端和数据源之间使用最少的层数,所有这些都是为了提供轻量、高性能的接口。下面的对象类组成了ADO接口。
Connection:用于表示与数据库的连接,以及处理一些命令和事务。
Command:用于处理传送给数据源的命令。
Recordset:用于处理数据的表格集,包括获取和修改数据。
Field:用于表示记录集中的列信息,包括列值和其他信息。
Parameter:在传送给数据源的命令之间传递数据。
Property:用于操作在ADO中使用的其他对象的详细属性。
Error:用于获得可能发生的详细错误信息。

㈣ MFC编程用ADO连接数据库,执行查询语句后,如果返回0条记录有什么标志吗

if ((m_pRecordset->BOF)||(m_pRecordset->adoEOF))
{
// AfxMessageBox("没有记录");
return;
}

㈤ ADO+MFC数据库编程时,修改记录和插入记录的代码各条语句的意思

1. // 这个Open函数的第二个参数为什么和
答:你这里不都是一样的吗?

2.m_pRecordset->AddNew(); //为什么要这一句呢?是提示程序要添加新的记录了吗?
答:不是提示,这个是让表添加一个新行。

3.m_pRecordset->PutCollect("name", _variant_t(m_Name)); // 这里的PutCollect函数的作用是什么?
答:put 放入的意思。这里是把m_Name值放入表中的name字段中。

4.m_pRecordset->MoveFirst(); // 这一句和下面的Move有什么作用??
答:m_pRecordset表示记录集。MoveFirst移动指针到记录集中的第一行。
Move(cursel);移动到cursel)行。

5.m_pRecordset->PutCollect("age", atol(m_Age)); //为什么这里的强制转换是用atol,而不是用上面的_variant_t ???
答:因为在表中声明的age是long类型。放入数据时类型要一致。

阅读全文

与mfcado数据库编程相关的资料

热点内容
java带参数的线程 浏览:911
为什么安卓车载中控屏看起来很差 浏览:464
吃鸡怎么解压最快 浏览:966
linux网络编程基础 浏览:217
产研是程序员吗 浏览:592
程序员的法律 浏览:967
编程第四关用冰雪火焰闪现通关 浏览:754
批处理当前文件夹参数 浏览:183
鸿蒙安卓如何下载 浏览:902
开3389命令 浏览:540
程序员大都单纯吗 浏览:913
APP如何实现下载功能 浏览:214
通达信源码怎样放到桌面 浏览:643
程序员的脑袋会秃吗 浏览:453
为什么eve登录启动不进去服务器 浏览:270
微信招生app哪个好用 浏览:233
宝可梦剑盾启动文件在哪个文件夹 浏览:765
压缩机比容 浏览:117
python自动化测试面试 浏览:949
买便宜点的鞋子去哪个app买 浏览:890