几何尺寸与公差论坛------致力于产品几何量公差标准GD&T (GDT:ASME)|New GPS(ISO)研究/CAD设计/CAM加工/CMM测量  


返回   几何尺寸与公差论坛------致力于产品几何量公差标准GD&T (GDT:ASME)|New GPS(ISO)研究/CAD设计/CAM加工/CMM测量 » 仿射空间:CAX软件开发(三)二次开发与程序设计 » CAD二次开发 » AutoCAD二次开发 » ObjectARX(C++)
用户名
密码
注册 帮助 会员 日历 银行 搜索 今日新帖 标记论坛为已读


回复
 
主题工具 搜索本主题 显示模式
旧 2009-04-16, 01:57 PM   #1
yang686526
高级会员
 
注册日期: 06-11
帖子: 14579
精华: 1
现金: 224494 标准币
资产: 234494 标准币
yang686526 向着好的方向发展
默认 【转帖】[求助]arx与数据库连接并读数据画线 有问题

[求助]arx与数据库连接并读数据画线 有问题
[求助]arx与数据库连接并读数据画线 有问题
void connect()
{
_connectionptr m_pconnection;
coinitialize(null);
m_pconnection.createinstance(__uuidof(connection));
// 在ado操作中建议语句中要常用try...catch()来捕获错误信息,
// 因为它有时会经常出现一些想不到的错误。
try
{
// 打开本地access库db1.mdb
m_pconnection->open("provider=microsoft.jet.oledb.4.0;data source=e:\pipedata.mdb","","",admodeunknown);
}
catch(_com_error &e)
{
afxmessagebox("数据库连接失败,确认数据库pipedata.mdb是否在当前路径下!")
return false;
}
//建立数据集
//-------------------------------------------------------------------------------------
_recordsetptr m_precordset;
m_precordset.createinstance(__uuidof(recordset));
// 在ado操作中建议语句中要常用try...catch()来捕获错误信息,
// 因为它有时会经常出现一些意想不到的错误。
try
{
m_precordset->open("select * from dxl",
m_pconnection.getinterfaceptr(), // 获取库接库的idispatch指针
adopendynamic,
adlockoptimistic,
adcmdtext);
}
catch(_com_error *e)
{
afxmessagebox(e->errormessage());

}
//--------------------------------------------------------------------------------------
//读取数据
//--------------------------------------------------------------------------------------
_variant_t var,var1,var2;

acgepoint3d startpt,endpt;
char *strid,*strid1,*str1,*str2;
//float x,y;
try
{
if(!m_precordset->bof)
m_precordset->movefirst();
else
{
afxmessagebox("表内数据为空");
return 1;
}
// 读入库中各字段
while(!m_precordset->adoeof)
{
var = m_precordset->getcollect("起始点号");
if(var.vt != vt_null)
strid= _com_util::convertbstrtostring((_bstr_t)var); //_variant_t转字符串
var2 = m_precordset->getcollect("终止点号");
if(var.vt != vt_null)
strid1= _com_util::convertbstrtostring((_bstr_t)var2); //_variant_t转字符串
while(!m_precordset->adoeof)
{
m_precordset->open("select * from dxp",
m_pconnection.getinterfaceptr(), // 获取库接库的idispatch指针
adopendynamic,
adlockoptimistic,
adcmdtext);
var1=m_precordset->getcollect("物探点号");
str1= _com_util::convertbstrtostring((_bstr_t)var); //_variant_t转字符串
if(strid==str1)
{
var1 = m_precordset->getcollect("x");
if(var1.vt != vt_null)
startpt[x]=_com_util::convertbstrtostring((_bstr_t)var1);
var1 = m_precordset->getcollect("y");
if(var1.vt != vt_null)
startpt[y]=_com_util::convertbstrtostring((_bstr_t)var1);
}
if(strid1==str1)
{
var1 = m_precordset->getcollect("x");
if(var1.vt != vt_null)
endpt[x]=_com_util::convertbstrtostring((_bstr_t)var);
var1 = m_precordset->getcollect("y");
if(var1.vt != vt_null)
endpt[y]=_com_util::convertbstrtostring((_bstr_t)var);
}
m_precordset->movenext();
acdbline *pline = new acdbline(startpt, endpt); //构建直线类(acdbline)的对象
acdbblocktable *pblocktable; //指向块表的指针
acdbhostapplicationservices()->workingdatabase()->getsymboltable(pblocktable, acdb::kforread); //将指针指向当前数据库中的块表
acdbblocktablerecord *pblocktablerecord; //指向块表记录的指针
//将块表记录的指针指向当前块表的模型空间记录
pblocktable->getat(acdb_model_space, pblocktablerecord, cdb::kforwrite);
pblocktable->close(); //关闭块表
acdbobjectid lineid; //指向id
pblocktablerecord->appendacdbentity(lineid, pline); //将指向添加到块表记录
pblocktablerecord->close(); //关闭块表记录
pline->close();
return lineid;
}

m_precordset->movenext();

}
}
catch(_com_error *e)
{
afxmessagebox(e->errormessage());
}
//--------------------------------------------------------------------------------------
//关闭数据集
m_precordset->close();
m_precordset = null;
//--------------------------------------------------------------------------------------
//关闭数据库连接
//--------------------------------------------------------------------------------------
if(m_pconnection->state)
m_pconnection->close();
m_pconnection= null;
return 0;
}
yang686526离线中   回复时引用此帖
GDT自动化论坛(仅游客可见)
回复


主题工具 搜索本主题
搜索本主题:

高级搜索
显示模式

发帖规则
不可以发表新主题
不可以回复主题
不可以上传附件
不可以编辑您的帖子

vB 代码开启
[IMG]代码开启
HTML代码关闭



所有的时间均为北京时间。 现在的时间是 04:05 PM.


于2004年创办,几何尺寸与公差论坛"致力于产品几何量公差标准GD&T | GPS研究/CAD设计/CAM加工/CMM测量"。免责声明:论坛严禁发布色情反动言论及有关违反国家法律法规内容!情节严重者提供其IP,并配合相关部门进行严厉查处,若內容有涉及侵权,请立即联系我们QQ:44671734。注:此论坛须管理员验证方可发帖。
沪ICP备06057009号-2
更多