WxAdoImpl.cpp 26 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832
  1. #include "StdAfx.h"
  2. #include "WxAdoImpl.h"
  3. #include "WxAdoPool.h"
  4. #include "table.pb.h"
  5. #ifdef _DEBUG
  6. #define new DEBUG_NEW
  7. #endif
  8. #define GETDBPTR(dwTimeOut) \
  9. pAdoObj pObj = NULL;\
  10. CAdoConnGuard tagConnGuard(pObj, dwTimeOut);\
  11. if ( pObj == NULL)\
  12. return FALSE\
  13. // 添加参数;
  14. auto AddSTRParameters = [](_CommandPtr cmd, LPCTSTR lpszFieldName, LPCTSTR lpszFieldValue)->BOOL {
  15. if (lpszFieldName == NULL || lpszFieldValue == NULL)
  16. return FALSE;
  17. _ParameterPtr param;
  18. param.CreateInstance(__uuidof(Parameter));
  19. param = cmd->CreateParameter(_bstr_t(lpszFieldName), adBSTR, adParamInput, _tclen(lpszFieldValue), lpszFieldValue);
  20. cmd->Parameters->Append(param);
  21. return TRUE;
  22. };
  23. auto AddIntParameters = [](_CommandPtr cmd, LPCTSTR lpszFieldName, int nFieldValue)->BOOL {
  24. if (lpszFieldName == NULL )
  25. return FALSE;
  26. _ParameterPtr param;
  27. param.CreateInstance(__uuidof(Parameter));
  28. param = cmd->CreateParameter(_bstr_t(lpszFieldName), adInteger, adParamInput, sizeof(nFieldValue), nFieldValue);
  29. cmd->Parameters->Append(param);
  30. return TRUE;
  31. };
  32. auto AddBoolParameters = [](_CommandPtr cmd, LPCTSTR lpszFieldName, BOOL bFieldValue)->BOOL {
  33. if (lpszFieldName == NULL)
  34. return FALSE;
  35. _ParameterPtr param;
  36. param.CreateInstance(__uuidof(Parameter));
  37. param = cmd->CreateParameter(_bstr_t(lpszFieldName), adBoolean, adParamInput, sizeof(bFieldValue), bFieldValue);
  38. cmd->Parameters->Append(param);
  39. return TRUE;
  40. };
  41. enum UserLogInStatus
  42. {
  43. USER_LOGIN = 1, // 登录成功;
  44. USER_PW_MISTAKE = 2, // 密码错误;
  45. USER_NULL = 0 // 没有用户;
  46. };
  47. CWxAdoImpl* CWxAdoImpl::m_pInstance = NULL;
  48. CWxAdoImpl::CWxAdoImpl(void):m_nRef(0),m_nObjRef(0)
  49. {
  50. // 全局uid,64位整型,转字符长度17位;
  51. m_uniqueid.setWorkerId(10);
  52. m_uniqueid.setDatacenterId(20);
  53. }
  54. CWxAdoImpl::~CWxAdoImpl(void)
  55. {
  56. }
  57. ULONG CWxAdoImpl::AddRef()
  58. {
  59. InterlockedIncrement( &m_nRef ); //增加引用计数;
  60. return m_nRef;
  61. }
  62. ULONG CWxAdoImpl::Release()
  63. {
  64. InterlockedDecrement( &m_nRef ); //减少引用计数;
  65. //如果为0,删除对象
  66. if( m_nRef == 0 )
  67. {
  68. delete this;
  69. }
  70. return m_nRef;
  71. }
  72. HRESULT CWxAdoImpl::QueryInterface(REFIID refiid, void **ppvObject)
  73. {
  74. if (IID_IUnknown == refiid)
  75. {
  76. *ppvObject = this;
  77. }
  78. else if (IID_IWxAdoInterface == refiid)
  79. {
  80. *ppvObject = (IWxAdoInterface*)this;
  81. }
  82. else
  83. {
  84. *ppvObject = NULL;
  85. return E_NOINTERFACE;
  86. }
  87. ((IUnknown*)(*ppvObject))->AddRef();
  88. return NOERROR;
  89. }
  90. /************************************************************************/
  91. /* 函数:[9/25/2016 IT];
  92. /* 描述:;
  93. /* 参数:;
  94. /* [IN] :;
  95. /* [OUT] :;
  96. /* [IN/OUT] :;
  97. /* 返回:void;
  98. /* 注意:;
  99. /* 示例:;
  100. /*
  101. /* 修改:;
  102. /* 日期:;
  103. /* 内容:;
  104. /************************************************************************/
  105. void CWxAdoImpl::SolveDBError( IN CONST DWORD &dwError, IN LPVOID pDBConn)
  106. {
  107. switch(dwError)
  108. {
  109. //case SQL_ERROR://这个错误比较难精确判断问题;
  110. case ERROR_PIPE_NOT_CONNECTED:
  111. case WSAECONNRESET:
  112. case WSAECONNABORTED:
  113. {
  114. pAdoObj pObj = (pAdoObj)pDBConn;
  115. CWxAdoPool::GetInstance()->CloseBusyConnection(pObj);
  116. #if _DEBUG
  117. OutputDebugString(_T("关闭数据库连接\n"));
  118. #endif
  119. }
  120. break;
  121. default:
  122. break;
  123. }
  124. }
  125. //template<typename T>
  126. //BOOL CWxAdoImpl::GetFiedValue(IN _RecordsetPtr rst, IN LPCTSTR lpFiedName, T &value)
  127. //{
  128. // typeid(value);
  129. // _variant_t var = rst->GetCollect(lpFiedName);
  130. //switch(var.vt)
  131. //{
  132. //case VT_EMPTY:
  133. // break;
  134. //case VT_NULL:
  135. // break;
  136. //case VT_I2://2 byte signed int
  137. // value = var.iVal;
  138. // break;
  139. //case VT_I4://4 byte signed int
  140. // value = var.iVal;
  141. // break;
  142. //case VT_R4://4 byte real
  143. // value = var.fltVal;
  144. // break;
  145. //case VT_R8://8 byte real
  146. // value = var.dblVal;
  147. // break;
  148. //case VT_CY://currency
  149. // break;
  150. //case VT_DATE:
  151. // {
  152. // COleDateTime dt(var);
  153. // value = dt.Format(_T("%Y-%m-%d %H:%M:%S"));
  154. // }
  155. // break;
  156. //case VT_BSTR://OLE Automation string
  157. // value = _bstr_t(var.bstrVal);
  158. // break;
  159. //case VT_DISPATCH://IDispatch *
  160. // break;
  161. //case VT_ERROR://SCODE
  162. // break;
  163. //case VT_BOOL://True=-1, False=0
  164. // value = var.boolVal;
  165. // break;
  166. //case VT_VARIANT://VARIANT *
  167. // break;
  168. //case VT_UNKNOWN://IUnknown *
  169. // break;
  170. //case VT_DECIMAL://16 byte fixed point
  171. // break;
  172. //case VT_RECORD://user defined type
  173. // break;
  174. //case VT_I1: // signed char
  175. // value = var.pcVal;
  176. // break;
  177. //case VT_UI1://unsigned char
  178. // value = var.bVal;
  179. // break;
  180. //case VT_UI2://unsigned short
  181. // value = var.uiVal;
  182. // break;
  183. //case VT_UI4://unsigned long
  184. // value = var.uiVal;
  185. // break;
  186. //case VT_I8://signed 64-bit int
  187. // value = var.lVal;
  188. // break;
  189. //case VT_UI8://unsigned 64-bit int
  190. // value = var.ulVal;
  191. // break;
  192. //case VT_INT://signed machine int
  193. // value = var.intVal;
  194. // break;
  195. //case VT_UINT://unsigned machine int
  196. // value = var.uintVal;
  197. // break;
  198. //case VT_INT_PTR://signed machine register size width
  199. // break;
  200. //case VT_UINT_PTR://unsigned machine register size width
  201. // break;
  202. //case VT_VOID://C style void
  203. // break;
  204. //case VT_HRESULT://Standard return type
  205. // break;
  206. //case VT_PTR://pointer type
  207. // break;
  208. //case VT_SAFEARRAY://(use VT_ARRAY in VARIANT)
  209. // break;
  210. //case VT_CARRAY://C style array
  211. // break;
  212. //case VT_USERDEFINED://user defined type
  213. // break;
  214. //case VT_LPSTR://null terminated string
  215. // break;
  216. //case VT_LPWSTR://wide null terminated string
  217. // break;
  218. //case VT_FILETIME://FILETIME
  219. // break;
  220. //case VT_BLOB://Length prefixed bytes
  221. // break;
  222. //case VT_STREAM://Name of the stream follows
  223. // break;
  224. //case VT_STORAGE://Name of the storage follows
  225. // break;
  226. //case VT_STREAMED_OBJECT://Stream contains an object
  227. // break;
  228. //case VT_STORED_OBJECT://Storage contains an object
  229. // break;
  230. //case VT_VERSIONED_STREAM://Stream with a GUID version
  231. // break;
  232. //case VT_BLOB_OBJECT://Blob contains an object
  233. // break;
  234. //case VT_CF://Clipboard format
  235. // break;
  236. //case VT_CLSID://A Class ID
  237. // break;
  238. //case VT_VECTOR://simple counted array
  239. // break;
  240. //case VT_ARRAY://SAFEARRAY*
  241. // break;
  242. //case VT_BYREF://void* for local use
  243. // break;
  244. //case VT_BSTR_BLOB://Reserved for system use
  245. // break;
  246. //default:
  247. // value = var.iVal;
  248. //}
  249. // return TRUE;
  250. //}
  251. /************************************************************************/
  252. /* 函数:[9/25/2016 IT];
  253. /* 描述:;
  254. /* 参数:;
  255. /* [IN] :;
  256. /* [OUT] :;
  257. /* [IN/OUT] :;
  258. /* 返回:void;
  259. /* 注意:;
  260. /* 示例:;
  261. /*
  262. /* 修改:;
  263. /* 日期:;
  264. /* 内容:;
  265. /************************************************************************/
  266. DWORD CWxAdoImpl::InitializePool( IN LPCTSTR lpDBType, IN LPCTSTR lpDBSource, IN CONST DWORD &dwDBPort, IN LPCTSTR lpDBAccount, IN LPCTSTR lpPassWord, IN LPCTSTR lpDBName, IN CONST INT &nMinConn /* = 1 */, IN CONST INT &nMaxConn /* = 5 */ )
  267. {
  268. return CWxAdoPool::GetInstance()->InitializePool(lpDBType, lpDBSource, dwDBPort, lpDBAccount, lpPassWord, lpDBName, nMinConn, nMaxConn);
  269. }
  270. /************************************************************************/
  271. /* 函数:[9/25/2016 IT];
  272. /* 描述:;
  273. /* 参数:;
  274. /* [IN] :;
  275. /* [OUT] :;
  276. /* [IN/OUT] :;
  277. /* 返回:void;
  278. /* 注意:;
  279. /* 示例:;
  280. /*
  281. /* 修改:;
  282. /* 日期:;
  283. /* 内容:;
  284. /************************************************************************/
  285. void CWxAdoImpl::ReleasePool()
  286. {
  287. CWxAdoPool *pObj = CWxAdoPool::GetInstance();
  288. if ( pObj )
  289. {
  290. pObj->ReleasePool();
  291. delete pObj;
  292. pObj = NULL;
  293. }
  294. }
  295. /************************************************************************/
  296. /* 函数:[9/25/2016 IT];
  297. /* 描述:;
  298. /* 参数:;
  299. /* [IN] :;
  300. /* [OUT] :;
  301. /* [IN/OUT] :;
  302. /* 返回:void;
  303. /* 注意:;
  304. /* 示例:;
  305. /*
  306. /* 修改:;
  307. /* 日期:;
  308. /* 内容:;
  309. /************************************************************************/
  310. BOOL CWxAdoImpl::ExecuteSQL( IN LPCTSTR lpExcuteSQL, IN CONST DWORD &dwTimeOut /* = 30000 */ )
  311. {
  312. GETDBPTR(dwTimeOut);
  313. try
  314. {
  315. if ( lpExcuteSQL == NULL || pObj == NULL )
  316. return FALSE;
  317. pObj->pCommand->CommandText = _bstr_t(lpExcuteSQL);
  318. // 执行SQL语句,返回记录集
  319. pObj->pCommand->Execute(NULL, NULL, adCmdText);
  320. }
  321. catch (_com_error &e)
  322. {
  323. _bstr_t bstrSource(e.Source());
  324. _bstr_t bstrDescription(e.Description());
  325. SolveDBError(e.Error(), pObj);
  326. WriteTextLog(_T("SQL出错:%08lx,%s,%s,%s"), e.Error(), e.ErrorMessage(), (TCHAR*)bstrSource, (TCHAR*)bstrDescription);
  327. return FALSE;
  328. }
  329. return TRUE;
  330. }
  331. /************************************************************************/
  332. /* 函数:[9/25/2016 IT];
  333. /* 描述:;
  334. /* 参数:;
  335. /* [IN] :;
  336. /* [OUT] :;
  337. /* [IN/OUT] :;
  338. /* 返回:void;
  339. /* 注意:;
  340. /* 示例:;
  341. /*
  342. /* 修改:;
  343. /* 日期:;
  344. /* 内容:;
  345. /************************************************************************/
  346. BOOL CWxAdoImpl::IsUserExist( IN LPCTSTR lpPhone, IN LPCTSTR lpPassword, OUT LPVOID lpOutValue,IN CONST DWORD &dwTimeOut /* = 3000 */ )
  347. {
  348. GETDBPTR(dwTimeOut);
  349. #if 0
  350. try
  351. {
  352. if ( lpPhone == NULL || lpPassword == NULL || pObj == NULL)
  353. return FALSE;
  354. CString strSql = _T("");
  355. strSql.Format(_T("select csr_id,csr_name,csr_phone,csr_gender,csr_password,csr_old_phone,csr_vcode,vcode_expiry_time,enable from customer where csr_phone = %s"), lpPhone);//用于是否转相片;
  356. pObj->pCommand->CommandText = _bstr_t(strSql);
  357. // 执行SQL语句,返回记录集
  358. _RecordsetPtr rst = pObj->pCommand->Execute(NULL, NULL, adCmdText);
  359. tb_customer &customer = *(tb_customer*)lpOutValue;
  360. if(!rst->adoEOF)
  361. {
  362. customer.set_customer_id(_bstr_t(rst->GetCollect(_T("csr_id")).bstrVal));
  363. customer.set_customer_name(_bstr_t(rst->GetCollect(_T("csr_name")).bstrVal));
  364. customer.set_customer_gender(rst->GetCollect(_T("csr_gender")).boolVal == VARIANT_TRUE ? TRUE : FALSE);
  365. customer.set_customer_password(_bstr_t(rst->GetCollect(_T("csr_password")).bstrVal));
  366. customer.set_customer_phone(_bstr_t(rst->GetCollect(_T("csr_phone")).bstrVal));
  367. customer.set_customer_old_phone(_bstr_t(rst->GetCollect(_T("csr_old_phone")).bstrVal));
  368. customer.set_customer_vcode(_bstr_t(rst->GetCollect(_T("csr_vcode")).bstrVal));
  369. _variant_t var = rst->GetCollect(_T("vcode_expiry_time"));
  370. if (var.vt == VT_EMPTY || var.vt == VT_NULL)
  371. customer.set_customer_vcode_expiry_time(_T(""));
  372. else
  373. {
  374. COleDateTime dt(var);
  375. customer.set_customer_vcode_expiry_time(dt.Format(_T("%Y-%m-%d %H:%M:%S")));
  376. }
  377. customer.set_customer_enable(rst->GetCollect(_T("enable")).boolVal == VARIANT_TRUE ? TRUE : FALSE);
  378. }
  379. rst->Close();
  380. }
  381. catch (_com_error &e)
  382. {
  383. _bstr_t bstrSource(e.Source());
  384. _bstr_t bstrDescription(e.Description());
  385. SolveDBError(e.Error(), pObj);
  386. WriteTextLog(_T("SQL出错:%08lx,%s,%s,%s"), e.Error(), e.ErrorMessage(), (TCHAR*)bstrSource, (TCHAR*)bstrDescription);
  387. return FALSE;
  388. }
  389. #else // 参数化查询;
  390. try
  391. {
  392. if (lpPhone == NULL || lpPassword == NULL || pObj == NULL)
  393. return FALSE;
  394. AddSTRParameters(pObj->pCommand, _T("@csr_phone"), lpPhone);
  395. pObj->pCommand->CommandText = _bstr_t(_T("select csr_id,csr_name,csr_phone,csr_gender,csr_password,csr_old_phone,csr_vcode,vcode_expiry_time,enable from customer where csr_phone = ?"));
  396. // 执行SQL语句,返回记录集
  397. _RecordsetPtr rst = pObj->pCommand->Execute(NULL, NULL, adCmdText);
  398. tb_customer &customer = *(tb_customer*)lpOutValue;
  399. if (!rst->adoEOF)
  400. {
  401. customer.set_customer_id(_bstr_t(rst->GetCollect(_T("csr_id")).bstrVal));
  402. customer.set_customer_name(_bstr_t(rst->GetCollect(_T("csr_name")).bstrVal));
  403. customer.set_customer_gender(rst->GetCollect(_T("csr_gender")).boolVal == VARIANT_TRUE ? TRUE : FALSE);
  404. customer.set_customer_password(_bstr_t(rst->GetCollect(_T("csr_password")).bstrVal));
  405. customer.set_customer_phone(_bstr_t(rst->GetCollect(_T("csr_phone")).bstrVal));
  406. customer.set_customer_old_phone(_bstr_t(rst->GetCollect(_T("csr_old_phone")).bstrVal));
  407. customer.set_customer_vcode(_bstr_t(rst->GetCollect(_T("csr_vcode")).bstrVal));
  408. _variant_t var = rst->GetCollect(_T("vcode_expiry_time"));
  409. if (var.vt == VT_EMPTY || var.vt == VT_NULL)
  410. customer.set_customer_vcode_expiry_time(_T(""));
  411. else
  412. {
  413. COleDateTime dt(var);
  414. customer.set_customer_vcode_expiry_time(dt.Format(_T("%Y-%m-%d %H:%M:%S")));
  415. }
  416. customer.set_customer_enable(rst->GetCollect(_T("enable")).boolVal == VARIANT_TRUE ? TRUE : FALSE);
  417. }
  418. rst->Close();
  419. pObj->pCommand->Parameters->Release();
  420. }
  421. catch (_com_error &e)
  422. {
  423. _bstr_t bstrSource(e.Source());
  424. _bstr_t bstrDescription(e.Description());
  425. SolveDBError(e.Error(), pObj);
  426. WriteTextLog(_T("SQL出错:%08lx,%s,%s,%s"), e.Error(), e.ErrorMessage(), (TCHAR*)bstrSource, (TCHAR*)bstrDescription);
  427. return FALSE;
  428. }
  429. #endif
  430. return TRUE;
  431. }
  432. INT CWxAdoImpl::QueryUserDetail(IN LPCTSTR lpPhone, IN LPVOID lpOutValue, IN const DWORD & dwTimeOut)
  433. {
  434. GETDBPTR(dwTimeOut);
  435. #if 0
  436. try
  437. {
  438. if (lpPhone == NULL || pObj == NULL)
  439. return FALSE;
  440. CString strSql = _T("");
  441. strSql.Format(_T("select csr_id,csr_name,csr_phone,csr_gender,csr_password,csr_old_phone,csr_vcode,vcode_expiry_time,enable from customer where csr_phone = %s"), lpPhone);//用于是否转相片;
  442. pObj->pCommand->CommandText = _bstr_t(strSql);
  443. // 执行SQL语句,返回记录集
  444. _RecordsetPtr rst = pObj->pCommand->Execute(NULL, NULL, adCmdText);
  445. tb_customer &customer = *(tb_customer*)lpOutValue;
  446. if (!rst->adoEOF)
  447. {
  448. customer.set_customer_id(_bstr_t(rst->GetCollect(_T("csr_id")).bstrVal));
  449. customer.set_customer_name(_bstr_t(rst->GetCollect(_T("csr_name")).bstrVal));
  450. customer.set_customer_gender(rst->GetCollect(_T("csr_gender")).boolVal == VARIANT_TRUE ? TRUE : FALSE);
  451. customer.set_customer_password(_bstr_t(rst->GetCollect(_T("csr_password")).bstrVal));
  452. customer.set_customer_phone(_bstr_t(rst->GetCollect(_T("csr_phone")).bstrVal));
  453. customer.set_customer_old_phone(_bstr_t(rst->GetCollect(_T("csr_old_phone")).bstrVal));
  454. customer.set_customer_vcode(_bstr_t(rst->GetCollect(_T("csr_vcode")).bstrVal));
  455. _variant_t var = rst->GetCollect(_T("vcode_expiry_time"));
  456. if (var.vt == VT_EMPTY || var.vt == VT_NULL)
  457. customer.set_customer_vcode_expiry_time(_T(""));
  458. else
  459. {
  460. COleDateTime dt(var);
  461. customer.set_customer_vcode_expiry_time(dt.Format(_T("%Y-%m-%d %H:%M:%S")));
  462. }
  463. customer.set_customer_enable(rst->GetCollect(_T("enable")).boolVal == VARIANT_TRUE ? TRUE : FALSE);
  464. }
  465. rst->Close();
  466. }
  467. catch (_com_error &e)
  468. {
  469. _bstr_t bstrSource(e.Source());
  470. _bstr_t bstrDescription(e.Description());
  471. SolveDBError(e.Error(), pObj);
  472. WriteTextLog(_T("SQL出错:%08lx,%s,%s,%s"), e.Error(), e.ErrorMessage(), (TCHAR*)bstrSource, (TCHAR*)bstrDescription);
  473. return FALSE;
  474. }
  475. #else // 参数化查询;
  476. try
  477. {
  478. if (lpPhone == NULL || pObj == NULL)
  479. return FALSE;
  480. AddSTRParameters(pObj->pCommand, _T("@csr_phone"), lpPhone);
  481. pObj->pCommand->CommandText = _bstr_t(_T("select csr_id,csr_name,csr_phone,csr_gender,csr_password,csr_old_phone,csr_vcode,vcode_expiry_time,enable from customer where csr_phone = ?"));
  482. // 执行SQL语句,返回记录集
  483. _RecordsetPtr rst = pObj->pCommand->Execute(NULL, NULL, adCmdText);
  484. tb_customer &customer = *(tb_customer*)lpOutValue;
  485. if (!rst->adoEOF)
  486. {
  487. customer.set_customer_id(_bstr_t(rst->GetCollect(_T("csr_id")).bstrVal));
  488. customer.set_customer_name(_bstr_t(rst->GetCollect(_T("csr_name")).bstrVal));
  489. customer.set_customer_gender(rst->GetCollect(_T("csr_gender")).boolVal == VARIANT_TRUE ? TRUE : FALSE);
  490. customer.set_customer_password(_bstr_t(rst->GetCollect(_T("csr_password")).bstrVal));
  491. customer.set_customer_phone(_bstr_t(rst->GetCollect(_T("csr_phone")).bstrVal));
  492. customer.set_customer_old_phone(_bstr_t(rst->GetCollect(_T("csr_old_phone")).bstrVal));
  493. customer.set_customer_vcode(_bstr_t(rst->GetCollect(_T("csr_vcode")).bstrVal));
  494. _variant_t var = rst->GetCollect(_T("vcode_expiry_time"));
  495. if (var.vt == VT_EMPTY || var.vt == VT_NULL)
  496. customer.set_customer_vcode_expiry_time(_T(""));
  497. else
  498. {
  499. COleDateTime dt(var);
  500. customer.set_customer_vcode_expiry_time(dt.Format(_T("%Y-%m-%d %H:%M:%S")));
  501. }
  502. customer.set_customer_enable(rst->GetCollect(_T("enable")).boolVal == VARIANT_TRUE ? TRUE : FALSE);
  503. }
  504. rst->Close();
  505. pObj->pCommand->Parameters->Release();
  506. }
  507. catch (_com_error &e)
  508. {
  509. _bstr_t bstrSource(e.Source());
  510. _bstr_t bstrDescription(e.Description());
  511. SolveDBError(e.Error(), pObj);
  512. WriteTextLog(_T("SQL出错:%08lx,%s,%s,%s"), e.Error(), e.ErrorMessage(), (TCHAR*)bstrSource, (TCHAR*)bstrDescription);
  513. return FALSE;
  514. }
  515. #endif
  516. return TRUE;
  517. }
  518. INT CWxAdoImpl::QueryRecordOfType(IN LPCTSTR lpCustomerId, IN LPVOID lpOutValue, IN const DWORD & dwTimeOut)
  519. {
  520. GETDBPTR(dwTimeOut);
  521. try
  522. {
  523. if (lpCustomerId == NULL )
  524. return FALSE;
  525. AddSTRParameters(pObj->pCommand, _T("@csr_id"), lpCustomerId);
  526. pObj->pCommand->CommandText = _bstr_t(_T("select csr_id,type_id,type_name,type_gen_time from reply_type where csr_id = ?"));
  527. // 执行SQL语句,返回记录集
  528. _RecordsetPtr rst = pObj->pCommand->Execute(NULL, NULL, adCmdText);
  529. rec_type &listType = *(rec_type*)lpOutValue;
  530. while (!rst->adoEOF)
  531. {
  532. tb_type *pTypeObj = listType.add_types();
  533. pTypeObj->set_customer_id(_bstr_t(rst->GetCollect(_T("csr_id")).bstrVal));
  534. pTypeObj->set_type_id(_bstr_t(rst->GetCollect(_T("type_id")).bstrVal));
  535. pTypeObj->set_type_name(_bstr_t(rst->GetCollect(_T("type_name")).bstrVal));
  536. _variant_t var = rst->GetCollect(_T("type_gen_time"));
  537. if (var.vt == VT_EMPTY || var.vt == VT_NULL)
  538. pTypeObj->set_type_gen_time(_T(""));
  539. else
  540. {
  541. COleDateTime dt(var);
  542. pTypeObj->set_type_gen_time(dt.Format(_T("%Y-%m-%d %H:%M:%S")));
  543. }
  544. }
  545. rst->Close();
  546. pObj->pCommand->Parameters->Release();
  547. }
  548. catch (_com_error &e)
  549. {
  550. _bstr_t bstrSource(e.Source());
  551. _bstr_t bstrDescription(e.Description());
  552. SolveDBError(e.Error(), pObj);
  553. WriteTextLog(_T("SQL出错:%08lx,%s,%s,%s"), e.Error(), e.ErrorMessage(), (TCHAR*)bstrSource, (TCHAR*)bstrDescription);
  554. return FALSE;
  555. }
  556. return 0;
  557. }
  558. INT CWxAdoImpl::QueryRecordOfReply(IN LPCTSTR lpCustomerId, IN LPCTSTR lpTypeId, IN LPVOID lpOutValue, IN const DWORD & dwTimeOut)
  559. {
  560. GETDBPTR(dwTimeOut);
  561. try
  562. {
  563. if (lpCustomerId == NULL || lpTypeId == NULL)
  564. return FALSE;
  565. AddSTRParameters(pObj->pCommand, _T("@csr_id"), lpCustomerId);
  566. AddSTRParameters(pObj->pCommand, _T("@type_id"), lpTypeId);
  567. pObj->pCommand->CommandText = _bstr_t(_T("select csr_id,type_id,reply_id,reply_name,reply_content,reply_gen_time from reply where csr_id = ? and type_id = ?"));
  568. // 执行SQL语句,返回记录集
  569. _RecordsetPtr rst = pObj->pCommand->Execute(NULL, NULL, adCmdText);
  570. rec_reply &listReply = *(rec_reply*)lpOutValue;
  571. while (!rst->adoEOF)
  572. {
  573. tb_reply *pReplyObj = listReply.add_replys();
  574. pReplyObj->set_customer_id(_bstr_t(rst->GetCollect(_T("csr_id")).bstrVal));
  575. pReplyObj->set_type_id(_bstr_t(rst->GetCollect(_T("type_id")).bstrVal));
  576. pReplyObj->set_reply_id(_bstr_t(rst->GetCollect(_T("reply_id")).bstrVal));
  577. pReplyObj->set_reply_name(_bstr_t(rst->GetCollect(_T("reply_name")).bstrVal));
  578. pReplyObj->set_reply_content(_bstr_t(rst->GetCollect(_T("reply_content")).bstrVal));
  579. _variant_t var = rst->GetCollect(_T("reply_gen_time"));
  580. if (var.vt == VT_EMPTY || var.vt == VT_NULL)
  581. pReplyObj->set_reply_gen_time(_T(""));
  582. else
  583. {
  584. COleDateTime dt(var);
  585. pReplyObj->set_reply_gen_time(dt.Format(_T("%Y-%m-%d %H:%M:%S")));
  586. }
  587. }
  588. rst->Close();
  589. pObj->pCommand->Parameters->Release();
  590. }
  591. catch (_com_error &e)
  592. {
  593. _bstr_t bstrSource(e.Source());
  594. _bstr_t bstrDescription(e.Description());
  595. SolveDBError(e.Error(), pObj);
  596. WriteTextLog(_T("SQL出错:%08lx,%s,%s,%s"), e.Error(), e.ErrorMessage(), (TCHAR*)bstrSource, (TCHAR*)bstrDescription);
  597. return FALSE;
  598. }
  599. return 0;
  600. }
  601. BOOL CWxAdoImpl::AddCustomer(IN LPVOID lpCustomerInfo, IN const DWORD & dwTimeOut)
  602. {
  603. if (lpCustomerInfo == NULL)
  604. return FALSE;
  605. GETDBPTR(dwTimeOut);
  606. tb_customer &customer = *(tb_customer*)lpCustomerInfo;
  607. try
  608. {
  609. #if 1
  610. CString strSql = _T("");
  611. customer.set_customer_id(GetUID().c_str());
  612. if (customer.customer_vcode_expiry_time().size() == 0)
  613. customer.set_customer_vcode_expiry_time(_T("0000-00-00 00:00:00"));
  614. strSql.Format(_T("INSERT INTO customer(csr_id,csr_name,csr_phone,csr_gender,csr_password,csr_old_phone,csr_vcode,vcode_expiry_time,enable) "
  615. "VALUES('%s','%s','%s',%d,'%s','%s','%s','%s',%d) "),
  616. customer.customer_id().c_str(),
  617. customer.customer_name().c_str(),
  618. customer.customer_phone().c_str(),
  619. customer.customer_gender(),
  620. customer.customer_password().c_str(),
  621. customer.customer_old_phone().c_str(),
  622. customer.customer_vcode().c_str(),
  623. customer.customer_vcode_expiry_time().c_str(),
  624. customer.customer_enable()
  625. );
  626. pObj->pCommand->CommandText = _bstr_t(strSql);
  627. // 执行SQL语句,返回记录集
  628. pObj->pCommand->Execute(NULL, NULL, adCmdText);
  629. #else
  630. // 出错:对象关闭时,不允许操作;
  631. AddSTRParameters(pObj->pCommand, _T("@csr_id"), customer.customer_id().c_str());
  632. AddSTRParameters(pObj->pCommand, _T("@csr_name"), customer.customer_name().c_str());
  633. AddSTRParameters(pObj->pCommand, _T("@csr_phone"), customer.customer_phone().c_str());
  634. AddBoolParameters(pObj->pCommand, _T("@csr_gender"), BOOL(customer.customer_gender()));
  635. AddSTRParameters(pObj->pCommand, _T("@csr_password"), customer.customer_password().c_str());
  636. AddSTRParameters(pObj->pCommand, _T("@csr_old_phone"), customer.customer_old_phone().c_str());
  637. AddSTRParameters(pObj->pCommand, _T("@csr_vcode"), customer.customer_vcode().c_str());
  638. AddSTRParameters(pObj->pCommand, _T("@vcode_expiry_time"), customer.customer_vcode_expiry_time().c_str());
  639. AddBoolParameters(pObj->pCommand, _T("@enable"), customer.customer_enable());
  640. pObj->pCommand->CommandText = _bstr_t(_T("INSERT INTO customer(csr_id, csr_name, csr_phone, csr_gender, csr_password, csr_old_phone, csr_vcode, vcode_expiry_time, enable) VALUES(?,?,?,?,?,?,?,?,?)"));
  641. // 执行SQL语句,返回记录集
  642. _RecordsetPtr rst = pObj->pCommand->Execute(NULL, NULL, adCmdText);
  643. if (!rst->adoEOF)
  644. {
  645. ;
  646. }
  647. rst->Close();
  648. pObj->pCommand->Parameters->Release();
  649. #endif
  650. }
  651. catch (_com_error &e)
  652. {
  653. _bstr_t bstrSource(e.Source());
  654. _bstr_t bstrDescription(e.Description());
  655. SolveDBError(e.Error(), pObj);
  656. WriteTextLog(_T("SQL出错:%08lx,%s,%s,%s"), e.Error(), e.ErrorMessage(), (TCHAR*)bstrSource, (TCHAR*)bstrDescription);
  657. return FALSE;
  658. }
  659. return TRUE;
  660. }
  661. BOOL CWxAdoImpl::AddType(IN LPVOID lpTypeInfo, IN const DWORD & dwTimeOut)
  662. {
  663. if (lpTypeInfo == NULL)
  664. return FALSE;
  665. GETDBPTR(dwTimeOut);
  666. tb_type &type = *(tb_type*)lpTypeInfo;
  667. try
  668. {
  669. #if 1
  670. CString strSql = _T("");
  671. type.set_type_id(GetUID().c_str());
  672. if (type.type_gen_time().size() == 0)
  673. type.set_type_gen_time(GetCurrentLocalTime().c_str());
  674. strSql.Format(_T("INSERT INTO reply_type(csr_id,type_id,type_name,type_gen_time) "
  675. "VALUES('%s','%s','%s','%s') "),
  676. type.customer_id().c_str(),
  677. type.type_id().c_str(),
  678. type.type_name().c_str(),
  679. type.type_gen_time().c_str()
  680. );
  681. pObj->pCommand->CommandText = _bstr_t(strSql);
  682. // 执行SQL语句,返回记录集
  683. _RecordsetPtr rst = pObj->pCommand->Execute(NULL, NULL, adCmdText);
  684. if (!rst->adoEOF)
  685. {
  686. ;
  687. }
  688. rst->Close();
  689. #else
  690. // 出错:对象关闭时,不允许操作;
  691. AddSTRParameters(pObj->pCommand, _T("@csr_id"), type.customer_id().c_str());
  692. AddSTRParameters(pObj->pCommand, _T("@type_id"), GetUID().c_str());
  693. AddSTRParameters(pObj->pCommand, _T("@type_name"), type.type_name().c_str());
  694. AddSTRParameters(pObj->pCommand, _T("@type_gen_time"), type.type_gen_time().c_str());
  695. pObj->pCommand->CommandText = _bstr_t(_T("INSERT INTO reply_type(csr_id,type_id,type_name,type_gen_time) VALUES(?,?,?,?)"));
  696. // 执行SQL语句,返回记录集
  697. _RecordsetPtr rst = pObj->pCommand->Execute(NULL, NULL, adCmdText);
  698. if (!rst->adoEOF)
  699. {
  700. ;
  701. }
  702. rst->Close();
  703. pObj->pCommand->Parameters->Release();
  704. #endif
  705. }
  706. catch (_com_error &e)
  707. {
  708. _bstr_t bstrSource(e.Source());
  709. _bstr_t bstrDescription(e.Description());
  710. SolveDBError(e.Error(), pObj);
  711. WriteTextLog(_T("SQL出错:%08lx,%s,%s,%s"), e.Error(), e.ErrorMessage(), (TCHAR*)bstrSource, (TCHAR*)bstrDescription);
  712. return FALSE;
  713. }
  714. return TRUE;
  715. }
  716. BOOL CWxAdoImpl::AddReply(IN LPVOID lpReplyInfo, IN const DWORD & dwTimeOut)
  717. {
  718. if (lpReplyInfo == NULL)
  719. return FALSE;
  720. GETDBPTR(dwTimeOut);
  721. tb_reply &reply = *(tb_reply*)lpReplyInfo;
  722. try
  723. {
  724. #if 1
  725. CString strSql = _T("");
  726. reply.set_reply_id(GetUID().c_str());
  727. if (reply.reply_gen_time().size() == 0)
  728. reply.set_reply_gen_time(GetCurrentLocalTime().c_str());
  729. strSql.Format(_T("INSERT INTO reply(csr_id,type_id,reply_id,reply_name,reply_content,reply_gen_time) "
  730. "VALUES('%s','%s','%s','%s','%s','%s') "),
  731. reply.customer_id().c_str(),
  732. reply.type_id().c_str(),
  733. reply.reply_id().c_str(),
  734. reply.reply_name().c_str(),
  735. reply.reply_content().c_str(),
  736. reply.reply_gen_time().c_str());
  737. pObj->pCommand->CommandText = _bstr_t(strSql);
  738. // 执行SQL语句,返回记录集
  739. _RecordsetPtr rst = pObj->pCommand->Execute(NULL, NULL, adCmdText);
  740. if (!rst->adoEOF)
  741. {
  742. ;
  743. }
  744. rst->Close();
  745. #else
  746. // 出错:对象关闭时,不允许操作;
  747. AddSTRParameters(pObj->pCommand, _T("@csr_id"), reply.customer_id().c_str());
  748. AddSTRParameters(pObj->pCommand, _T("@type_id"), reply.type_id().c_str());
  749. AddSTRParameters(pObj->pCommand, _T("@reply_id"), GetUID().c_str());
  750. AddBoolParameters(pObj->pCommand, _T("@reply_name"), reply.reply_name().c_str());
  751. AddSTRParameters(pObj->pCommand, _T("@reply_content"), reply.reply_content().c_str());
  752. AddSTRParameters(pObj->pCommand, _T("@reply_gen_time"), reply.reply_gen_time().c_str());
  753. pObj->pCommand->CommandText = _bstr_t(_T("INSERT INTO reply(csr_id,type_id,reply_id,reply_name,reply_content,reply_gen_time) VALUES(?,?,?,?,?,?)"));
  754. // 执行SQL语句,返回记录集
  755. _RecordsetPtr rst = pObj->pCommand->Execute(NULL, NULL, adCmdText);
  756. if (!rst->adoEOF)
  757. {
  758. ;
  759. }
  760. rst->Close();
  761. pObj->pCommand->Parameters->Release();
  762. #endif
  763. }
  764. catch (_com_error &e)
  765. {
  766. _bstr_t bstrSource(e.Source());
  767. _bstr_t bstrDescription(e.Description());
  768. SolveDBError(e.Error(), pObj);
  769. WriteTextLog(_T("SQL出错:%08lx,%s,%s,%s"), e.Error(), e.ErrorMessage(), (TCHAR*)bstrSource, (TCHAR*)bstrDescription);
  770. return FALSE;
  771. }
  772. return TRUE;
  773. }
  774. BOOL CWxAdoImpl::UpdateCustomer(IN LPVOID lpCustomerInfo, IN const DWORD & dwTimeOut)
  775. {
  776. return 0;
  777. }