PLM之家PLMHome-工业软件践行者

[资料] NX二次开发源码分享:使用MFC数据库的方式访问excel数值

[复制链接]

2017-3-30 16:07:29 4498 1

2470

主题

1275

回帖

8万

积分

管理员

PLM之家站长

积分
82168
QQ
发表于 2014-11-10 15:43:38 | 显示全部楼层 |阅读模式

请使用QQ关联注册PLM之家,学习更多关于内容,更多精彩原创视频供你学习!

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

x
; t. x& `7 B) f# l. |+ V+ p  F$ a
头文件,加入 #include <afxdb.h>& e" J% k( T5 V# [: F$ s

2 {  n; {' D6 P' avoid excelTest::do_it()( M% J- F' I3 C  y# l& l
{! m5 k& X* u% S9 o3 h

# B3 b4 R$ b' i5 ~- x' x        // TODO: add your code here
$ Q' j2 w4 s. M: `9 F: T' s2 H0 I! y7 Y4 p; i  V  ^  C( t
        CDatabase Database;     // 定义一个MFC的CDatabse数据库类对象Databse
: p% L* j" b9 v, L% a. j1 N    CString   SQLCommand = "select * from plmhome";     // SQL查询语句 6 i6 W8 \4 S. G" }
    DWORD     dwOptions = 0;    // 设置连接的建立方式 ( S9 D7 u, S2 v; H
    CDBVariant temp;        // 数据库数据通用类型
- k0 o* p% V3 D& Z0 }5 X2 p1 V) R    int result;             // 储存返回值的变量 7 o3 e# q; {1 X, ]* \9 c$ m: D
    char cyl_height[133]; ' U- V  O' b8 E' i. t& b
    char cyl_diam[133]; 5 j9 I* C9 ^2 I8 f1 H! h' p
    double *cylinderValue = NULL;  ! I$ B# c6 m4 M  z
) ?) z  {) D" l1 i+ k
    try 3 b+ ]1 @4 B% F# A, u3 }! [8 N$ l
    {
7 q$ Q6 N; s/ m* @/ ^8 j# @2 E6 |                ( V# d9 C* M" n& B
        result = Database.OpenEx(_T("DSN=plmhome"), dwOptions );  // 打开数据库 ( l$ K( K! H+ n. B  s' c/ I
        if( result != 0 )   // 如果成功打开
7 R0 Y3 N% k1 G/ ^$ |        {
' a  X  w: L4 v            CRecordset rs( &Database );  // 定义记录集
( M. s/ f& V; ~/ r$ T( a            if ( rs.Open( CRecordset::snapshot, SQLCommand ) != false )  
/ [( A- q+ S# ^& G2 m            { ' I! B$ ~+ z6 c8 l
                rs.MoveFirst( );     
; v! e! b" X- o6 f& n0 |                short nFields = rs.GetODBCFieldCount( );    // 获取记录的字段数目         % H9 q' B# [+ C5 p' r& H8 h0 i3 [
                while( !rs.IsEOF( ) )      A: h6 D+ W; w( x% q
                {
( W! a2 J$ A- o* s5 ]                    cylinderValue =(double *)malloc( nFields * sizeof(double) );
2 e) D* c5 C7 X4 ]  X! J                    for( short index = 0; index < nFields; index++ )     
! d5 P4 e8 @: l, ?$ c7 _% K                    { : @- t% P1 D, |" M" e0 n. N
                        rs.GetFieldValue( index, temp );  
9 C3 X5 N. Y. {# P9 A                        cylinderValue[index] = temp.m_dblVal;                                     & Z' t4 k0 T" K. m1 p6 a: g
                    }     
) }  H  F$ O4 I8 d& R                    sprintf(cyl_height,"%f",cylinderValue[0] );
$ x+ [' v2 ?8 u0 f$ H* z                    sprintf(cyl_diam,"%f",cylinderValue[1] ); / i4 I3 o0 E# Y( Z( h

9 y0 c, m( w2 ^1 E                    rs.MoveNext( );  3 N& h. r' w/ X5 K7 G+ Y/ }
                    free(cylinderValue);
% j$ ^9 Q  r# \  S                } 6 d" y( }+ |2 q# [. P
                rs.Close( );    // 关闭记录集 . J/ N4 {6 f9 y% e
            } & |' Z4 E' @1 L1 K* q
            Database.Close();   // 关门数据库连接         
" M- e( ]. @( f& Z) L5 g                } 5 o- w) X! h2 v; |
    } 3 P1 O& N4 Z, \! _# m
& a6 h2 X  x' {& |' i" _8 M* ~9 j

* [. W# D- L5 N5 k  p  V1 }caTCh( CDBException *pe )   // 出错处理 7 G2 w- L8 A8 ]  z" ^
    {
' ]' i$ x  \8 y% L; S- s7 c$ k                AfxMessageBox( _T("Exception!" )); & z( U, k; |+ P$ V
        AfxMessageBox( pe->m_strError ); 9 D% D/ h- h/ Y/ H
        pe -> Delete( ); $ h) S% H5 z9 |2 f" {
    } ' r9 Q9 H5 z# E( j" k; W5 N2 t
}
& h$ D, E- v8 H6 b
) X/ B+ [0 L# j2 A6 \  a" K* T7 @9 |, K' j* w

( @9 y% T. f: ~+ |; f% D7 U7 n
上海点团信息科技有限公司,承接UG NX,CATIA,CREO,Solidworks 等CAx软件,Teamcenter,3D Experience等PLM软件,工业4.0数字化软件的实施\二次开发\培训相关业务,详情QQ 939801026 Tel 18301858168 网址 doTeam.tech
回复

使用道具 举报

全部回复1

0

主题

10

回帖

73

积分

注册会员

积分
73
发表于 2017-3-30 16:07:29 | 显示全部楼层
这个运行的怎么样,上个图看看
上海点团信息科技有限公司,承接UG NX,CATIA,CREO,Solidworks 等CAx软件,Teamcenter,3D Experience等PLM软件,工业4.0数字化软件的实施\二次开发\培训相关业务,详情QQ 939801026 Tel 18301858168 网址 www.doteam.tech
回复 支持 反对

使用道具 举报

发表回复

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

返回列表 本版积分规则

  • 发布新帖

  • 在线客服

  • 微信

  • 客户端

  • 返回顶部

  • x
    温馨提示

    本网站(plmhome.com)为PLM之家工业软件学习官网站

    展示的视频材料全部免费,需要高清和特殊技术支持请联系 QQ: 939801026

    PLM之家NX CAM二次开发专题模块培训报名开始啦

    我知道了