博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
商店管理系统源代码(三)
阅读量:6648 次
发布时间:2019-06-25

本文共 9682 字,大约阅读时间需要 32 分钟。

#if !defined(AFX_SALESBILL_H__E95A758E_1C5A_442D_91F0_BA25EF86E146__INCLUDED_)#define AFX_SALESBILL_H__E95A758E_1C5A_442D_91F0_BA25EF86E146__INCLUDED_#if _MSC_VER > 1000#pragma once#endif // _MSC_VER > 1000// SalesBill.h : header file///// CSalesBill dialog#include "MyButton.h"class CSalesBill : public CDialog{private:	CBitmapButton bitmapButton;	// Constructionpublic:	CSalesBill(CWnd* pParent = NULL);   // standard constructor// Dialog Data	//{
{AFX_DATA(CSalesBill) enum { IDD = IDD_SALESBILLDLG }; CMyButton m_btnCommoditySearch; CMyButton m_btnCommodityResearch; CListCtrl m_ctrlListMain; CString m_strBillDate; CString m_strBiller; CString m_strNote; CString m_strSerchCode; float m_fltSalePrice; int m_iNum; float m_fltAmount; CString m_strClient; CString m_strBillCode; //}}AFX_DATA// Overrides // ClassWizard generated virtual function overrides //{
{AFX_VIRTUAL(CSalesBill) protected: virtual void DoDataExchange(CDataExchange* pDX); // DDX/DDV support //}}AFX_VIRTUAL// Implementationprotected: // Generated message map functions //{
{AFX_MSG(CSalesBill) virtual BOOL OnInitDialog(); afx_msg void OnBill(); afx_msg void OnSave(); afx_msg void OnUpdate(); afx_msg void OnDelete(); afx_msg void OnAccount(); afx_msg void OnExit(); afx_msg void OnClientfind(); afx_msg void OnCommodityserch(); //}}AFX_MSG DECLARE_MESSAGE_MAP()};//{
{AFX_INSERT_LOCATION}}// Microsoft Visual C++ will insert additional declarations immediately before the previous line.#endif // !defined(AFX_SALESBILL_H__E95A758E_1C5A_442D_91F0_BA25EF86E146__INCLUDED_)// SalesBill.cpp : implementation file//#include "stdafx.h"#include "SalesManagementSystem.h"#include "SalesManagementSystemDlg.h"#include "SalesBill.h"#include "ADOConn.h"#include "MyTime.h"#include "DiagLog.h"#include "DlgAll.h"#ifdef _DEBUG#define new DEBUG_NEW#undef THIS_FILEstatic char THIS_FILE[] = __FILE__;#endif/// CSalesBill dialogCSalesBill::CSalesBill(CWnd* pParent /*=NULL*/) : CDialog(CSalesBill::IDD, pParent){ //{
{AFX_DATA_INIT(CSalesBill) m_strBillDate = _T(""); m_strBiller = _T(""); m_strNote = _T(""); m_strSerchCode = _T(""); m_fltSalePrice = 0.0f; m_iNum = 0; m_fltAmount = 0.0f; m_strClient = _T(""); m_strBillCode = _T(""); //}}AFX_DATA_INIT}void CSalesBill::DoDataExchange(CDataExchange* pDX){ CDialog::DoDataExchange(pDX); //{
{AFX_DATA_MAP(CSalesBill) DDX_Control(pDX, IDC_COMMODITYSERCH, m_btnCommoditySearch); DDX_Control(pDX, IDC_LISTCOMMODITY, m_ctrlListMain); DDX_Text(pDX, IDC_BILLDATE, m_strBillDate); DDX_Text(pDX, IDC_BILLER, m_strBiller); DDX_Text(pDX, IDC_NOTE, m_strNote); DDX_Text(pDX, IDC_SERCHCODE, m_strSerchCode); DDX_Text(pDX, IDC_SALEPRICE, m_fltSalePrice); DDX_Text(pDX, IDC_NUM, m_iNum); DDX_Text(pDX, IDC_AMOUNT, m_fltAmount); DDX_Text(pDX, IDC_CLIENT, m_strClient); DDX_Text(pDX, IDC_BILLCODE, m_strBillCode); //}}AFX_DATA_MAP}BEGIN_MESSAGE_MAP(CSalesBill, CDialog) //{
{AFX_MSG_MAP(CSalesBill) ON_BN_CLICKED(IDC_BILL, OnBill) ON_BN_CLICKED(IDC_SAVE, OnSave) ON_BN_CLICKED(IDC_UPDATE, OnUpdate) ON_BN_CLICKED(IDC_DELETE, OnDelete) ON_BN_CLICKED(IDC_ACCOUNT, OnAccount) ON_BN_CLICKED(IDC_CLIENTFIND, OnClientfind) ON_BN_CLICKED(IDC_COMMODITYSERCH, OnCommodityserch) //}}AFX_MSG_MAPEND_MESSAGE_MAP()/// CSalesBill message handlersBOOL CSalesBill::OnInitDialog() { CDialog::OnInitDialog(); // TODO: Add extra initialization here m_btnCommoditySearch.SetXIcon(IDI_ICONSERCH); //CBitmapButton bitmapButton; //bitmapButton.LoadBitmaps(IDB_BITMAP1, IDB_BITMAP1); bitmapButton.AutoLoad(IDC_BUTTON2, this); bitmapButton.LoadBitmaps(IDI_ICONSERCH, IDB_BITMAP3); //bitmapButton.SubclassDlgItem(IDC_COMMODITYSERCH, this); bitmapButton.SizeToContent(); m_ctrlListMain.InsertColumn(0, "条形码", LVCFMT_CENTER, 100); m_ctrlListMain.InsertColumn(1, "名称", LVCFMT_CENTER, 100); m_ctrlListMain.InsertColumn(2, "标准", LVCFMT_CENTER, 100); m_ctrlListMain.InsertColumn(3, "单位", LVCFMT_CENTER, 50); m_ctrlListMain.InsertColumn(4, "价格", LVCFMT_CENTER, 50); m_ctrlListMain.InsertColumn(5, "库存", LVCFMT_CENTER, 50); m_ctrlListMain.InsertColumn(6, "数量", LVCFMT_CENTER, 50); m_ctrlListMain.SetExtendedStyle(LVS_EX_GRIDLINES | LVS_EX_FULLROWSELECT); return TRUE; // return TRUE unless you set the focus to a control // EXCEPTION: OCX Property Pages should return FALSE}void CSalesBill::OnBill() { // TODO: Add your control notification handler code here UpdateData(TRUE); CMyTime myTime; m_strBillCode = myTime.GetSimpleString(); m_strBillDate = myTime.GetDateString(FALSE); m_strClient = ""; m_strNote = ""; m_fltSalePrice = 0; m_iNum = 0; m_fltAmount = 0; UpdateData(FALSE);}void CSalesBill::OnSave() { // TODO: Add your control notification handler code here UpdateData(TRUE); POSITION pos; int index; CString strNum, strPrice; strNum.Format(_T("%d"), m_iNum); strPrice.Format(_T("%f"), m_fltSalePrice); pos = m_ctrlListMain.GetFirstSelectedItemPosition(); index = m_ctrlListMain.GetNextSelectedItem(pos); m_fltAmount = m_fltAmount - atof(m_ctrlListMain.GetItemText(index, 4)) * atoi(m_ctrlListMain.GetItemText(index, 6)); m_ctrlListMain.SetItemText(index, 6, strNum); m_ctrlListMain.SetItemText(index, 4, strPrice); m_fltAmount = m_fltAmount + atof(m_ctrlListMain.GetItemText(index, 4)) * atoi(m_ctrlListMain.GetItemText(index, 6)); UpdateData(FALSE);}void CSalesBill::OnUpdate() { // TODO: Add your control notification handler code here UpdateData(TRUE); CString strSQL, strTemp; CADOConn adoSaleBill, adoSaleCommodity, adoStoreInfo, adoIntegral; strSQL = "INSERT INTO SaleBill VALUES ('"; strSQL = strSQL + m_strBillCode + "', '"; strSQL = strSQL + m_strBillDate + "', '"; strSQL = strSQL + m_strBiller + "', '"; strSQL = strSQL + m_strClient + "', '"; strSQL = strSQL + m_strNote + "')"; adoSaleBill.ExecuteSQL(strSQL); for(int i = 0; i < m_ctrlListMain.GetItemCount(); i++) { strSQL = "INSERT INTO SaleCommodity VALUES ('"; strSQL = strSQL + m_strBillCode + "', '"; strSQL = strSQL + m_ctrlListMain.GetItemText(i, 0) + "', '"; strSQL = strSQL + m_ctrlListMain.GetItemText(i, 4) + "', '"; strSQL = strSQL + m_ctrlListMain.GetItemText(i, 6) + "')"; adoSaleCommodity.ExecuteSQL(strSQL); int num = atoi(m_ctrlListMain.GetItemText(i, 5)) - atoi(m_ctrlListMain.GetItemText(i, 6)); strSQL = "UPDATE StoreInfo SET num = '"; strTemp.Format(_T("%d"), num); strSQL = strSQL + strTemp + "' WHERE barcode = '"; strSQL = strSQL + m_ctrlListMain.GetItemText(i, 0) + "'"; adoStoreInfo.ExecuteSQL(strSQL); } strSQL = "SELECT * FROM Integral WHERE cardcode = '"; strSQL = strSQL + m_strClient + "'"; adoIntegral.Open(strSQL); if (!adoIntegral.adoEOF()) { strSQL = "UPDATE Integral SET totalintegral = '"; strTemp.Format(_T("%0.2f"), m_fltAmount + atoi(adoIntegral.GetItemString(1))); strSQL = strSQL + strTemp + "', remainderintegral = '"; strTemp.Format(_T("%0.2f"), m_fltAmount + atoi(adoIntegral.GetItemString(3))); strSQL = strSQL + strTemp + "' WHERE cardcode = '"; strSQL = strSQL + m_strClient + "'"; adoIntegral.ExecuteSQL(strSQL); } else { strSQL = "INSERT INTO Integral VALUES ('"; strSQL = strSQL + m_strClient + "', '"; strTemp.Format(_T("%d"), m_fltAmount); strSQL = strSQL + strTemp + "', '0', '"; strSQL = strSQL + strTemp + "')"; adoIntegral.ExecuteSQL(strSQL); } }void CSalesBill::OnDelete() { // TODO: Add your control notification handler code here POSITION pos; int index; CADOConn adoSaleBill; CString strSQL; pos = m_ctrlListMain.GetFirstSelectedItemPosition(); index = m_ctrlListMain.GetNextSelectedItem(pos); strSQL = "DELETE * FROM SaleBill WHERE SaleBill.salecode ='"; strSQL = strSQL + m_ctrlListMain.GetItemText(index, 0) + "'"; adoSaleBill.ExecuteSQL(strSQL); m_fltAmount = m_fltAmount - atof(m_ctrlListMain.GetItemText(index, 4)) * atoi(m_ctrlListMain.GetItemText(index, 6)); m_ctrlListMain.DeleteItem(index);}void CSalesBill::OnAccount() { // TODO: Add your control notification handler code here m_strBillCode = ""; m_strBillDate = ""; m_strClient = ""; m_strNote = ""; m_fltSalePrice = 0; m_iNum = 0; m_ctrlListMain.DeleteAllItems(); UpdateData(FALSE);}void CSalesBill::OnClientfind() { // TODO: Add your control notification handler code here CADOConn adoFind; CDlgAll dlgAll; dlgAll.strTitle = "客户信息"; dlgAll.strSQL = "SELECT * FROM ClientInfo"; dlgAll.intKey = 0; if (dlgAll.DoModal() == IDOK) { m_strClient = dlgAll.strKey; UpdateData(FALSE); }}void CSalesBill::OnCommodityserch() { // TODO: Add your control notification handler code here UpdateData(TRUE); CADOConn adoFind; CDlgAll dlgAll; CString strSQL; strSQL = "SELECT CommodityInfo.barcode, CommodityInfo.name, CommodityInfo.standard, "; strSQL = strSQL + "CommodityInfo.unit, StoreInfo.saleprice, StoreInfo.num FROM CommodityInfo INNER JOIN StoreInfo ON "; strSQL = strSQL + "CommodityInfo.barcode = StoreInfo.barcode WHERE CommodityInfo.barcode = '"; strSQL = strSQL + m_strSerchCode + "' OR CommodityInfo.commoditycode = '"; strSQL = strSQL + m_strSerchCode + "' OR CommodityInfo.spellcode = '"; strSQL = strSQL + m_strSerchCode + "'"; dlgAll.strTitle = "商品基本信息"; dlgAll.strSQL = strSQL; dlgAll.intKey = 0; if (dlgAll.DoModal() == IDOK) { strSQL = "SELECT CommodityInfo.barcode, CommodityInfo.name, CommodityInfo.standard, "; strSQL = strSQL + "CommodityInfo.unit, StoreInfo.saleprice, StoreInfo.num FROM CommodityInfo INNER JOIN StoreInfo ON "; strSQL = strSQL + "CommodityInfo.barcode = StoreInfo.barcode WHERE CommodityInfo.barcode = '"; strSQL = strSQL + dlgAll.strKey + "'"; adoFind.Open(strSQL); //adoFind.InitList(&m_ctrlListMain); adoFind.FillList(&m_ctrlListMain); m_ctrlListMain.SetItemText(0, 6, "1"); m_fltSalePrice = atof(m_ctrlListMain.GetItemText(0, 4)); m_iNum = 1; m_fltAmount = m_fltAmount + m_iNum * m_fltSalePrice; UpdateData(FALSE); }}

转载地址:http://vduto.baihongyu.com/

你可能感兴趣的文章
HDU-4528 小明系列故事——捉迷藏 BFS模拟
查看>>
软件测试 (三) 界面测试
查看>>
java 多线程 Synchronized方法和方法块 synchronized(this)和synchronized(object)的理解
查看>>
ASP.NET MVC5+EF6+EasyUI 后台管理系统(18)-权限管理系统-表数据
查看>>
Windows Phone 8初学者开发—第12部分:改进视图模型和示例数据
查看>>
Redis: under the hood---转载
查看>>
C#笔试题面试题锦集(全)总20篇
查看>>
windows下体验Redis
查看>>
在Phonegap下实现oAuth认证
查看>>
Flash播放mp4的两个问题:编码问题和需要下载完后才能播放的问题
查看>>
ios 去掉UITableView Group形式下面的白色阴影
查看>>
Pascal可视化编程 CodeTyphon 、Lazarus
查看>>
LD_PRELOAD & LD_LIBRARY_PATH 动态库路径
查看>>
linux 下 java 链接oracle数据库
查看>>
网站标签命名规范【转载】
查看>>
android手机内的通讯录数据库
查看>>
与众不同 windows phone (1) - Hello Windows Phone
查看>>
linux 用户管理
查看>>
我是该学JAVA呢,还是学IOS开发呢?
查看>>
HDU 1058 Humble Number
查看>>