找回密码
 立即注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

查看: 836|回复: 14

[ARX程序]:ARX中查询Access数据库

[复制链接]
发表于 2003-3-29 11:45:20 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。

您需要 登录 才可以下载或查看,没有账号?立即注册

×
在ARX中查询Access数据库,如何处理?在VC++中编译成功但到Cad中运行时,出现错误信息为"Unhanlde Access",希望能够解答。非常感谢!!
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
发表于 2003-3-29 13:24:27 | 显示全部楼层
我对这个也想知道。。。有没有完整的源程序参考一下呢?
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

发表于 2003-3-29 14:24:16 | 显示全部楼层
读写Access数据库,可以参观周景润的用ADO读写Access,好像一般的vc网站都有.
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

发表于 2003-4-1 16:41:06 | 显示全部楼层
你使用什么数据库引擎,是ADO吗?我刚做了一个可以访问Oracle SQL Access等数据源的程序,用来保存自定义实体对象的属性。其实知道了ADO的使用方法就可以直接在ARX中访问Access数据库了。
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

发表于 2003-4-3 22:04:20 | 显示全部楼层
大虾们能否做一个简单点的实例呀?
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

发表于 2003-4-4 19:19:48 | 显示全部楼层
我也卡在这个问题上,哪位大虾能帮忙一下,给个实例!
谢谢!!!
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

发表于 2003-4-4 23:37:39 | 显示全部楼层
这个问题对我来说也是一个难题。请高手把相关的源代码提供出来给大家参考吧。
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

发表于 2003-4-6 13:38:20 | 显示全部楼层
周景润的用ADO读写Access
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

发表于 2003-4-7 19:40:52 | 显示全部楼层
这篇文章我已有了,我参考之后在我自己的程序加入了数据库模块,编译通过,运行出错。
出错信息:不支持此接口!
我到现在还没找出原因,各位高手能不能提供在ARX里连接数据库的源码?!
谢谢!!!
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

发表于 2003-4-10 15:40:41 | 显示全部楼层
是呀是呀 最好有代码大家学习一下
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

发表于 2003-4-21 16:15:31 | 显示全部楼层
是呀,我也卡在这里了
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

发表于 2003-4-26 19:29:12 | 显示全部楼层
.h

#ifndef _ADOVISIT_H
#define _ADOVISIT_H

#define INITGUID
#import "C:\Program Files\Common Files\SYSTEM\ADO\msado15.dll"\
        no_namespace rename("EOF", "EndOfFile"),\
        no_namespace rename("LockTypeEnum", "LockTypeEnumA"),\
        no_namespace rename("DataTypeEnum", "DataTypeEnumA"),\
        no_namespace rename("FieldAttributeEnum", "FieldAttributeEnumA"),\
        no_namespace rename("EditModeEnum", "EditModeEnumA"),\
        no_namespace rename("RecordStatusEnum", "RecordStatusEnumA"),\
        no_namespace rename("ParameterDirectionEnum", "ParameterDirectionEnumA"),\
        no_namespace rename("EOS", "EOSA")
#include "comdef.h"
#include "stdio.h"
#include "adoid.h"
#include "icrsint.h"
#include "acutads.h"

class CCustomRs : public CADORecordBinding
{
BEGIN_ADO_BINDING(CCustomRs)
        ADO_VARIABLE_LENGTH_ENTRY2(1, adVarChar, m_code,
                sizeof(m_code), codeStatus, FALSE)
        ADO_VARIABLE_LENGTH_ENTRY2(2, adVarChar, m_count,
                sizeof(m_count), countStatus, FALSE)
        ADO_VARIABLE_LENGTH_ENTRY2(3, adVarChar, m_direction,
                sizeof(m_direction), directionStatus, FALSE)
END_ADO_BINDING()
               
public:
        CHAR   m_code[41];
        ULONG   codeStatus;
        CHAR   m_count[12];
        ULONG   countStatus;
        CHAR   m_direction[41];
        ULONG   directionStatus;
};

void VisitMdb();

#endif

.cpp

#include "StdAfx.h"
#include "AdoVisit.h"
#include "conio.h"
#include "ole2.h"

void dump_com_error(_com_error &e)
{
        acutPrintf("Error\n");
        acutPrintf("\a\tCode = %08lx\n", e.Error());
        acutPrintf("\a\tCode meaning = %s", e.ErrorMessage());
        _bstr_t bstrSource(e.Source());
        _bstr_t bstrDescription(e.Description());
        acutPrintf("\a\tSource = %s\n", (LPCSTR) bstrSource);
        acutPrintf("\a\tDescription = %s\n", (LPCSTR) bstrDescription);
}

void
VisitMdb()
{
        HRESULT hr;
        IADORecordBinding   *picRs = NULL;
        _ConnectionPtr pConn("ADODB.Connection");
        _RecordsetPtr pRs("ADODB.Recordset");
        CCustomRs rs;
       
        ::CoInitialize(NULL);
        try
        {
                               
                pConn->Open("Provider=Microsoft.Jet.OLEDB.4.0;\
                        Data Source=e:\\kable\\basefiles\\Weld.mdb",\
                        "","",adModeUnknown);
               
                pRs->Open("select * from WeldingCode", (IDispatch*)pConn,
                        adOpenDynamic, adLockOptimistic, adCmdUnknown);
               
                if (FAILED(hr = pRs->QueryInterface(__uuidof(IADORecordBinding),
            (LPVOID*)&picRs)))
                        _com_issue_error(hr);
               
                if (FAILED(hr = picRs->BindToRecordset(&rs)))
                        _com_issue_error(hr);
               
                pRs->MoveFirst();
                while (!pRs->EndOfFile)
                {
                        acutPrintf("\a\tcode: %s\t count:%s\tdirection: %s\n",
                                (rs.codeStatus == adFldOK ? rs.m_code : ""),
                                (rs.countStatus == adFldOK ? rs.m_count: ""),
                                (rs.directionStatus == adFldOK ? rs.m_direction: ""));

                        pRs->MoveNext();
                }
                pConn->BeginTrans();
                pRs->UpdateBatch(adAffectAll);
               
                pConn->CommitTrans();
        }
        catch (_com_error &e)
        {
                dump_com_error(e);
        }
       
        if (picRs)
                picRs->Release();
       
        CoUninitialize();
}


1.有的#include文件要用尖括号,奇怪用尖括号贴不上去

2.这个程序可以运行,我总觉得有点怪怪的,请高手赐教
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

发表于 2004-5-20 14:49:56 | 显示全部楼层
一用dao加载数据就会出现内存不足的错误,咋办?
有用这个德马?大家为什么 都用ado呢:?
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

发表于 2004-5-20 15:11:55 | 显示全部楼层
微軟的IDE會幫你自動生成odbc的相關代碼呀
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

发表于 2004-6-16 16:40:37 | 显示全部楼层
我也想了解这方面的编程
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

QQ|申请友链|Archiver|手机版|小黑屋|辽公网安备|晓东CAD家园 ( 辽ICP备15016793号 )

GMT+8, 2024-9-21 19:56 , Processed in 0.392014 second(s), 61 queries , Gzip On.

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

快速回复 返回顶部 返回列表