SaleDlg.cpp
上传用户:tyjx315
上传日期:2015-01-18
资源大小:1685k
文件大小:4k
源码类别:

百货/超市行业

开发平台:

Visual C++

  1. // SaleDlg.cpp : implementation file
  2. //
  3. #include "stdafx.h"
  4. #include "SuperMarket.h"
  5. #include "SaleDlg.h"
  6. #include "afxdb.h"
  7. #ifdef _DEBUG
  8. #define new DEBUG_NEW
  9. #undef THIS_FILE
  10. static char THIS_FILE[] = __FILE__;
  11. #endif
  12. /////////////////////////////////////////////////////////////////////////////
  13. // CSaleDlg dialog
  14. CSaleDlg::CSaleDlg(CWnd* pParent /*=NULL*/)
  15. : CDialog(CSaleDlg::IDD, pParent)
  16. {
  17. //{{AFX_DATA_INIT(CSaleDlg)
  18. m_number = _T("");
  19. m_count = 1;
  20. m_time = 0;
  21. total = 0;
  22. add_time = 0;
  23. //}}AFX_DATA_INIT
  24. }
  25. void CSaleDlg::DoDataExchange(CDataExchange* pDX)
  26. {
  27. CDialog::DoDataExchange(pDX);
  28. //{{AFX_DATA_MAP(CSaleDlg)
  29. DDX_Control(pDX, IDC_LIST1, m_list);
  30. DDX_Text(pDX, IDC_EDIT1, m_number);
  31. DDX_Text(pDX, IDC_EDIT2, m_count);
  32. DDX_DateTimeCtrl(pDX, IDC_DATETIMEPICKER1, m_time);
  33. //}}AFX_DATA_MAP
  34. }
  35. BEGIN_MESSAGE_MAP(CSaleDlg, CDialog)
  36. //{{AFX_MSG_MAP(CSaleDlg)
  37. ON_BN_CLICKED(IDC_ADD, OnAdd)
  38. //}}AFX_MSG_MAP
  39. END_MESSAGE_MAP()
  40. /////////////////////////////////////////////////////////////////////////////
  41. // CSaleDlg message handlers
  42. void CSaleDlg::OnAdd() 
  43. {
  44. // TODO: Add your control notification handler code here
  45.  
  46.  UpdateData();
  47.      int count;
  48.      CString str0,str1,str2,str3,str4,strSQL;  
  49.  CDatabase dbTemp;
  50.  
  51.  dbTemp.OpenEx("Driver={Microsoft Access Driver (*.mdb)};DBQ=超市管理数据库.mdb;"); 
  52.      CRecordset  rs( &dbTemp); 
  53.  rs.Open(AFX_DB_USE_DEFAULT_TYPE,"select * From 商品信息 where 商品编号='"+m_number+"'");
  54.  rs.GetFieldValue((short)0,str0);   //从商品信息表中读入商品信息
  55.  rs.GetFieldValue((short)1,str1);
  56.  rs.GetFieldValue((short)2,str2);
  57.  rs.GetFieldValue((short)4,str4);  
  58.  
  59.  count=atoi(str4);     //更新库存量
  60.  count=count-m_count;
  61.  str4.Format("%d",count);
  62.  strSQL="update 商品信息 set 库存量='"+str4+"' where 商品编号='"+m_number+"'"; 
  63.  dbTemp.ExecuteSQL(strSQL);
  64.  rs.Close();
  65.  
  66.  price = atof(str2);   
  67.  total=total+price*m_count;
  68.  str3.Format("%d",m_count);  //显示到窗口
  69.  m_list.InsertItem   (add_time,str0);//写第一列;   
  70.  m_list.SetItemText   (add_time,1,str1);//第二列;   
  71.  m_list.SetItemText   (add_time,2,str2);//第三列;   
  72.  m_list.SetItemText   (add_time,3,str3);//第四列;  
  73.  add_time = add_time + 1;
  74.  UpdateData(false);
  75. }
  76. void CSaleDlg::OnOK() 
  77. {
  78. // TODO: Add extra validation here
  79. CString str0,strSQL,time,str1;
  80. int sale_number;
  81. str0.Format("%.2f",total); //窗口中显示总价
  82. MessageBox("总价:"+str0);
  83. CDatabase dbTemp;
  84.  
  85. dbTemp.OpenEx("Driver={Microsoft Access Driver (*.mdb)};DBQ=超市管理数据库.mdb;"); 
  86.     CRecordset rs( &dbTemp);
  87. rs.Open(AFX_DB_USE_DEFAULT_TYPE,"select * From 销售表");//把一次销售添加到销售表中
  88. time.Format("%d-%d-%d",m_time.GetYear(),m_time.GetMonth(),m_time.GetDay()); //获取当天时间
  89. sale_number=(int)rs.GetRecordCount();
  90. while(!rs.IsEOF())
  91. {
  92.       sale_number++;
  93.   rs.MoveNext();
  94. }  
  95. str1.Format("%d",sale_number);
  96. strSQL="insert into 销售表 values('"+str1+"','"+str0+"','"+time+"')"; 
  97. dbTemp.ExecuteSQL(strSQL);  
  98. rs.Close();
  99. total = 0;
  100. m_list.DeleteAllItems();
  101. m_number="";
  102. m_count =1;
  103. add_time = 0;
  104. UpdateData(false);
  105. // CDialog::OnOK();
  106. }
  107. BOOL CSaleDlg::OnInitDialog() 
  108. {
  109. CDialog::OnInitDialog();
  110. // TODO: Add extra initialization here
  111. CTime temptime;
  112. m_time = temptime.GetCurrentTime();
  113. UpdateData(false);
  114.    
  115. // Set the icon for this dialog.  The framework does this automatically
  116. //  when the application's main window is not a dialog
  117. // m_list.SetExtendedStyle(LVS_EX_GRIDLINES);
  118. m_list.SetExtendedStyle(LVS_EX_GRIDLINES|LVS_EX_FULLROWSELECT|LVS_EX_ONECLICKACTIVATE);
  119. m_list.InsertColumn(0,"编号",LVCFMT_LEFT,80);
  120. m_list.InsertColumn(1,"名称",LVCFMT_LEFT,145);
  121. m_list.InsertColumn(2,"价格",LVCFMT_LEFT,80);
  122. m_list.InsertColumn(3,"数量",LVCFMT_LEFT,100);
  123.  
  124. UpdateData();
  125. return TRUE;  // return TRUE unless you set the focus to a control
  126.               // EXCEPTION: OCX Property Pages should return FALSE
  127. }