在好例子网,分享、交流、成长!
您当前所在位置:首页C# 开发实例C#数据库操作 → POS收银系统

POS收银系统

C#数据库操作

下载此实例
  • 开发语言:C#
  • 实例大小:0.49M
  • 下载次数:210
  • 浏览次数:4630
  • 发布时间:2015-09-11
  • 实例类别:C#数据库操作
  • 发 布 人:mabocfd
  • 文件格式:.rar
  • 所需积分:2
 相关标签: 系统

实例介绍

【实例简介】
超市POS收银系统

前台收银用户名:haiyang 密码:1

后台管理用户名:admin 密码:1

后台管理功能主要用:商品分类管理、商品添加、商品修改、商品管理、日汇总、月汇总、年汇总、用户管理等,配合条码机、扫描枪、小票打印机等硬件使用,适合超市收银使用。。


要求必须安装 office,因为 数据库用的 access

【实例截图】

【核心代码】

using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Text;
using System.Windows.Forms;

namespace FOUPOS
{
    public partial class Cash : Form
    {
        POS.Model.FUser m_User = new POS.Model.FUser();
        public Cash(POS.Model.FUser fuser)
        {
            InitializeComponent();
            this.m_User = fuser;

        }
        private int sumCount = 0;
        POS.BLL.FGoods b_Goods = new POS.BLL.FGoods();
        POS.Model.FGoods m_Goods = new POS.Model.FGoods();
        private void Cash_Load(object sender, EventArgs e)
        {
            skinEngine1.SkinFile = "OneBlue.ssk";
            SetlvGoods();


        }
        #region 在界面Load的时候先设置好标题名和长度.

        protected void SetlvGoods()
        {
            lvGoods.Columns.Add("数量", 60);
            lvGoods.Columns.Add("条码", 170);
            lvGoods.Columns.Add("商品名", 210);
            lvGoods.Columns.Add("单价", 80);

            lvGoods.Columns.Add("金额", 80);
            lvGoods.Columns.Add("收银员", 80);

        }
        #endregion
        private void btnAdd_Click(object sender, EventArgs e)
        {

            int scount = 1;
            if (!string.IsNullOrEmpty(txtNum.Text))
            {
                if (b_Goods.Exists(txtNum.Text.Trim()))
                {
                    m_Goods = b_Goods.GetModelByNum(txtNum.Text.Trim());
                    if (lvGoods.Items.Count > 0)
                    {
                        bool exist = false;
                        foreach (ListViewItem checklvi in lvGoods.Items)
                        {
                            if (checklvi.SubItems[1].Text == txtNum.Text.Trim())
                            {
                                exist = true;
                                checklvi.SubItems[0].Text = (int.Parse(checklvi.SubItems[0].Text)   1).ToString();
                                checklvi.SubItems[4].Text = string.Format("{0:F2}", (int.Parse(checklvi.SubItems[0].Text) * m_Goods.SSalePrice));
                                sumCount  = 1;
                                lblSumMoney.Text = GetSumMoney().ToString();
                                txtSumMoney.Text = lblSumMoney.Text;
                                txtShouldGetMoney.Text = lblSumMoney.Text;
                                lblSumCount.Text = sumCount.ToString();//记录商品总数
                                txtNum.Text = "";
                                return;//跳出button事件之前更新商品总数和txtNum的text属性
                            }
                        }
                        if (exist == false)
                        {
                            ListViewItem lvi = lvGoods.Items.Add(scount.ToString());
                            lvi.SubItems.Add(m_Goods.SNum);
                            lvi.SubItems.Add(m_Goods.SName);
                            lvi.SubItems.Add(string.Format("{0:F2}", m_Goods.SSalePrice));

                            lvi.SubItems.Add(string.Format("{0:F2}", m_Goods.SSalePrice));
                            lvi.SubItems.Add(m_User.UName);
                            sumCount  = 1;
                        }
                    }
                    else
                    {

                        ListViewItem lvi = lvGoods.Items.Add(scount.ToString());
                        lvi.SubItems.Add(m_Goods.SNum);
                        lvi.SubItems.Add(m_Goods.SName);
                        lvi.SubItems.Add(string.Format("{0:F2}", m_Goods.SSalePrice));

                        lvi.SubItems.Add(string.Format("{0:F2}", m_Goods.SSalePrice));
                        lvi.SubItems.Add(m_User.UName);
                        sumCount  = 1;
                    }
                }
            }
            lblSumMoney.Text = GetSumMoney().ToString();
            txtSumMoney.Text = lblSumMoney.Text;
            txtShouldGetMoney.Text = lblSumMoney.Text;
            lblSumCount.Text = sumCount.ToString();//记录商品总数
            txtNum.Text = "";
        }

        private void Cash_Activated(object sender, EventArgs e)
        {
            txtNum.Focus();
        }
        #region 获取金额
        protected decimal GetSumMoney()
        {
            decimal summoney = 0;
            foreach (ListViewItem checklvi in lvGoods.Items)
            {
                summoney  = decimal.Parse(checklvi.SubItems[4].Text);
            }
            return summoney;
        }
        #endregion
        private void lvGoods_AfterLabelEdit(object sender, LabelEditEventArgs e)
        {
            try
            {
                ListView lv = (ListView)sender;
                int a = int.Parse(e.Label);
                lv.SelectedItems[0].SubItems[4].Text = (a * decimal.Parse(lv.SelectedItems[0].SubItems[3].Text)).ToString();
                lblSumMoney.Text = GetSumMoney().ToString();
                txtSumMoney.Text = lblSumMoney.Text;
                txtShouldGetMoney.Text = lblSumMoney.Text;
            }
            catch (Exception ex)
            {
                e.CancelEdit = true;
                MessageBox.Show(ex.Message);
            }
        }

        private void txtGetMoney_Leave(object sender, EventArgs e)
        {
            try
            {
                decimal shouldmoney = decimal.Parse(txtShouldGetMoney.Text);
                decimal getmoney = decimal.Parse(txtGetMoney.Text);
                if (getmoney > shouldmoney)
                {
                    txtReturnMoney.Text = string.Format("{0:F2}", getmoney - shouldmoney);
                }
                else
                {
                    MessageBox.Show("交来金额小于实收金额。");
                }
            }
            catch
            {
                MessageBox.Show("数据有误,请仔细检查输入金额。");
            }
        }
        #region 取出精确到毫秒的时间做流水号
        protected string GetAccountNum()
        {
            int year = System.DateTime.Now.Year;
            int month = System.DateTime.Now.Month;
            int day = System.DateTime.Now.Day;
            int hour = System.DateTime.Now.Hour;
            int minute = System.DateTime.Now.Minute;
            int second = System.DateTime.Now.Second;
            int millisecond = System.DateTime.Now.Millisecond;
            string num = year.ToString()   month.ToString()   day.ToString()   hour.ToString()   minute.ToString()   second.ToString()   millisecond.ToString();
            return num;
        }
        #endregion
        private void button1_Click(object sender, EventArgs e)
        {
            POS.BLL.FAccount b_Account = new POS.BLL.FAccount();
            POS.Model.FAccount m_Account = new POS.Model.FAccount();
            m_Account.AccountNum = GetAccountNum();
            m_Account.GetMoney = decimal.Parse(txtShouldGetMoney.Text);
            m_Account.JoinTime = DateTime.Now;
            m_Account.NoGetMoney = 0;
            m_Account.SumMoney = decimal.Parse(txtSumMoney.Text);
            m_Account.UID = m_User.UID;
            b_Account.Add(m_Account);
            int id = b_Account.GetMaxID();
            POS.Model.FDetail m_Detail = new POS.Model.FDetail();
            POS.BLL.FDetail b_Detail = new POS.BLL.FDetail();
            m_Detail.AID = id;
            foreach (ListViewItem checklvi in lvGoods.Items)
            {
                m_Detail.GNum = checklvi.SubItems[1].Text;
                m_Detail.DCount = int.Parse(checklvi.SubItems[0].Text);
                b_Detail.Add(m_Detail);
            }
            GetClear();
            MessageBox.Show("收银成功。");
        }
        protected void GetClear()
        {
            lvGoods.Items.Clear();
            lblSumMoney.Text = null;
            lblSumCount.Text = null;
            txtGetMoney.Text = null;
            txtReturnMoney.Text = null;
            txtShouldGetMoney.Text = null;
            txtSumMoney.Text = null;
        }
    }
}


标签: 系统

实例下载地址

POS收银系统

不能下载?内容有错? 点击这里报错 + 投诉 + 提问

好例子网口号:伸出你的我的手 — 分享

网友评论

第 1 楼 xdeepbreath 发表于: 2017-07-13 23:57 18
缺乏核心代码,不能用。

支持(0) 盖楼(回复)

第 2 楼 4401743@qq.com 发表于: 2018-03-15 21:35 26
非常简单,学习还是可以

支持(0) 盖楼(回复)

发表评论

(您的评论需要经过审核才能显示)

查看所有2条评论>>

小贴士

感谢您为本站写下的评论,您的评论对其它用户来说具有重要的参考价值,所以请认真填写。

  • 类似“顶”、“沙发”之类没有营养的文字,对勤劳贡献的楼主来说是令人沮丧的反馈信息。
  • 相信您也不想看到一排文字/表情墙,所以请不要反馈意义不大的重复字符,也请尽量不要纯表情的回复。
  • 提问之前请再仔细看一遍楼主的说明,或许是您遗漏了。
  • 请勿到处挖坑绊人、招贴广告。既占空间让人厌烦,又没人会搭理,于人于己都无利。

关于好例子网

本站旨在为广大IT学习爱好者提供一个非营利性互相学习交流分享平台。本站所有资源都可以被免费获取学习研究。本站资源来自网友分享,对搜索内容的合法性不具有预见性、识别性、控制性,仅供学习研究,请务必在下载后24小时内给予删除,不得用于其他任何用途,否则后果自负。基于互联网的特殊性,平台无法对用户传输的作品、信息、内容的权属或合法性、安全性、合规性、真实性、科学性、完整权、有效性等进行实质审查;无论平台是否已进行审查,用户均应自行承担因其传输的作品、信息、内容而可能或已经产生的侵权或权属纠纷等法律责任。本站所有资源不代表本站的观点或立场,基于网友分享,根据中国法律《信息网络传播权保护条例》第二十二与二十三条之规定,若资源存在侵权或相关问题请联系本站客服人员,点此联系我们。关于更多版权及免责申明参见 版权及免责申明

;
报警