C#可视化 商品信息管理系统(具体做法及全部代码)

news2025/1/13 6:25:49

目录

题目:

 效果图:

 数据库:

做法:

主页面添加menustrip,之后添加两个窗体双击事件,双击下拉区域就好了。

添加界面

查询按钮功能

datagirdview设置

全部代码: 

 DBHelper类

 From1主窗体代码

添加代码:

查询代码 


题目:

 效果图:

信息管理下拉框中有两个选项,每一个都会打开对应的窗体

                                                   

 

 数据库:

 

做法:

主页面添加menustrip,之后添加两个窗体双击事件,双击下拉区域就好了。

添加界面

 

 该页面主要代码:

该代码作用:

1 首先为Brand表添加brand数据,

2 红色字体是全新写法,查询别的表的内容

 string s = string.Format("insert PcInfo(pcName,brandId,isReceiv,pcPrice,pcDetail,pcRemark)values ('{0}',(select id from Brand where brand='{1}'),{2},{3},'{4}','{5}')", textBox1.Text, comboBox1.Text, temp, textBox4.Text, textBox2.Text, textBox3.Text);

 private void button1_Click(object sender, EventArgs e)
        {
            try
            {
                if (textBox1.Text != null && textBox2.Text != null && textBox3.Text != null && textBox4.Text != null && comboBox1.Text != null)
                {
                    string sql = string.Format("insert Brand(brand)values ('{0}')", comboBox1.Text.ToString());
                    if (!DBHelper.noqe(sql))
                    {
                        MessageBox.Show("品牌添加失败");
                    }
                    byte temp = 0;
                    if (radioButton2.Checked == true)
                    {
                        temp =1;
                    }
                    string s = string.Format("insert PcInfo(pcName,brandId,isReceiv,pcPrice,pcDetail,pcRemark)values ('{0}',(select id from Brand where brand='{1}'),{2},{3},'{4}','{5}')", textBox1.Text, comboBox1.Text, temp, textBox4.Text, textBox2.Text, textBox3.Text);
                    if (DBHelper.noqe(s))
                    {
                        MessageBox.Show("保存成功!");
                    }
                    else
                    {
                        MessageBox.Show("保存失败!");
                    }
                }
                else
                {
                    MessageBox.Show("请录入完整商品信息!");

                }
            }
            catch (Exception ee)
            {
                MessageBox.Show(ee.ToString());              
            }
        }

查询按钮功能

需要用到连接查询,因为有两个表。再用模糊查询查询两个表的内容

private void button1_Click(object sender, EventArgs e)
        {
            string sql =string.Format("select pcName,brand,pcPrice,pcDetail,timestamp from PcInfo p join Brand b on p.brandId=b.id where pcName like'%{0}%'",textBox1.Text) ;
            DataSet ds = DBHelper.ds(sql);
            this.dataGridView1.DataSource = ds.Tables[0];
        }

datagirdview设置

首先设置datagridview的这三个属性

    1. AutoSizeColumsMode = Fill 设置每列单元格宽度平铺

    1. RowHeadersVisible = False 取消列表最左侧列显示

    1. SelectionMode = FullRowSelect 设置单元格选中模式为整行选中

 

全部代码: 

 DBHelper类

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Data;
using System.Data.SqlClient;

namespace spxxgl
{
    class DBHelper
    {
        public static SqlConnection conn = null;
        public static string connstr = "server=.;database=GoodsManager;uid=sa;pwd=123456";
        public static void into() {
            if (conn==null)
            {
                conn = new SqlConnection(connstr);
            }
            conn.Close();
            conn.Open();
        }
        public static bool noqe(string sql) {
            into();
            SqlCommand cmd = new SqlCommand(sql,conn);
            int ret = cmd.ExecuteNonQuery();
            conn.Close();
            if (ret>0)
            {
                
                return true;
            }
            else
            {
                return false;
            }
        }
        public static DataSet ds(string sql){
            into();
            DataSet d = new DataSet();
            SqlDataAdapter t = new SqlDataAdapter(sql,conn);
            t.Fill(d);
            conn.Close();
            return d;



        }
    }
}

 From1主窗体代码

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

namespace spxxgl
{
    public partial class MainForm : Form
    {
        public MainForm()
        {
            InitializeComponent();
        }

        private void 退出ToolStripMenuItem_Click(object sender, EventArgs e)
        {
            this.Close();
        }

        private void 增加信息ToolStripMenuItem_Click(object sender, EventArgs e)
        {
            jia j = new jia();
            j.ShowDialog();
            j.MdiParent = this;
           
        }

        private void 查询信息ToolStripMenuItem_Click(object sender, EventArgs e)
        {
            cha j = new cha();
            j.ShowDialog();
            j.MdiParent = this;
        }

        private void MainForm_Load(object sender, EventArgs e)
        {

        }
    }
}

添加代码:

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

namespace spxxgl
{
    public partial class jia : Form
    {
        public jia()
        {
            InitializeComponent();
        }

        private void button1_Click(object sender, EventArgs e)
        {
            try
            {
                if (textBox1.Text != null && textBox2.Text != null && textBox3.Text != null && textBox4.Text != null && comboBox1.Text != null)
                {
                    string sql = string.Format("insert Brand(brand)values ('{0}')", comboBox1.Text.ToString());
                    if (!DBHelper.noqe(sql))
                    {
                        MessageBox.Show("品牌添加失败");
                    }
                    byte temp = 0;
                    if (radioButton2.Checked == true)
                    {
                        temp =1;
                    }
                    string s = string.Format("insert PcInfo(pcName,brandId,isReceiv,pcPrice,pcDetail,pcRemark)values ('{0}',(select id from Brand where brand='{1}'),{2},{3},'{4}','{5}')", textBox1.Text, comboBox1.Text, temp, textBox4.Text, textBox2.Text, textBox3.Text);
                    if (DBHelper.noqe(s))
                    {
                        MessageBox.Show("保存成功!");
                    }
                    else
                    {
                        MessageBox.Show("保存失败!");
                    }
                }
                else
                {
                    MessageBox.Show("请录入完整商品信息!");

                }
            }
            catch (Exception ee)
            {
                MessageBox.Show(ee.ToString());              
            }
        }
        private void button3_Click(object sender, EventArgs e)
        {
            textBox1.Text = null;
            comboBox1.Text = null;
            radioButton1.Checked = true;
            textBox4.Text = null;
            textBox2.Text = null;
            textBox3.Text = null;
        }

        private void button2_Click(object sender, EventArgs e)
        {
            this.Close();
        }

        private void jia_Load(object sender, EventArgs e)
        {

        }
    }
}

查询代码 

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

namespace spxxgl
{
    public partial class cha : Form
    {
        public cha()
        {
            InitializeComponent();
        }

        private void button1_Click(object sender, EventArgs e)
        {
            string sql =string.Format("select pcName,brand,pcPrice,pcDetail,timestamp from PcInfo p join Brand b on p.brandId=b.id where pcName like'%{0}%'",textBox1.Text) ;
            DataSet ds = DBHelper.ds(sql);
            this.dataGridView1.DataSource = ds.Tables[0];
        }

        private void cha_Load(object sender, EventArgs e)
        {
            string sql = "select pcName,brand,pcPrice,pcDetail,timestamp from PcInfo p join Brand b on p.brandId=b.id";
          DataSet ds=  DBHelper.ds(sql);
           this.dataGridView1.DataSource= ds.Tables[0];
        }
    }
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/620555.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【并发篇】01 java中的线程状态

Java线程分为6种状态: (1)新建NEW:用new关键字创建的线程就是新建状态,这时候还没有和系统底层真正的线程关联起来,还仅仅只是一个java对象,所以这个时候这个线程不会被系统分配给cpu。 &#…

【云原生】docker

容器化越来越受欢迎,因为容器是: ●灵活:即使是最复杂的应用也可以集装箱化。 ●轻量级:容器利用并共享主机内核。 ●可互换:可以即时部署更新和升级。 ●便携式:可以在本地构建,部署到云&#…

shel脚本基础1——变量基础、脚本运算符

文章目录 一、变量基础二、bash变量类型三、脚本基础知识3.1 脚本测试命令3.2 shell运算符3.3 命令逻辑关系3.4 bash条件判断3.4.1 条件测试的表达式3.4.2 整数测试3.4.2 字符测试3.4.3 文件测试3.4.4 组合测试条件 一、变量基础 变量的含义: 变量可以通过变量名访问…

5.数据结构期末复习之图以及相关算法

1.应用: 教学计划(先修什么才能修什么课程)社交网络地图导航 2.什么是图? 顶点(有穷非空个)顶点的边 ,抽象为G(V,E) (Vert,Edge) 1.无向图: 点到点都可以到达 表示为(vi,vj) 2.有向图 只能一个点到另外一个点 表示为<vi,vj> 又分为: 1.非带权图(上面的例子就是) 2.带权图…

Day29

TCP_SER #include <myhead.h>//定义处理错误的宏函数 #define ERR_MSG(msg) do{\fprintf(stderr,"line:%d %s %s",__LINE__, __FILE__, __func__);\perror(msg);\ }while(0)//定义IP和端口号 #define IP "192.168.2.186" #define PORT 6666int …

数组的定义方式及访问

问题 如何创建及访问数组。 方法 了解数组的概念 数组就是存储多个数据的容器&#xff0c;数组的长度固定&#xff0c;多个数据的数据类型要一致。 数组的三种定义方式 数据存储的数据类型[] 数组名字 new 数组存储的数据类型[长度] 数据类型[] 数组名 new 数据类型[]{元素…

测试人35岁何去何从?软件测试路在何方?“我“一路升级打怪...

目录&#xff1a;导读 前言一、Python编程入门到精通二、接口自动化项目实战三、Web自动化项目实战四、App自动化项目实战五、一线大厂简历六、测试开发DevOps体系七、常用自动化测试工具八、JMeter性能测试九、总结&#xff08;尾部小惊喜&#xff09; 前言 测试员干到35岁&a…

暑期健身房招生活动文案分享,在线传单设计

想要有效地宣传健身房的信息&#xff0c;还能够吸引学员了解报名的宣传单要怎么制作&#xff1f;不用自己动手设计&#xff0c;借助在线模板和在线设计工具&#xff0c;一键就能生成专属的招生传单。以下是在线招生传单设计教程和传单设计模板使用教程。 首先找到一个在线设计工…

Juypter更改默认路径,并且解决改完默认路径不自动跳转的问题

目录 更改默认路径 第一步先在你所安装的juypter的环境下输入下面代码 第二步在自己的文件夹下找到这个目录&#xff0c;用记事本打开 第三步更改快捷方式 解决浏览器不调转方法 相对于juypter来讲&#xff0c;还是挺好用的&#xff0c;自我感觉比pycharm更好一点。 juypt…

ES6中 Promise和使用场景

介绍 &#x1f959;&#x1f959;&#x1f959;更加合理和更加强大 Promise&#xff0c;译为承诺&#xff0c;是异步编程的一种解决方案&#xff0c;比传统的解决方案&#xff08;回调函数&#xff09;更加合理和更加强大 在以往我们如果处理多层异步操作&#xff0c;我们往往…

群晖服务器被encrypted勒索病毒攻击后的表现与如何解密勒索病毒

群晖服务器是一种高效的数据管理方案&#xff0c;但是如果被Encrypted勒索病毒感染&#xff0c;可能会导致许多重要的数据会丢失。Encrypted勒索病毒将加密被感染服务器上的文件&#xff0c;导致它们无法打开。一旦我们遭到encrypted勒索病毒攻击&#xff0c;建议大家选择专业的…

【Web开发技术】异常处理机制的使用

文章目录 一、引言1、应用场景2、语法3、体系 二、详细设计&#xff08;后端开发&#xff09;1、信息提示常量类2、自定义异常3、Model层4、Controller层5、View层 一、引言 编程也有很久的时间了&#xff0c;如果每个报的错误和寻找的答案写成一张纸&#xff0c;叠加起来也得有…

JAVA项目代码几乎没有改动,重新发布后突然报错,无法启动

项目场景&#xff1a; 提示&#xff1a;这里简述项目相关背景&#xff1a; JAVA项目代码几乎没有改动&#xff0c;重新发布后突然报错&#xff0c;无法启动 问题描述 提示&#xff1a;这里描述项目中遇到的问题&#xff1a; JAVA项目代码几乎没有改动&#xff0c;重新发布后…

2023年PMP 续证的费用和流程最全介绍

PMP证书并不是终身有效的&#xff0c;是需要三年一续的&#xff0c;PMI会在有效期截止前给持证者发邮件提示换证&#xff08;续证&#xff09;。目前的续证费用为150美金和积满60个PDU&#xff0c;60个PDU是在证书三年有效期内积满就可以&#xff0c;像我的培训机构艾威每周都会…

当Mysql缓慢时,这几招可解燃眉之急

第一步定位问题源&#xff1a; 常见的以查询Mysql性能问题的方法 1.大部分的性能问题都是查询过慢的问题&#xff0c;可以查询慢sql日志。 通过慢查询日志定位那些执行效率较低的SQL语句&#xff0c;用–log-slow-queries[ file_name]选项启动时&#xff0c;mysqld写一个包含所…

售后退换货客服话术

在客服的工作生涯里&#xff0c;售后退换货这种问题&#xff0c;对于我们客服来说可以说是见惯不惯了。今天小编给大家准备了一些退换货的售后回复话术&#xff0c;让大家工作起来更加高效。 一、引导退换货 1.亲&#xff0c;麻烦您收到后请先试穿&#xff0c;请一定要保持衣服…

WordPress入门版,保姆级记录

服务器里用户越近&#xff0c;访问速度越快&#xff0c;所以需要根据用户群体选择合适的服务器 国外网站&#xff1a;SiteGround国内网站&#xff1a;阿里云 bidewang.co/sg WordPress托管服务器页面&#xff0c;一般选择第二个套餐 没有域名则选择购买域名 然后填选购买信息…

007-从零搭建微服务-网关中心(一)

写在最前 如果这个项目让你有所收获&#xff0c;记得 Star 关注哦&#xff0c;这对我是非常不错的鼓励与支持。 源码地址&#xff1a;https://gitee.com/csps/mingyue 文档地址&#xff1a;https://gitee.com/csps/mingyue/wikis 新建 mingyue-gateway 在 【从零搭建微服务…

练习SpringBoot烘培坊项目

烘培坊项目 文章目录 烘培坊项目项目概述项目搭建项目关键代码实现实现首页轮播图实现注册功能实现登录功能实现图片上传稿件管理页面内容列表功能稿件管理页面修改功能稿件管理页面删除功能首页三个类型下的分类展示首页三种类型的内容展示点击查看更多进入列表页面在header里…

mysql waf绕过-WAF Bypass技巧(2)

数据库waf绕过的一些玩法 WAF Bypass技巧(0)_luozhonghua2000的博客-CSDN博客 WAF绕过-WAF Bypass技巧(1)_luozhonghua2000的博客-CSDN博客 数据库特性 第一篇: Mysql数据库特性 0x01 前言 我们经常利用一些数据库特性来进行WAF绕过。在Mysgl中,比如可以这样 位置一: 参数和…