借助DBHelper实现学生管理案例分析
一、案例功能的实现
数据:
--专业
create table ProfessionInfo
(
ProfessionID int primary key identity(1,1), --专业编号
professionName varchar(50) not null unique --专业名称
)
--学生
create table StudentInfo
(
StuID varchar(20) primary key, --学生学号
StuName varchar(50) not null, --学生姓名
StuAge int not null check(StuAge > 0 and StuAge < 130), --学生年龄
StuSex char(2) not null check(StuSex in('男','女')), --学生性别
StuHobby nvarchar(100), --爱好
ProfessionID int not null references ProfessionInfo(ProfessionID), --所属专业编号
)
--添加专业信息
insert into ProfessionInfo(professionName) values('电子竞技')
insert into ProfessionInfo(professionName) values('软件开发')
insert into ProfessionInfo(professionName) values('医疗护理')
--插入学生信息
insert into StudentInfo(StuID,StuName,StuAge,StuSex,StuHobby,ProfessionID)
values('001','刘备',18,'男','',1)
insert into StudentInfo(StuID,StuName,StuAge,StuSex,StuHobby,ProfessionID)
values('002','关羽',20,'男','',2)
insert into StudentInfo(StuID,StuName,StuAge,StuSex,StuHobby,ProfessionID)
values('003','张飞',19,'男','',2)
insert into StudentInfo(StuID,StuName,StuAge,StuSex,StuHobby,ProfessionID)
values('004','孙尚香',17,'女','',3)
业务需求:

(1)专业下拉框绑定专业表数据,网格控件绑定学生数据,并且点击"搜索"按钮可以多条件组合查询。
(2)选中某一行,右键可以弹出"删除"菜单,点击"删除"菜单可以删除学生数据。
(3)点击"新增"按钮,弹出新增窗体,在此窗体中完成学生的新增操作。

(4)选中某一行,点击"编辑"按钮,弹出编辑窗体,在此窗体中完成数据的修改。

备注:其中性别的单选框,以及爱好的多选框分别用两个Pannel容器包含。
实现代码:
(1)查询窗体绑定专业信息、绑定学生信息以及搜索功能代码:
#region 绑定专业信息到下拉框
private void BindProfession()
{
DataTable dt = new DataTable();
DBHelper.PrepareSql("select * from ProfessionInfo");
dt = DBHelper.ExecQuery();
DataRow dr = dt.NewRow();
dr["ProfessionID"] = 0;
dr["professionName"] = "--请选择--";
dt.Rows.InsertAt(dr, 0);
this.cmbPro.DataSource = dt;
this.cmbPro.DisplayMember = "professionName";
this.cmbPro.ValueMember = "ProfessionID";
}
#endregion
#region 绑定学生数据
private void BindData()
{
string sql = "select * from StudentInfo inner join ProfessionInfo on StudentInfo.ProfessionID=ProfessionInfo.ProfessionID where 1 = 1 ";
if(!this.cmbPro.SelectedValue.ToString().Equals("0"))
sql += " and StudentInfo.ProfessionID = " + this.cmbPro.SelectedValue.ToString();
if(!this.txtName.Text.Equals(""))
sql += " and StuName like '%" + this.txtName.Text + "%'";
this.dataGridView1.AutoGenerateColumns = false;
DBHelper.PrepareSql(sql);
this.dataGridView1.DataSource = DBHelper.ExecQuery();
}
#endregion
private void Form1_Load(object sender, EventArgs e)
{
BindProfession();
BindData();
}
private void btSearch_Click(object sender, EventArgs e)
{
BindData();
}
(2)删除菜单代码:
private void 删除ToolStripMenuItem_Click(object sender, EventArgs e)
{
//添加是否确定删除的对话框
DialogResult result = MessageBox.Show("确定要删除数据吗,删除之后无法恢复!", "提示框",
MessageBoxButtons.OKCancel, MessageBoxIcon.Question);
if (result == DialogResult.Cancel)
return;
string stuid = this.dataGridView1.SelectedRows[0].Cells[0].Value.ToString();
string sql = "delete from StudentInfo where StuID = @StuID";
DBHelper.PrepareSql(sql);
DBHelper.SetParameter("StuID", stuid);
int rowCount = DBHelper.ExecNonQuery();
if (rowCount == 1)
MessageBox.Show("删除成功!");
else
MessageBox.Show("删除失败!");
BindData();
}
(3)添加学生信息窗体代码:
#region 绑定专业信息到下拉框
private void BindProfession()
{
DataTable dt = new DataTable();
DBHelper.PrepareSql("select * from ProfessionInfo");
dt = DBHelper.ExecQuery();
DataRow dr = dt.NewRow();
dr["ProfessionID"] = 0;
dr["professionName"] = "--请选择--";
dt.Rows.InsertAt(dr, 0);
this.cmbPro.DataSource = dt;
this.cmbPro.DisplayMember = "professionName";
this.cmbPro.ValueMember = "ProfessionID";
}
#endregion
private void FrmAdd_Load(object sender, EventArgs e)
{
BindProfession();
}
private void btAdd_Click(object sender, EventArgs e)
{
string sql = "insert into StudentInfo(StuID,StuName,StuAge,StuSex,StuHobby,ProfessionID) values(@StuID,@StuName,@StuAge,@StuSex,@StuHobby,@ProfessionID)";
DBHelper.PrepareSql(sql);
DBHelper.SetParameter("StuID", this.txtId.Text);
DBHelper.SetParameter("StuName",this.txtName.Text);
DBHelper.SetParameter("StuAge",this.txtAge.Text);
//性别处理
string sex = "";
if (this.rbBoy.Checked == true) sex = this.rbBoy.Text;
if (this.rbGirl.Checked == true) sex = this.rbGirl.Text;
DBHelper.SetParameter("StuSex", sex);
//爱好处理
string hobby = "";
foreach (CheckBox ck in this.panel2.Controls)
{
if (ck.Checked == true)
{
if (!hobby.Equals(""))
hobby += ",";
hobby += ck.Text;
}
}
DBHelper.SetParameter("StuHobby", hobby);
DBHelper.SetParameter("ProfessionID",this.cmbPro.SelectedValue.ToString());
int rowCount = DBHelper.ExecNonQuery();
if (rowCount == 1)
{
MessageBox.Show("新增成功!");
this.Close();
}
else
{
MessageBox.Show("新增失败!");
}
}
(4)编辑学生信息窗体代码:
public string StuID { get; set; } //学生编号
#region 绑定专业信息到下拉框
private void BindProfession()
{
DataTable dt = new DataTable();
DBHelper.PrepareSql("select * from ProfessionInfo");
dt = DBHelper.ExecQuery();
DataRow dr = dt.NewRow();
dr["ProfessionID"] = 0;
dr["professionName"] = "--请选择--";
dt.Rows.InsertAt(dr, 0);
this.cmbPro.DataSource = dt;
this.cmbPro.DisplayMember = "professionName";
this.cmbPro.ValueMember = "ProfessionID";
}
#endregion
private void BindDetail()
{
string sql = "select * from StudentInfo where StuID = " + this.StuID;
DBHelper.PrepareSql(sql);
DataTable dt = new DataTable();
dt = DBHelper.ExecQuery();
this.txtId.Text = dt.Rows[0]["StuID"].ToString();
this.txtName.Text = dt.Rows[0]["StuName"].ToString();
this.txtAge.Text = dt.Rows[0]["StuAge"].ToString();
this.cmbPro.SelectedValue = dt.Rows[0]["ProfessionID"].ToString();
//性别处理
if (dt.Rows[0]["StuSex"].ToString().Equals("男"))
this.rbBoy.Checked = true;
else
this.rbGirl.Checked = true;
//爱好处理
string[] arrHobby = dt.Rows[0]["StuHobby"].ToString().Split(',');
foreach (string hobby in arrHobby)
{
foreach (CheckBox ck in this.panel2.Controls)
{
if (ck.Text.Equals(hobby))
ck.Checked = true;
}
}
}
private void FrmEdit_Load(object sender, EventArgs e)
{
BindProfession();
BindDetail();
}
private void btUpdate_Click(object sender, EventArgs e)
{
string sql = "update StudentInfo set StuName=@StuName,StuAge=@StuAge,StuSex=@StuSex,StuHobby=@StuHobby,ProfessionID=@ProfessionID where StuID=@StuID";
DBHelper.PrepareSql(sql);
DBHelper.SetParameter("StuName", this.txtName.Text);
DBHelper.SetParameter("StuAge", this.txtAge.Text);
//性别处理
string sex = "";
if (this.rbBoy.Checked == true) sex = this.rbBoy.Text;
if (this.rbGirl.Checked == true) sex = this.rbGirl.Text;
DBHelper.SetParameter("StuSex", sex);
//爱好处理
string hobby = "";
foreach (CheckBox ck in this.panel2.Controls)
{
if (ck.Checked == true)
{
if (!hobby.Equals(""))
hobby += ",";
hobby += ck.Text;
}
}
DBHelper.SetParameter("StuHobby", hobby);
DBHelper.SetParameter("ProfessionID", this.cmbPro.SelectedValue.ToString());
DBHelper.SetParameter("StuID", this.StuID);
int rowCount = DBHelper.ExecNonQuery();
if (rowCount == 1)
{
MessageBox.Show("修改成功!");
this.Close();
}
else
{
MessageBox.Show("修改失败!");
}
}
(5)查询窗体中"新增"和"编辑"按钮代码:
private void btAdd_Click(object sender, EventArgs e)
{
FrmAdd frm = new FrmAdd();
//frm.Owner = this;
frm.Show();
}
private void btEdit_Click(object sender, EventArgs e)
{
string stuid = this.dataGridView1.SelectedRows[0].Cells[0].Value.ToString();
FrmEdit frm = new FrmEdit();
frm.StuID = stuid;
frm.Show();
}
二、补充:连接字符串配置
将数据库连接字符串直接写在C#代码中,如果连接字符串需要发生改变,必须在C#代码中修改,并且重新进行编译的操作,给软件实施带来了麻烦。
解决此问题,可以将数据库连接字符串存放在配置文件中。
(1)在项目中找到App.config文件,如果没有此文件可以添加一个应用程序配置文件,在此配置文件的configuration节点内部添加如下配置:
<connectionStrings>
<add name="DefaultConn" connectionString="server=.;database=DBTEST;uid=sa;pwd=123456;"/>
</connectionStrings>
(2)给项目添加引用"System.Configuration",并且将C#中连接字符串的赋值修改如下:
public static string connStr = ConfigurationManager.ConnectionStrings["DefaultConn"].ConnectionString;
借助DBHelper实现学生管理案例分析的更多相关文章
- 098 01 Android 零基础入门 02 Java面向对象 03 综合案例(学生信息管理) 02 案例分析及实现 02 编写并测试Subject类
098 01 Android 零基础入门 02 Java面向对象 03 综合案例(学生信息管理) 02 案例分析及实现 02 编写并测试Subject类 本文知识点:编写并测试Subject类 说明: ...
- 099 01 Android 零基础入门 02 Java面向对象 03 综合案例(学生信息管理) 02 案例分析及实现 03 编写并测试Student类
099 01 Android 零基础入门 02 Java面向对象 03 综合案例(学生信息管理) 02 案例分析及实现 03 编写并测试Student类 本文知识点:编写并测试Subject类 说明: ...
- 101 01 Android 零基础入门 02 Java面向对象 03 综合案例(学生信息管理) 02 案例分析及实现 05 通过方法实现学生类与专业类关联——方案二
101 01 Android 零基础入门 02 Java面向对象 03 综合案例(学生信息管理) 02 案例分析及实现 05 通过方法实现学生类与专业类关联--方案二 本文知识点:通过方法实现学生类与 ...
- 2020BUAA软工个人博客作业-软件案例分析
2020BUAA软工个人博客作业-软件案例分析 17373010 杜博玮 项目 内容 这个作业属于哪个课程 2020春季计算机学院软件工程(罗杰 任健) 这个作业的要求在哪里 个人博客作业-软件案例分 ...
- Vue基础语法-数据绑定、事件处理和扩展组件等知识详解(案例分析,简单易懂,附源码)
前言: 本篇文章主要讲解了Vue实例对象的创建.常用内置指令的使用.自定义组件的创建.生命周期(钩子函数)等.以及个人的心得体会,汇集成本篇文章,作为自己对Vue基础知识入门级的总结与笔记. 其中介绍 ...
- 个人作业-Week2 案例分析
微软必应词典客户端的案例分析 第一部分 调研,评测 1)bug: 运行平台:iOS 10.0.2 必应词典版本:4.2.2 1. bug标题:词库加载错误 bug详细描述:学习界面中的经典词库出国考试 ...
- [2017BUAA软工助教]案例分析小结
BUAA案例分析小结 一.作业要求 http://www.cnblogs.com/jiel/p/7631784.html 二.统计数据 总人数 神策数据 博客园博客 必应词典 30 1 12 17 三 ...
- 第四次作业——关于石墨文档(Android)客户端的案例分析
关于石墨文档(Android)客户端的案例分析 作业地址:[https://edu.cnblogs.com/campus/nenu/2016CS/homework/2505] 第一部分调研,评测 1. ...
- 个人作业2——集大通APP案例分析
个人作业2——集大通APP案例分析 产品:集大通 我认为这个是我们学校的APP,我们应该支持一下. 一.个人体验 1.下载并使用,描述最简单直观的个人第一次上手体验. ①界面美观,可以感受到丰富的校园 ...
随机推荐
- idea创建WebService服务端和客户端
创建服务端 1.file–>new–>project 2.点击next后输入服务端名,点击finish,生成目录如下 3.在 HelloWorld.Java 文件中右击,选 WebServ ...
- Linux-标准输入标准输出
标准输入(代码为0) 标准输出(代码为1) 标准错误输出(代码为2) 将标准输出重定向到一个文件 find /etc -name fileA >list 等同于 find /etc -name ...
- jquery.form 兼容IE89文件上传
导入部分 <script type="text/javascript" src="js/jquery-1.8.3.min.js" charset=&quo ...
- 用Java中的File类模拟实现对系统文件的增删改查效果
码字不易,三连支持一波吧 IO操作向来是各大语言的热区,而对文件的操作也是重中之重. 那么在Java中也给我们提供了很多关于文件操作的类.今天我就用一个比较基本的File类来模拟实现对文件的增删改查效 ...
- 《PHP面试笔试真题库》——PHP面试的好帮手
你好,是我琉忆. 一个文艺的PHP开发工程师. 很荣幸能够在这里带来我的第一本新书--<PHP程序员面试笔试真题库>. 一.创作过程 <PHP 程序员面试笔试真题库>是我的第三 ...
- 13、Linux基础--grep、sed、awk三剑客综合运用
考试 1.找出/proc/meminfo文件中以s开头的行,至少用三种方式忽略大小写 [root@localhost ~]# grep -E '^[sS]' /proc/meminfo [root@l ...
- JNDI漏洞利用探索
最近学习了师傅寻找的一些JNDI漏洞的利用链受益匪浅,自己也尝试关于JNDI漏洞利用做一些挖掘,目前JNDI在利用过程我想到了两个问题. 测试每一个JNDI Bypass 利用链都需要手动更改URL很 ...
- GIT学习——天天都在用Git,那么你系统学习过吗?(学习过程)
你系统学习Git了吗? 学习圣思园张龙老师的Git课程. 使用Mac编程的好处,不是因为Mac长得好看 Git内容学习准备 如果你还没有用Git,就不要写代码了. GitHub仓库的使用. 新员工入职 ...
- 超强可视化图表工具:Smartbi!!
要制作出专业的可视化图表,还是需要一定的学习成本的,并且需要大量的时间.并且即使是制作出来,配色也是一大难题,对于一般人而言,通常会通过两种方式实现可视化大屏的制作: 1.写代码 大部分人可能会选择大 ...
- JavaSE-万字长文-加载时间长-小白文
Java语法规范 所有的Java语句必须以;结尾! 无论是().[]还是{},所有的括号必须一一匹配! 主方法的代码只能写在{}中! Java基础语法(面向过程) 在学习面向对象之前,我们需要了解面向 ...