发布网友 发布时间:2022-04-14 21:00
共3个回答
懂视网 时间:2022-04-15 01:21
这个问题由来已久,由于不是非常影响项目进度,所以一直没有重视。最近闲来,又遇到此问题,决心仔细研究一番。上网搜了半天,整整半天,没有发现比较通俗易懂的文章,没办法,看看微软的资料,自己动手吧,把这个解决过程记录下来,以供大伙参考。 问题描述
这个问题由来已久,由于不是非常影响项目进度,所以一直没有重视。最近闲来,又遇到此问题,决心仔细研究一番。上网搜了半天,整整半天,没有发现比较通俗易懂的文章,没办法,看看微软的资料,自己动手吧,把这个解决过程记录下来,以供大伙参考。
问题描述:
ADODB::_ConnectionPtr m_pConnection1;
ADODB::_ConnectionPtr m_pConnection2;
ADODB::_RecordsetPtr m_pRecordset1;
ADODB::_RecordsetPtr m_pRecordset2;
初始化过程略去。。。。。。
当使用
m_pRecordset1->Open(pSql ,m_pConnection1.GetInterfacePtr(),ADODB::adOpenDynamic,ADODB::adLockOptimistic,ADODB::adCmdText);
进行INSERT、UPDATE、Delete 操作后,立即用m_pConnection2 和m_pRecordset2 对更新的表进行查询,发现刚刚m_pConnection1添加的数据根本没法查出来,修改的数据也没更新,删除记录也依旧乖乖的呆在数据库里。
这种情况只有在使用两个或两个以上连接进行数据库操作时才会出现,只有一个连接是不会有这个问题的。但很多时候我们不得不使用多个连接同时操作数据,所以问题必须解决。
解决办法:
在执行增删改的 SQL语句时使用“事务Transaction” , 使用JRO引擎强制刷新 查询连接的 数据缓存。
#import "c:program filescommon filessystemadomsjro.dll" //开始事务 m_pConnection->BeginTrans(); //inster update delete操作 代码省略 //提交 m_pConnection->CommitTrans();//在查询前刷新缓存 刷新过后进行查询操作,数据就不会有延迟现象了。 BOOL CDBOperate::RefreshData() { JRO::IJetEnginePtr jet(__uuidof(JRO::JetEngine)); jet->RefreshCache(m_pConnection); return TRUE; }
通过上述代码,实现ACCESS多连接数据同步。参考文章
http://support.microsoft.com/kb/200300
热心网友 时间:2022-04-14 22:29
你一定是用的DATA控件吧?那个不支持97以上的版本。你可以改成ADO控件。热心网友 时间:2022-04-14 23:47
data控件不支持97以上的数据库
你还是换一个控件好了
比如说Adodc控件
不过,用的好好的,为什么换呢