remote_commodity_problem.cpp 3.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104
  1. // remote_commodity_problem.h : CTblRemote_Commodity_Problem 类的实现
  2. // CTblRemote_Commodity_Problem 实现
  3. // 代码生成在 2017年09月30日, 14:23
  4. #include "stdafx.h"
  5. #include "remote_commodity_problem.h"
  6. IMPLEMENT_DYNAMIC(CTblRemote_Commodity_Problem, CRecordset)
  7. CTblRemote_Commodity_Problem::CTblRemote_Commodity_Problem(CDatabase* pdb)
  8. : CRecordset(pdb)
  9. {
  10. m_problem_id = 0;
  11. m_commodity_id = _T("");
  12. m_problem_name = _T("");
  13. m_problem_remark = _T("");
  14. m_nFields = 4;
  15. m_nDefaultType = dynaset;
  16. }
  17. //#error 安全问题:连接字符串可能包含密码。
  18. // 此连接字符串中可能包含明文密码和/或其他重要
  19. // 信息。请在查看完此连接字符串并找到所有与安全
  20. // 有关的问题后移除 #error。可能需要将此密码存
  21. // 储为其他格式或使用其他的用户身份验证。
  22. CString CTblRemote_Commodity_Problem::GetDefaultConnect()
  23. {
  24. return _T("DSN=internal;Trusted_Connection=Yes;APP=Microsoft\x00ae Visual Studio\x00ae 2008;WSID=DESKTOP-5ILISFF;DATABASE=Internal;");
  25. }
  26. CString CTblRemote_Commodity_Problem::GetDefaultSQL()
  27. {
  28. return _T("[dbo].[remote_commodity_problem]");
  29. }
  30. void CTblRemote_Commodity_Problem::DoFieldExchange(CFieldExchange* pFX)
  31. {
  32. pFX->SetFieldType(CFieldExchange::outputColumn);
  33. // RFX_Text() 和 RFX_Int() 这类宏依赖的是
  34. // 成员变量的类型,而不是数据库字段的类型。
  35. // ODBC 尝试自动将列值转换为所请求的类型
  36. RFX_Long(pFX, _T("[problem_id]"), m_problem_id);
  37. RFX_Text(pFX, _T("[commodity_id]"), m_commodity_id);
  38. RFX_Text(pFX, _T("[problem_name]"), m_problem_name);
  39. RFX_Text(pFX, _T("[problem_remark]"), m_problem_remark);
  40. }
  41. /////////////////////////////////////////////////////////////////////////////
  42. // CTblRemote_Commodity_Problem 诊断
  43. #ifdef _DEBUG
  44. void CTblRemote_Commodity_Problem::AssertValid() const
  45. {
  46. CRecordset::AssertValid();
  47. }
  48. void CTblRemote_Commodity_Problem::Dump(CDumpContext& dc) const
  49. {
  50. CRecordset::Dump(dc);
  51. }
  52. #endif //_DEBUG
  53. void CTblRemote_Commodity_Problem::GetReturnValue(IN CArray<CStringArray, CStringArray>& AryValue, IN CDatabase* pDatabase, IN CString strFilter)
  54. {
  55. CRecordset tagSet(pDatabase);
  56. CString strTemp = _T("select count(*) as cot from [remote_commodity_problem]");
  57. if ( !strFilter.IsEmpty() )
  58. strTemp += _T(" where ") + strFilter;
  59. tagSet.Open(CRecordset::forwardOnly, strTemp);
  60. tagSet.GetFieldValue(_T("cot"), strTemp);
  61. tagSet.Close();
  62. // 2.查询指定条件记录;
  63. DWORD dwCount = atol(strTemp);
  64. DWORD dwOldSize = AryValue.GetSize();
  65. AryValue.SetSize(dwOldSize + dwCount, 1);
  66. DWORD dwIndex = dwOldSize == 0 ? 0 : dwOldSize - 1;
  67. CTblRemote_Commodity_Problem tagRst(pDatabase);
  68. if ( !strFilter.IsEmpty() )
  69. tagRst.m_strFilter = strFilter;
  70. tagRst.Open();
  71. while( !tagRst.IsEOF() )
  72. {
  73. AryValue.ElementAt(dwIndex).RemoveAll();
  74. strTemp.Format(_T("%d"),tagRst.m_problem_id);
  75. AryValue.ElementAt(dwIndex).Add(strTemp); // 0.注释;
  76. AryValue.ElementAt(dwIndex).Add(tagRst.m_commodity_id); // 1.注释;
  77. AryValue.ElementAt(dwIndex).Add(tagRst.m_problem_name); // 2.注释;
  78. AryValue.ElementAt(dwIndex).Add(tagRst.m_problem_remark); // 3.注释;
  79. dwIndex++;
  80. if ( AryValue.GetSize() <= dwIndex )
  81. break;
  82. tagRst.MoveNext();
  83. }
  84. AryValue.SetSize(dwIndex,1);
  85. tagRst.Close();
  86. }