学生点名系统
目录
1设计目的 . ................................................................................................. 1
2需求分析 . ................................................................................................. 1
2.1 项目背景 ....................................................................................... 1
2.2 项目功能 ....................................................................................... 2
2.3功能实现 ........................................................................................ 2
3模块分析及设计 ..................................................................................... 3
3.1界面设计 ........................................................................................ 3
3.1.1主界面 ................................................................................... 3
3.1.2其他界面 ............................................................................... 3
3.2代码设计 ........................................................................................ 5
3.2.1“点名”按钮代码 ................................................................ 5
3.2.2“到”按钮代码 .................................................................... 6
3.2.3“缺席”按钮代码 ................................................................ 8
3.2.4菜单代码 ............................................................................. 10
3.2.5“添加”按钮代码 .............................................................. 11
3.2.6“查询”按钮代码 .............................................................. 14
3.2.7“考试标记”的登陆代码 .................................................. 15
4数据库设计说明 ................................................................................... 17
5制作过程及要点 ................................................................................... 19
6设计总结 . ............................................................................................... 19
7参考资料 . ............................................................................................... 21
1设计目的
本软件专门为了老师上课期间点名的便利而设计。只需要电击鼠标就可以实现对学生点名,方便省时。
此外,本软件中还有对学生的大分与记录,对学生的整体情况进行记录,以及对每次到课情况进行统计,使得课堂上的更多情况能在数据库中得以保存。
可见本软件在目标上是尽量满足用户的需求。
2需求分析
2.1 项目背景
在计算机广泛推广的今天,应用计算机已经大大的提高了社会的各方面的效率,而作为学校,社会知识的高度集中区,计算机已经成为一种必需品。有了计算机,那么我们就应该在方方面面想到用它来提高我们的效率,
对于大学学生的考勤方面,现在越来越现实其重要性,虽然大学生都已经步入成年,但是其自制力还是很不容乐观,很作方面还需要代课老师和学校的监督,但是对于上课点名很占时间,而其效果不好,老师不能对学生每次点名情况都有明确的了解,所以一个可视化的点名系统成为必须。
此外,对于学生上课表现情况,老师可以更其回答问题的质量和次数来进行打分,所以在上课时有一个能够面向学生的点名系统对学生的知识进行提问也称为老师们十分想要的一个系统。
但是虽然软件业发展很快,对于这方面的软件却很少,所以开发点名与提问系统的软件成为一个十分需求的认为。
2.2 项目功能
输入学生数据。
对学生点名。
统计3次没到学生记录并将其考试标记设为0。
统计缺席次数少于3次的学生记录并将其考试标记设为
输出两种考试标记的学生记录。
随机查询任意学生信息并输出。
2.3功能实现
模拟日常生活中的点名方式,使用windows 应用程序设计主界面实现点名功能,通过对主界面菜单的设计实现其他的功能。
3模块分析及设计
3.1界面设计
3.1.1主界面
单击“点名”按钮开始点名,然后单击“到”或“缺席”按钮实现应答功能。“文件”菜单的扩展有“学生表”,“考试标记”,“关闭”。“考试标记”扩展有“缺席少于3次”和“缺席不低于3次”。以上的菜单分别实现了“点名”以外的其它所有功能。
3.1.2其他界面
以下3个界面中所用到的数据绑定控件均为DataGridView 控件 分别实现对不同学生信息的显示功能。
3.2代码设计
3.2.1“点名”按钮代码
private void 学生表_Load(object sender, EventArgs e) {
// TODO: 这行代码将数据加载到表“学生
DataSet2.student ”中。您可以根据需要移动或移除它。 this .studentTableAdapter1.Fill(this . 学生DataSet2.student);
}
static string conStr = "server=.;database=学
生;integrated security=true";
static SqlConnection con = new SqlConnection (conStr); static int kaiShi = 0;
private void button3_Click(object sender, EventArgs e)
{
kaiShi = 1; //开始标记
SqlCommand cmd = con.CreateCommand();
string select = "select * from student"; cmd.CommandText = select;
con.Open();
SqlDataReader reader = cmd.ExecuteReader(); reader.Read();
textBox1.Text = reader[" 学号" ].ToString(); textBox2.Text = reader[" 姓名" ].ToString(); reader.Close();
con.Close();
}
3.2.2“到”按钮代码
static int n = 1; //序号每次从1开始
private void button1_Click(object sender, EventArgs e)
{
if (kaiShi == 1)
{
try
{
n++;
SqlCommand cmd = con.CreateCommand(); string select = "select * from student where 序号=" + n.ToString();
cmd.CommandText = select;
con.Open();
SqlDataReader reader =
cmd.ExecuteReader();
reader.Read();
textBox1.Text = reader[" 学号
" ].ToString();
textBox2.Text = reader[" 姓名
" ].ToString();
reader.Close();
con.Close();
}
catch
{
MessageBox .Show(" 点名结束!" );
}
}
}
3.2.3“缺席”按钮代码
private void button2_Click(object sender, EventArgs e)
{
if (kaiShi == 1)
{
try
{
//////////////////////////////////// SqlCommand cmd1 = con.CreateCommand(); string select1 = "select 缺席次数 from student1 where 学号=" + textBox1.Text;
cmd1.CommandText = select1;
con.Open();
SqlDataReader reader1 =
cmd1.ExecuteReader();
reader1.Read();
int ciShu = int .Parse(reader1[" 缺席次数
" ].ToString()) + 1;
reader1.Close();
//con.Close();
if (ciShu
select1 = "update student1 set 缺席次数='" + ciShu.ToString() + "', 考试标记='1' where 学号='" + textBox1.Text + "'" ;
else
select1 = "update student1 set 缺席次数='" + ciShu.ToString() + "', 考试标记='0' where 学号='" + textBox1.Text + "'" ;
cmd1.CommandText = select1;
//con.Open();
cmd1.ExecuteNonQuery();
con.Close();
///////////////////////////////////// n++;
SqlCommand cmd = con.CreateCommand(); string select = "select * from student where 序号=" + n.ToString();
cmd.CommandText = select;
con.Open();
SqlDataReader reader =
cmd.ExecuteReader();
reader.Read();
textBox1.Text = reader[" 学号
" ].ToString();
textBox2.Text = reader[" 姓名
" ].ToString();
reader.Close();
con.Close();
}
catch
{
MessageBox .Show(" 点名结束!" ); }
}
}
3.2.4菜单代码
private void 关于ToolStripMenuItem_Click(object sender,
EventArgs e)
{
MessageBox .Show("3次没到的学生其考试标记为0,其他的为1" ); }
private void toolStripMenuItem2_Click(object sender, EventArgs e)
{
///////////////////////
Form f = new 缺席少于3次();
f.Show();
}
private void toolStripMenuItem3_Click(object sender, EventArgs e)
{
Form f1 = new 缺席不低于3次();
f1.Show();
}
private void 技术支持ToolStripMenuItem_Click(object sender, EventArgs e)
{
System.Diagnostics. Process .Start("http://www.baidu.com/");
}
private void 关闭ToolStripMenuItem_Click(object sender,
EventArgs e)
{
this .Close();
}
private void 学生表ToolStripMenuItem_Click(object sender, EventArgs e)
{
Form f = new 学生表();
f.Show();
}
3.2.5“添加”按钮代码
private void 学生表_Load(object sender, EventArgs e) {
// TODO: 这行代码将数据加载到表“学生
DataSet2.student ”中。您可以根据需要移动或移除它。
this .studentTableAdapter1.Fill(this . 学生DataSet2.student);
}
static string conString = "server=.;database=学
生;integrated security=true";
static SqlConnection myCon = new
SqlConnection (conString);
private void button1_Click(object sender, EventArgs e)
{
int s = 1;
SqlCommand cmd = myCon.CreateCommand(); myCon.Open();
string str1 = "select * from student where 序号=(select max(序号) from student)";
cmd.CommandText = str1;
SqlDataReader reader = cmd.ExecuteReader(); if (reader.Read() == true )
{
s = int .Parse(reader[" 序号" ].ToString()); s++;
}
reader.Close();
myCon.Close();
///////////////////////
if (textBox1.Text == "" || textBox2.Text == "" ) {
MessageBox .Show(" 请输入数据!" );
return ;
}
string str2 = "insert into student(序号, 学号, 姓名, 性别) values('" + s.ToString() + "','" + textBox1.Text + "','" + textBox2.Text + "','" +
comboBox1.SelectedItem.ToString() + "')" ;
string str3 = "insert into student1(学号, 缺席次数, 考试标记) values('" + textBox1.Text + "','0','1')" ; cmd.CommandText = str2;
myCon.Open();
cmd.ExecuteNonQuery();
//MessageBox.Show("添加数据成功!");
myCon.Close();
cmd.CommandText = str3;
myCon.Open();
cmd.ExecuteNonQuery();
MessageBox .Show(" 添加数据成功!" );
myCon.Close();
}
3.2.6“查询”按钮代码
private void button2_Click(object sender, EventArgs e)
{
try
{
string str=null ;
SqlCommand cmd = myCon.CreateCommand(); if (textBox1.Text!="" )
str = "select student.学号,student. 姓名,student. 性别,student1. 缺席次数 from student,student1 where student.学号=student1.学号 and student1.学号='" + textBox1.Text+"'" ;
else if (textBox2.Text!="" )
str = "select student.学号,student. 姓名,student. 性别,student1. 缺席次数 from student,student1 where student.学号=student1.学号 and student.姓名='" + textBox2.Text+"'" ;
cmd.CommandText = str;
myCon.Open();
SqlDataReader reader = cmd.ExecuteReader();
if (reader.Read() == true )
{
MessageBox .Show(" 学号:" + reader[" 学号" ].ToString() + "\n姓名:" + reader[" 姓名" ].ToString() + "\n性别:" + reader[" 性别" ].ToString() + "\n缺席次数:" + reader[" 缺席次数" ].ToString());
}
}
catch
{
MessageBox .Show(" 输入有误!" );
}
myCon.Close();
}
3.2.7“考试标记”的登陆代码
//考试标记为0
private void 缺席不低于3次_Load(object sender,
EventArgs e)
{
string conStr = "server=.;database=学
生;integrated security=true";
SqlConnection con = new SqlConnection (conStr); SqlCommand cmd = con.CreateCommand();
string select = "select student.学号,student. 姓名,student. 性别,student1. 缺席次数 from student,student1 where student.学号=student1.学号 and student1.考试标记=0"; cmd.CommandText = select;
con.Open();
cmd.ExecuteNonQuery();
SqlDataAdapter sda = new SqlDataAdapter (cmd); DataTable dt = new DataTable ();
sda.Fill(dt);
dataGridView1.DataSource = dt;
con.Close();
}
//考试标记为1
private void 缺席少于3次_Load(object sender, EventArgs e)
{
string conStr = "server=.;database=学
生;integrated security=true";
SqlConnection con = new SqlConnection (conStr); SqlCommand cmd = con.CreateCommand();
string select = "select student.学号,student. 姓名,student. 性别,student1. 缺席次数 from student,student1 where student.学号=student1.学号 and student1.考试标记=1"; cmd.CommandText = select;
con.Open();
cmd.ExecuteNonQuery();
SqlDataAdapter sda = new SqlDataAdapter (cmd); DataTable dt = new DataTable ();
sda.Fill(dt);
dataGridView1.DataSource = dt;
con.Close();
}
4数据库设计说明
新建一个“学生”数据库,并在其中新建student 和student1两个表(如下图所示)
5制作过程及要点
本次课程设计通过模拟生活中的点名方式,对不同的功能进行各个击破,然后将不同功能组合在一起形成了“学生点名系统”。为了方便对数据库的存取操作,用了2张表代替了原先的一张表,程序执行时,每录入一个学生信息都会对2张表进行写操作。
为了让点名功能能够自动有序的完成,特意将student 表增加了“序号”属性。
6设计总结
我们小组三人在本次试验中充分体会到了团结,合作以及坚持等因素是一件事情成功的关键所在。
首先,在团结方面,我们认为系统编程不是一个人的事情,而且特别苦和累,也是年轻人的事情,所以本软件在开发期间组员之间都要团结,一起讨论解决方案和鼓励对方。
其次一定要抱有一颗合作的心态,我们认为没有合作是做不成事情的。特别是在和队员讨论问题的时候,一定要耐性的理解对方的思路,经过自己的思考,用于实际之中。我认为我们的工作是一个团队的工
作,团队需要个人,个人也离不开团队,必须发扬团结协作的精神。某个人的离群都可能导致导致整项工作的失败。实习中只有一个人知道原理是远远不够的,必须让每个人都知道,否则一个人的错误,就有可能导致整个工作失败。团结协作是我们实习成功的一项非常重要的保证。而这次实习也正好锻炼我们这一点,这也是非常宝贵的。
这次课程设计,我们很快就完成了,这要归功于我们组对此次任务的合理分配。这次课程设计让我认识到一个人的力量是有限的,组员之间有效的沟通是很重要的。
通过这次课程设计使我懂得了理论与实际相结合是很重要的,只有理论知识是远远不够的,只有把所学的理论知识与实践相结合起来,从理论中得出结论,才能真正为社会服务,从而提高自己的实际动手能力和独立思考的能力。在设计的过程中遇到问题,可以说得是困难重重,这毕竟第一次做的,难免会遇到过各种各样的问题,同时在设计的过程中发现了自己的不足之处,对以前所学过的知识理解得不够深刻,掌握得不够牢固。
对我们而言,知识上的收获重要,精神上的丰收更加可喜。挫折是一份财富,经历是一份拥有。这次实习必将成为我人生旅途上一个非常美好的回忆!
20
7参考资料
《Visual Studio.NET 2008开发一册通:C#3.0从基础到项目实战》 李海涛 化学工业出版社 2010-1-1
《Visual C#开发技术大全》 明日科技 人民邮电出版社 2007-11-01
《Visual C# 2008入门经典》 (
电出版社 2009-06-01
《Visual C# 通用范例开发金典》
版社 2008-6-1
21 美)James Foxall 人民邮王超,潘杨 电子工业出