AdoImpl.cpp 19 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835
  1. #include "StdAfx.h"
  2. #include "AdoImpl.h"
  3. AdoImpl::AdoImpl(void)
  4. {
  5. m_pADODatabase = NULL;
  6. memset(m_szConnectString,0,1024);
  7. InitializeCriticalSection(&m_csAdo);
  8. }
  9. AdoImpl::~AdoImpl(void)
  10. {
  11. DeleteCriticalSection(&m_csAdo);
  12. }
  13. void AdoImpl::SetConnectString(IN const int &nType,IN const STAdoDatabaseInfo &tagAodDatabaseInfo)
  14. {
  15. switch (nType)
  16. {
  17. case ADO_ACCESS97:
  18. sprintf(m_szConnectString, "Provider=Microsoft.Jet.OLEDB.3.51;Data Source=%s", tagAodDatabaseInfo.szDatabaseFile);
  19. break;
  20. case ADO_ACCESS2000:
  21. sprintf(m_szConnectString, "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=%s", tagAodDatabaseInfo.szDatabaseFile);
  22. break;
  23. case ADO_ACCESS2007:
  24. sprintf(m_szConnectString, "Provider=Microsoft.ACE.OLEDB.12.0;Data Source=%s", tagAodDatabaseInfo.szDatabaseFile);
  25. break;
  26. case ADO_SQLSERVER:
  27. {
  28. if ( !_stricmp(tagAodDatabaseInfo.szDatabaseTCPPort,"0"))
  29. {
  30. //sprintf(m_szConnectString, "Provider=sqloledb.1;Persist Security Info=false;Data Source=%s;Initial Catalog=%s;User Id=%s;Password=%s; ",
  31. sprintf(m_szConnectString, "Provider=sqloledb;Data Source=%s;Initial Catalog=%s;User Id=%s;Password=%s; ",
  32. tagAodDatabaseInfo.szDataSource, // IP華硊麼督昢靡備;
  33. tagAodDatabaseInfo.szDatabaseName,
  34. tagAodDatabaseInfo.szDatabaseAccount,
  35. tagAodDatabaseInfo.szDatabasePassword);
  36. }
  37. else
  38. {
  39. //sprintf(m_szConnectString, "Provider=sqloledb.1;Persist Security Info=false;Data Source=%s,%s;Initial Catalog=%s;User Id=%s;Password=%s; ",
  40. sprintf(m_szConnectString, "Provider=sqloledb;Data Source=%s,%s;Initial Catalog=%s;User Id=%s;Password=%s; ",
  41. tagAodDatabaseInfo.szDataSource, // IP華硊麼督昢靡備;
  42. tagAodDatabaseInfo.szDatabaseTCPPort,
  43. tagAodDatabaseInfo.szDatabaseName,
  44. tagAodDatabaseInfo.szDatabaseAccount,
  45. tagAodDatabaseInfo.szDatabasePassword);
  46. }
  47. }
  48. break;
  49. case ADO_PGSQL:
  50. {
  51. sprintf(m_szConnectString, "DRIVER={PostgreSQL ODBC Driver(UNICODE)}; SERVER=%s; port=%s; DATABASE=%s; UID=%s; PWD=%s;",
  52. tagAodDatabaseInfo.szDataSource, // IP華硊麼督昢靡備;
  53. tagAodDatabaseInfo.szDatabaseTCPPort,
  54. tagAodDatabaseInfo.szDatabaseName,
  55. tagAodDatabaseInfo.szDatabaseAccount,
  56. tagAodDatabaseInfo.szDatabasePassword);
  57. }
  58. break;
  59. default:
  60. break;
  61. }
  62. }
  63. bool AdoImpl::opendatabase(IN const TCHAR *pConnectString)
  64. {
  65. bool bResult = false;
  66. if( NULL == m_pADODatabase )
  67. {
  68. m_pADODatabase = new CADODatabase();
  69. if( m_pADODatabase )
  70. {
  71. if( pConnectString == NULL )
  72. {
  73. m_pADODatabase->SetConnectionString(m_szConnectString);
  74. }
  75. else
  76. {
  77. m_pADODatabase->SetConnectionString(pConnectString);
  78. strcpy(m_szConnectString, pConnectString);
  79. }
  80. if( TRUE == m_pADODatabase->Open() )
  81. {
  82. //LOG4C((LOG_NOTICE, "Database Connetion Success!"));
  83. bResult = true;
  84. }
  85. else
  86. {
  87. if( m_pADODatabase->IsOpen() )
  88. {
  89. m_pADODatabase->Close();
  90. }
  91. delete m_pADODatabase;
  92. m_pADODatabase = NULL;
  93. //LOG4C((LOG_NOTICE, "Database Connetion Lost!"));
  94. }
  95. }
  96. }
  97. return bResult;
  98. }
  99. void AdoImpl::closedatabase()
  100. {
  101. if( NULL != m_pADODatabase )
  102. {
  103. if( m_pADODatabase->IsOpen() )
  104. {
  105. m_pADODatabase->Close();
  106. }
  107. if( m_pADODatabase )
  108. delete m_pADODatabase;
  109. m_pADODatabase = NULL;
  110. }
  111. }
  112. int AdoImpl::Execute(TCHAR *pSQL)
  113. {
  114. INT iRetCode = 0;
  115. if( NULL == m_pADODatabase )
  116. {
  117. //LOG4C((LOG_NOTICE, "NULL == m_pADODatabase" ));
  118. return -1;
  119. }
  120. try
  121. {
  122. EnterCriticalSection(&m_csAdo);
  123. if ( m_pADODatabase->IsOpen() )
  124. {
  125. iRetCode = m_pADODatabase->Execute(pSQL);
  126. LeaveCriticalSection(&m_csAdo);
  127. }
  128. else
  129. {
  130. LeaveCriticalSection(&m_csAdo);
  131. //LOG4C((LOG_NOTICE, "m_pADODatabase->IsOpen() = false" ));
  132. return -1;
  133. }
  134. }
  135. catch (_com_error &e)
  136. {
  137. //LOG4C( ( LOG_ERROR, "Execute SQL Script Error, Script:%s, ErrorMsg:%s", pSql, e.ErrorMessage() ) );
  138. }// end catch (_com_error &e)
  139. return iRetCode;
  140. }
  141. void AdoImpl::DeleteADORecordSet(CADORecordset* pRSet)
  142. {
  143. CloseADORecordSet(pRSet);
  144. if( pRSet )
  145. {
  146. delete pRSet;
  147. pRSet = NULL;
  148. }
  149. }
  150. bool AdoImpl::OpenADORecordSet(CADORecordset* pRSet, const TCHAR *pSQL)
  151. {
  152. int iRetCode;
  153. bool bResult = true;
  154. if( NULL == pRSet ) return false;
  155. try
  156. {
  157. iRetCode = pRSet->Open(pSQL, CADORecordset::openQuery);
  158. if (iRetCode == 0)
  159. {
  160. DeleteADORecordSet(pRSet);
  161. bResult = false;
  162. }
  163. }
  164. catch (_com_error &e)
  165. {
  166. //LOG4C( ( LOG_ERROR, "Execute SQL Script Error, Script:%s, ErrorMsg:%s", pSql, e.ErrorMessage() ) );
  167. DeleteADORecordSet(pRSet);
  168. bResult = false;
  169. }// end catch (_com_error &e)
  170. return bResult;
  171. }
  172. void AdoImpl::CloseADORecordSet(CADORecordset* pRSet)
  173. {
  174. if( NULL != pRSet )
  175. {
  176. if( pRSet->IsOpen() )
  177. {
  178. pRSet->Close();
  179. }
  180. }
  181. }
  182. bool AdoImpl::GetADODateBaseStatus()
  183. {
  184. if( NULL == m_pADODatabase || !m_pADODatabase->IsOpen())
  185. return false;
  186. return true;
  187. }
  188. DWORD AdoImpl::GetTableRecordCount(IN const TCHAR *pTableName)
  189. {
  190. if ( pTableName == NULL)
  191. {
  192. return -1;
  193. }
  194. TCHAR szSQL[1024] = _T("");
  195. sprintf(szSQL,"select count(*) as cot from %s",pTableName);
  196. DWORD nRecordCount = 0;
  197. _variant_t vtFieldValue;
  198. bool bResult = false;
  199. EnterCriticalSection( &m_csAdo );
  200. bResult = GetADODateBaseStatus();
  201. if( false == bResult )
  202. {
  203. LeaveCriticalSection( &m_csAdo );
  204. return -1;
  205. }
  206. CADORecordset* pRSet = new CADORecordset(m_pADODatabase);
  207. LeaveCriticalSection( &m_csAdo );
  208. if( NULL == pRSet )
  209. {
  210. //LOG4C((LOG_NOTICE, "GetFieldValueList1 pRSet == NULL"));
  211. return -1;
  212. }
  213. bResult = OpenADORecordSet(pRSet, szSQL);
  214. if( false == bResult )
  215. {
  216. //LOG4C((LOG_NOTICE, "GetFieldValueList1 OpenADORecordSet <%s>", pSql));
  217. DeleteADORecordSet(pRSet);
  218. return -1;
  219. }
  220. if( !pRSet->IsFieldNull("cot") )
  221. {
  222. pRSet->GetFieldValue("cot", nRecordCount);
  223. }
  224. else
  225. {
  226. nRecordCount = -1;
  227. }// end if( !pRSet->IsFieldNull(0) )
  228. DeleteADORecordSet(pRSet);
  229. return nRecordCount;
  230. }
  231. int AdoImpl::GetClientServiceViewData(__in const TCHAR *pSQL,__out CArray<CStringArray,CStringArray>& strArray,__in const TCHAR *pfilter)
  232. {
  233. int nFieldCount = 0;
  234. int nRecordCount = 0;
  235. _variant_t vtFieldValue;
  236. bool bResult = false;
  237. EnterCriticalSection( &m_csAdo );
  238. bResult = GetADODateBaseStatus();
  239. if( false == bResult )
  240. {
  241. LeaveCriticalSection( &m_csAdo );
  242. return -1;
  243. }
  244. CADORecordset* pRSet = new CADORecordset(m_pADODatabase);
  245. LeaveCriticalSection( &m_csAdo );
  246. if( NULL == pRSet )
  247. {
  248. return -1;
  249. }
  250. TCHAR szSQL[1024] = _T("");
  251. if(pfilter && (strcmp(pfilter,"") != 0))
  252. sprintf(szSQL,"%s where %s",pSQL,pfilter);
  253. else
  254. sprintf(szSQL,"%s",pSQL);
  255. bResult = OpenADORecordSet(pRSet, szSQL);
  256. if( false == bResult )
  257. {
  258. DeleteADORecordSet(pRSet);
  259. return -1;
  260. }
  261. nRecordCount = pRSet->GetRecordCount();
  262. nFieldCount = pRSet->GetFieldCount();
  263. strArray.SetSize(nRecordCount,1);
  264. for( int i = 0; i < nRecordCount; i++ )
  265. {
  266. if( !pRSet->IsFieldNull("dindanid") )
  267. {
  268. pRSet->GetFieldValue("dindanid", vtFieldValue);
  269. string strFieldValue = string((char*)(_bstr_t)vtFieldValue);
  270. strArray.ElementAt(i).Add(strFieldValue.c_str());
  271. }
  272. else
  273. {
  274. strArray.ElementAt(i).Add("");
  275. }
  276. if( !pRSet->IsFieldNull("name1") )
  277. {
  278. pRSet->GetFieldValue("name1", vtFieldValue);
  279. string strFieldValue = string((char*)(_bstr_t)vtFieldValue);
  280. strArray.ElementAt(i).Add(strFieldValue.c_str());
  281. }
  282. else
  283. {
  284. strArray.ElementAt(i).Add("");
  285. }
  286. if( !pRSet->IsFieldNull("name2") )
  287. {
  288. pRSet->GetFieldValue("name2", vtFieldValue);
  289. string strFieldValue = string((char*)(_bstr_t)vtFieldValue);
  290. strArray.ElementAt(i).Add(strFieldValue.c_str());
  291. }
  292. else
  293. {
  294. strArray.ElementAt(i).Add("");
  295. }
  296. if( !pRSet->IsFieldNull("phone1") )
  297. {
  298. pRSet->GetFieldValue("phone1", vtFieldValue);
  299. string strFieldValue = string((char*)(_bstr_t)vtFieldValue);
  300. strArray.ElementAt(i).Add(strFieldValue.c_str());
  301. }
  302. else
  303. {
  304. strArray.ElementAt(i).Add("");
  305. }
  306. if( !pRSet->IsFieldNull("addr1") )
  307. {
  308. pRSet->GetFieldValue("addr1", vtFieldValue);
  309. string strFieldValue = string((char*)(_bstr_t)vtFieldValue);
  310. strArray.ElementAt(i).Add(strFieldValue.c_str());
  311. }
  312. else
  313. {
  314. strArray.ElementAt(i).Add("");
  315. }
  316. if( !pRSet->IsFieldNull("qq1") )
  317. {
  318. pRSet->GetFieldValue("qq1", vtFieldValue);
  319. string strFieldValue = string((char*)(_bstr_t)vtFieldValue);
  320. strArray.ElementAt(i).Add(strFieldValue.c_str());
  321. }
  322. else
  323. {
  324. strArray.ElementAt(i).Add("");
  325. }
  326. if( !pRSet->IsFieldNull("txtype") )
  327. {
  328. pRSet->GetFieldValue("txtype", vtFieldValue);
  329. string strFieldValue = string((char*)(_bstr_t)vtFieldValue);
  330. strArray.ElementAt(i).Add(strFieldValue.c_str());
  331. }
  332. else
  333. {
  334. strArray.ElementAt(i).Add("");
  335. }
  336. if( !pRSet->IsFieldNull("ren") )
  337. {
  338. pRSet->GetFieldValue("ren", vtFieldValue);
  339. string strFieldValue = string((char*)(_bstr_t)vtFieldValue);
  340. strArray.ElementAt(i).Add(strFieldValue.c_str());
  341. }
  342. else
  343. {
  344. strArray.ElementAt(i).Add("");
  345. }
  346. if( !pRSet->IsFieldNull("checkcontent") )
  347. {
  348. pRSet->GetFieldValue("checkcontent", vtFieldValue);
  349. string strFieldValue = string((char*)(_bstr_t)vtFieldValue);
  350. strArray.ElementAt(i).Add(strFieldValue.c_str());
  351. }
  352. else
  353. {
  354. strArray.ElementAt(i).Add("");
  355. }
  356. if( !pRSet->IsFieldNull("clerk") )
  357. {
  358. pRSet->GetFieldValue("clerk", vtFieldValue);
  359. string strFieldValue = string((char*)(_bstr_t)vtFieldValue);
  360. strArray.ElementAt(i).Add(strFieldValue.c_str());
  361. }
  362. else
  363. {
  364. strArray.ElementAt(i).Add("");
  365. }
  366. if( !pRSet->IsFieldNull("useqq") )
  367. {
  368. pRSet->GetFieldValue("useqq", vtFieldValue);
  369. string strFieldValue = string((char*)(_bstr_t)vtFieldValue);
  370. strArray.ElementAt(i).Add(strFieldValue.c_str());
  371. }
  372. else
  373. {
  374. strArray.ElementAt(i).Add("");
  375. }
  376. if( !pRSet->IsFieldNull("date") )
  377. {
  378. pRSet->GetFieldValue("date", vtFieldValue);
  379. string strFieldValue = string((char*)(_bstr_t)vtFieldValue);
  380. strArray.ElementAt(i).Add(strFieldValue.c_str());
  381. }
  382. else
  383. {
  384. strArray.ElementAt(i).Add("");
  385. }
  386. if( !pRSet->IsFieldNull("question") )
  387. {
  388. pRSet->GetFieldValue("question", vtFieldValue);
  389. string strFieldValue = string((char*)(_bstr_t)vtFieldValue);
  390. strArray.ElementAt(i).Add(strFieldValue.c_str());
  391. }
  392. else
  393. {
  394. strArray.ElementAt(i).Add("");
  395. }
  396. if( !pRSet->IsFieldNull("solution") )
  397. {
  398. pRSet->GetFieldValue("solution", vtFieldValue);
  399. string strFieldValue = string((char*)(_bstr_t)vtFieldValue);
  400. strArray.ElementAt(i).Add(strFieldValue.c_str());
  401. }
  402. else
  403. {
  404. strArray.ElementAt(i).Add("");
  405. }
  406. if( !pRSet->IsFieldNull("result") )
  407. {
  408. pRSet->GetFieldValue("result", vtFieldValue);
  409. string strFieldValue = string((char*)(_bstr_t)vtFieldValue);
  410. strArray.ElementAt(i).Add(strFieldValue.c_str());
  411. }
  412. else
  413. {
  414. strArray.ElementAt(i).Add("");
  415. }
  416. if( !pRSet->IsFieldNull("clientqq") )
  417. {
  418. pRSet->GetFieldValue("clientqq", vtFieldValue);
  419. string strFieldValue = string((char*)(_bstr_t)vtFieldValue);
  420. strArray.ElementAt(i).Add(strFieldValue.c_str());
  421. }
  422. else
  423. {
  424. strArray.ElementAt(i).Add("");
  425. }
  426. if( !pRSet->IsFieldNull("contact") )
  427. {
  428. pRSet->GetFieldValue("contact", vtFieldValue);
  429. string strFieldValue = string((char*)(_bstr_t)vtFieldValue);
  430. strArray.ElementAt(i).Add(strFieldValue.c_str());
  431. }
  432. else
  433. {
  434. strArray.ElementAt(i).Add("");
  435. }
  436. if( !pRSet->IsFieldNull("time") )
  437. {
  438. pRSet->GetFieldValue("time", vtFieldValue);
  439. string strFieldValue = string((char*)(_bstr_t)vtFieldValue);
  440. strArray.ElementAt(i).Add(strFieldValue.c_str());
  441. }
  442. else
  443. {
  444. strArray.ElementAt(i).Add("");
  445. }
  446. if( !pRSet->IsFieldNull("from") )
  447. {
  448. pRSet->GetFieldValue("from", vtFieldValue);
  449. string strFieldValue = string((char*)(_bstr_t)vtFieldValue);
  450. strArray.ElementAt(i).Add(strFieldValue.c_str());
  451. }
  452. else
  453. {
  454. strArray.ElementAt(i).Add("");
  455. }
  456. if( !pRSet->IsFieldNull("pinyin1") )
  457. {
  458. pRSet->GetFieldValue("pinyin1", vtFieldValue);
  459. string strFieldValue = string((char*)(_bstr_t)vtFieldValue);
  460. strArray.ElementAt(i).Add(strFieldValue.c_str());
  461. }
  462. else
  463. {
  464. strArray.ElementAt(i).Add("");
  465. }
  466. if( !pRSet->IsFieldNull("pinyin2") )
  467. {
  468. pRSet->GetFieldValue("pinyin2", vtFieldValue);
  469. string strFieldValue = string((char*)(_bstr_t)vtFieldValue);
  470. strArray.ElementAt(i).Add(strFieldValue.c_str());
  471. }
  472. else
  473. {
  474. strArray.ElementAt(i).Add("");
  475. }
  476. pRSet->MoveNext();
  477. }// end for( int i = 0; i < nRecordCount; i++ )
  478. DeleteADORecordSet(pRSet);
  479. return nRecordCount;
  480. }
  481. int AdoImpl::GetClientServiceViewDataEx(__in const TCHAR *pSQL,__out CArray<CStringArray,CStringArray>& strArray,__in const TCHAR *pfilter)
  482. {
  483. int nFieldCount = 0;
  484. int nRecordCount = 0;
  485. _variant_t vtFieldValue;
  486. bool bResult = false;
  487. EnterCriticalSection( &m_csAdo );
  488. bResult = GetADODateBaseStatus();
  489. if( false == bResult )
  490. {
  491. LeaveCriticalSection( &m_csAdo );
  492. return -1;
  493. }
  494. CADORecordset* pRSet = new CADORecordset(m_pADODatabase);
  495. LeaveCriticalSection( &m_csAdo );
  496. if( NULL == pRSet )
  497. {
  498. return -1;
  499. }
  500. TCHAR szSQL[1024] = _T("");
  501. if(pfilter && (strcmp(pfilter,"") != 0))
  502. sprintf(szSQL,"%s where %s",pSQL,pfilter);
  503. else
  504. sprintf(szSQL,"%s",pSQL);
  505. bResult = OpenADORecordSet(pRSet, szSQL);
  506. if( false == bResult )
  507. {
  508. DeleteADORecordSet(pRSet);
  509. return -1;
  510. }
  511. nRecordCount = pRSet->GetRecordCount();
  512. nFieldCount = pRSet->GetFieldCount();
  513. strArray.SetSize(nRecordCount,1);
  514. for( int i = 0; i < nRecordCount; i++ )
  515. {
  516. if( !pRSet->IsFieldNull("dindanid") )
  517. {
  518. pRSet->GetFieldValue("dindanid", vtFieldValue);
  519. string strFieldValue = string((char*)(_bstr_t)vtFieldValue);
  520. strArray.ElementAt(i).Add(strFieldValue.c_str());
  521. }
  522. else
  523. {
  524. strArray.ElementAt(i).Add("");
  525. }
  526. if( !pRSet->IsFieldNull("name1") )
  527. {
  528. pRSet->GetFieldValue("name1", vtFieldValue);
  529. string strFieldValue = string((char*)(_bstr_t)vtFieldValue);
  530. strArray.ElementAt(i).Add(strFieldValue.c_str());
  531. }
  532. else
  533. {
  534. strArray.ElementAt(i).Add("");
  535. }
  536. if( !pRSet->IsFieldNull("name2") )
  537. {
  538. pRSet->GetFieldValue("name2", vtFieldValue);
  539. string strFieldValue = string((char*)(_bstr_t)vtFieldValue);
  540. strArray.ElementAt(i).Add(strFieldValue.c_str());
  541. }
  542. else
  543. {
  544. strArray.ElementAt(i).Add("");
  545. }
  546. if( !pRSet->IsFieldNull("phone1") )
  547. {
  548. pRSet->GetFieldValue("phone1", vtFieldValue);
  549. string strFieldValue = string((char*)(_bstr_t)vtFieldValue);
  550. strArray.ElementAt(i).Add(strFieldValue.c_str());
  551. }
  552. else
  553. {
  554. strArray.ElementAt(i).Add("");
  555. }
  556. if( !pRSet->IsFieldNull("addr1") )
  557. {
  558. pRSet->GetFieldValue("addr1", vtFieldValue);
  559. string strFieldValue = string((char*)(_bstr_t)vtFieldValue);
  560. strArray.ElementAt(i).Add(strFieldValue.c_str());
  561. }
  562. else
  563. {
  564. strArray.ElementAt(i).Add("");
  565. }
  566. if( !pRSet->IsFieldNull("qq1") )
  567. {
  568. pRSet->GetFieldValue("qq1", vtFieldValue);
  569. string strFieldValue = string((char*)(_bstr_t)vtFieldValue);
  570. strArray.ElementAt(i).Add(strFieldValue.c_str());
  571. }
  572. else
  573. {
  574. strArray.ElementAt(i).Add("");
  575. }
  576. if( !pRSet->IsFieldNull("txtype") )
  577. {
  578. pRSet->GetFieldValue("txtype", vtFieldValue);
  579. string strFieldValue = string((char*)(_bstr_t)vtFieldValue);
  580. strArray.ElementAt(i).Add(strFieldValue.c_str());
  581. }
  582. else
  583. {
  584. strArray.ElementAt(i).Add("");
  585. }
  586. if( !pRSet->IsFieldNull("ren") )
  587. {
  588. pRSet->GetFieldValue("ren", vtFieldValue);
  589. string strFieldValue = string((char*)(_bstr_t)vtFieldValue);
  590. strArray.ElementAt(i).Add(strFieldValue.c_str());
  591. }
  592. else
  593. {
  594. strArray.ElementAt(i).Add("");
  595. }
  596. if( !pRSet->IsFieldNull("checkcontent") )
  597. {
  598. pRSet->GetFieldValue("checkcontent", vtFieldValue);
  599. string strFieldValue = string((char*)(_bstr_t)vtFieldValue);
  600. strArray.ElementAt(i).Add(strFieldValue.c_str());
  601. }
  602. else
  603. {
  604. strArray.ElementAt(i).Add("");
  605. }
  606. if( !pRSet->IsFieldNull("clerk") )
  607. {
  608. pRSet->GetFieldValue("clerk", vtFieldValue);
  609. string strFieldValue = string((char*)(_bstr_t)vtFieldValue);
  610. strArray.ElementAt(i).Add(strFieldValue.c_str());
  611. }
  612. else
  613. {
  614. strArray.ElementAt(i).Add("");
  615. }
  616. if( !pRSet->IsFieldNull("useqq") )
  617. {
  618. pRSet->GetFieldValue("useqq", vtFieldValue);
  619. string strFieldValue = string((char*)(_bstr_t)vtFieldValue);
  620. strArray.ElementAt(i).Add(strFieldValue.c_str());
  621. }
  622. else
  623. {
  624. strArray.ElementAt(i).Add("");
  625. }
  626. if( !pRSet->IsFieldNull("date") )
  627. {
  628. pRSet->GetFieldValue("date", vtFieldValue);
  629. string strFieldValue = string((char*)(_bstr_t)vtFieldValue);
  630. strArray.ElementAt(i).Add(strFieldValue.c_str());
  631. }
  632. else
  633. {
  634. strArray.ElementAt(i).Add("");
  635. }
  636. if( !pRSet->IsFieldNull("from") )
  637. {
  638. pRSet->GetFieldValue("from", vtFieldValue);
  639. string strFieldValue = string((char*)(_bstr_t)vtFieldValue);
  640. strArray.ElementAt(i).Add(strFieldValue.c_str());
  641. }
  642. else
  643. {
  644. strArray.ElementAt(i).Add("");
  645. }
  646. if( !pRSet->IsFieldNull("clientqq") )
  647. {
  648. pRSet->GetFieldValue("clientqq", vtFieldValue);
  649. string strFieldValue = string((char*)(_bstr_t)vtFieldValue);
  650. strArray.ElementAt(i).Add(strFieldValue.c_str());
  651. }
  652. else
  653. {
  654. strArray.ElementAt(i).Add("");
  655. }
  656. if( !pRSet->IsFieldNull("contact") )
  657. {
  658. pRSet->GetFieldValue("contact", vtFieldValue);
  659. string strFieldValue = string((char*)(_bstr_t)vtFieldValue);
  660. strArray.ElementAt(i).Add(strFieldValue.c_str());
  661. }
  662. else
  663. {
  664. strArray.ElementAt(i).Add("");
  665. }
  666. if( !pRSet->IsFieldNull("time") )
  667. {
  668. pRSet->GetFieldValue("time", vtFieldValue);
  669. string strFieldValue = string((char*)(_bstr_t)vtFieldValue);
  670. strArray.ElementAt(i).Add(strFieldValue.c_str());
  671. }
  672. else
  673. {
  674. strArray.ElementAt(i).Add("");
  675. }
  676. if( !pRSet->IsFieldNull("question") )
  677. {
  678. pRSet->GetFieldValue("question", vtFieldValue);
  679. string strFieldValue = string((char*)(_bstr_t)vtFieldValue);
  680. strArray.ElementAt(i).Add(strFieldValue.c_str());
  681. }
  682. else
  683. {
  684. strArray.ElementAt(i).Add("");
  685. }
  686. if( !pRSet->IsFieldNull("solution") )
  687. {
  688. pRSet->GetFieldValue("solution", vtFieldValue);
  689. string strFieldValue = string((char*)(_bstr_t)vtFieldValue);
  690. strArray.ElementAt(i).Add(strFieldValue.c_str());
  691. }
  692. else
  693. {
  694. strArray.ElementAt(i).Add("");
  695. }
  696. if( !pRSet->IsFieldNull("result") )
  697. {
  698. pRSet->GetFieldValue("result", vtFieldValue);
  699. string strFieldValue = string((char*)(_bstr_t)vtFieldValue);
  700. strArray.ElementAt(i).Add(strFieldValue.c_str());
  701. }
  702. else
  703. {
  704. strArray.ElementAt(i).Add("");
  705. }
  706. if( !pRSet->IsFieldNull("autoid") )
  707. {
  708. pRSet->GetFieldValue("autoid", vtFieldValue);
  709. string strFieldValue = string((char*)(_bstr_t)vtFieldValue);
  710. strArray.ElementAt(i).Add(strFieldValue.c_str());
  711. }
  712. else
  713. {
  714. strArray.ElementAt(i).Add("");
  715. }
  716. if( !pRSet->IsFieldNull("pinyin1") )
  717. {
  718. pRSet->GetFieldValue("pinyin1", vtFieldValue);
  719. string strFieldValue = string((char*)(_bstr_t)vtFieldValue);
  720. strArray.ElementAt(i).Add(strFieldValue.c_str());
  721. }
  722. else
  723. {
  724. strArray.ElementAt(i).Add("");
  725. }
  726. if( !pRSet->IsFieldNull("pinyin2") )
  727. {
  728. pRSet->GetFieldValue("pinyin2", vtFieldValue);
  729. string strFieldValue = string((char*)(_bstr_t)vtFieldValue);
  730. strArray.ElementAt(i).Add(strFieldValue.c_str());
  731. }
  732. else
  733. {
  734. strArray.ElementAt(i).Add("");
  735. }
  736. pRSet->MoveNext();
  737. }// end for( int i = 0; i < nRecordCount; i++ )
  738. DeleteADORecordSet(pRSet);
  739. return nRecordCount;
  740. }