|
|
请使用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 |
|