写项目之前呢,先来缕缕思路,既然要写学生管理系统,那肯定上不了从数据库中读取信息,然而想要从数据库中拿到你想要的东西,就要先登录,得到他的权限才行,所以我们第一步就要先搞出一个登录页面并且能连接到数据库的.So 就有了第一张图,至于他怎么来的,咱继续往下看!嘻嘻~

一、先登录

        

     登陆页面     登录出错(登录名或密码填写错误)

    想登陆成功需要在登录里加些代码进去,(双击登录进入代码编辑将下面的代码写进去)

  //验证用户名密码是否和数据库中匹配
string str = "Data source=.;initial catalog=MySchool;uid=sa";
SqlConnection con = new SqlConnection(str);
string sql = "select count(1) from student where studentname='" + txtName.Text + "' and loginpwd='" + txtPwd.Text + "'"; SqlCommand cmd = new SqlCommand(sql, con);
try
{
con.Open();
int count = Convert.ToInt32(cmd.ExecuteScalar());
if (count > )
{
this.Hide();
//定位到Main界面
FrmMain frm=new FrmMain();
Tool.pwd= txtPwd.Text;
frm.Show(); }
}
catch (Exception)
{
MessageBox.Show("网络出错");
}
finally
{
con.Close(); } }
//Load窗体在被用户肉眼看到前就被执行了
private void FrmLogin_Load(object sender, EventArgs e)
{ }
}

登录页面

    登陆成功后就能进入查询学生系统,所以,我们要写一个前台

生活中的前台是咨询的地方,所以我们的前台也会模仿他们一样,有固定的功能,For example 菜单→修改密码或退出;新建学生信息;查询学生信息;按年级查询学生信息......

    下面小博继续为大家讲解.   

二、编写前台

菜单栏(menuStrip1);工具栏(toolStrip1);右键(contextMenuStrip1);

 

下面进行真正的写项目,写具体"功能"了.

三、新建学生用户

为了让用户点击保存用户信息直接添加到数据库中,需要在"保存"里面加入下面的代码

  private void btnEdit_Click(object sender, EventArgs e)
{
//根据学号是否为0,判定该按钮用来执行“添加”还是“修改”
if (stuno!=)
{
//修改
//update
}
else
{
//添加
AddStudent();
}
} //添加学生
public void AddStudent()
{
//添加学生
string pwd = txtPwd.Text;//密码
string stuname = txtName.Text;//姓名
//获取性别
string stugender = string.Empty;
if (rbtnMale.Checked)
{
stugender = "";
}
else
{
stugender = "";
}
//如何给下拉框绑定数据
int gid = GetIdByName();
//电话
string stuPhone = txtPhone.Text; //地址
string stuAddress = txtAddress.Text;
//日期
DateTime dt = dpBirthday.Value;
string stuEmail = txtEmail.Text;
//StudentNo, LoginPwd, StudentName, Gender, GradeId, Phone, Address, Birthday, Email, MyTT
string sql = "insert into student values('" + pwd + "','" + stuname + "'," + stugender + "," + gid + ",'" + stuPhone + "','" + stuAddress + "','" + dt + "','" + stuEmail + "')";
string str = "Data source=.;initial catalog=MySchool;uid=sa";
SqlConnection con = new SqlConnection(str);
SqlCommand cmd = new SqlCommand(sql, con);
con.Open();
int count = cmd.ExecuteNonQuery();
if (count > )
{
MessageBox.Show("成功!");
}
con.Close();
} //该方法将年级名称转换成年级编号
public int GetIdByName()
{
string str = "Data source=.;initial catalog=MySchool;uid=sa";
SqlConnection con = new SqlConnection(str);
string sql = "select gradeid from grade where gradename='"+cboGrade.Text+"'";
SqlCommand cmd = new SqlCommand(sql, con);
int gid = ;
try
{
con.Open();
gid =Convert.ToInt32(cmd.ExecuteScalar());
}
catch (Exception)
{ MessageBox.Show("网络异常");
}
finally
{
con.Close();
}
return gid;
}

添加学生信息

四、从数据库中拿到想要的内容

和上面的方式相同

   private void btnSearch_Click(object sender, EventArgs e)
{ //查询数据前,清空LIstView中的数据
lvStuList.Items.Clear();
string sql = @"select Studentno,Studentname,Gender,gradename
from student,grade
where student.gradeid=grade.gradeid and studentname like '%"+txtStudentName.Text+"%' ";
LoadDataFromDBToListView(sql);
}

从数据库中查询想要的学生信息

以上就是小博今天为大家"传授"的小步骤,希望能多评价即便小博下次改正~如果有高手高手高高手,请联系小博,小博会悉心请教~谢谢.

                      No.QQ:1327805794

 

      

【皇甫】☀那些事儿......STEP的更多相关文章

  1. 【皇甫】☀IOC和AOP的拓展实例

    <!--构造器注入 --> <bean id="user1" class="cn.happy.entity.User"> <con ...

  2. 【皇甫】☀初识AOP

    新知识,新起点,下面介绍一下aop所要准备架包和各个层 特点: 创建好的各个层: 所需架包: 具体步骤: No.1  搭建分层架构 entity 1 public class User impleme ...

  3. 【皇甫】☀Spring开题中...

    spring (由Rod Johnson创建的一个开源框架)Spring是一个开源框架,Spring是于2003 年兴起的一个轻量级的Java 开发框架,由Rod Johnson创建.简单来说,Spr ...

  4. 【皇甫】☀Struts_第一节课

    本章讲解内容: DTD是Docunent Type Defintion的缩写,即文档类型定义.DTD用来描述XML文档结构. DOM4J是一个非常优秀的javaXML API,具有性能优异,功能强大和 ...

  5. 【皇甫】☀Hibernate入门

    说说我们最近的一些事 二期已经过去了,下面迎接的就是二年,据原老师讲解,我们10月份就开始陆续找工作了,虽然他说我们找工作不是问题,可每个人都有自知之明,我也知道我所处的位置,所以我清楚我要怎么做,我 ...

  6. 【皇甫】☀ TreeSet

    -Set: 元素是无序(存入和取出的顺序不一致),元素不可以重复 |-- HashSet: 底层数据结构是哈希表 HashSet是如何保证元素的唯一性的呢? 是通过元素的两个方法,hashCode和e ...

  7. 【皇甫】☀ 图_substring

    substring是啥?

  8. 【皇甫】☀PPT里的小玩意

    第三次写博客了,感觉写的蛮有趣的,在写的同时,回顾了知识点,又上手操作了一遍,印象更加深刻了,尽管今天写的和那些像JAVA啦,HTML啦,C#啦,没多大关系(个人理解),但确实我们经常能用到的.比如说 ...

  9. 【皇甫】☀亲爱的~help me

     亲爱的,我不知道该怎么把我想对你说的话表达出来,希望我对你的认识真的像下面的内容一样,如果我有错,那说明我还不够了解你... 希望我们能够一起走到最后吧... 首先,说说最近的吧,  在我还没有和你 ...

随机推荐

  1. jframe去掉窗体

    jframe 去掉最大化 怎样去除JFrame上的三个按钮(最大化,最小化,关闭) myjframe.getRootPane().setWindowDecorationStyle(JRootPane. ...

  2. 接口测试从未如此简单 - Postman (Chrome插件)【转】

    一个非常有力的Http Client工具用来测试Web服务的, 我这里来介绍如何用它测试restful web service 注:转载请注明出处http://www.cnblogs.com/wade ...

  3. mysql select 练习题

    10. 查询Score表中的最高分的学生学号和课程号.(子查询或者排序) select sno,cno from score where degree  in(select max(degree) f ...

  4. C# 字符串的截取和替换

    1.取字符串的前n个字符 (1)string str1=str.Substring(0,n); (2)string str1=str.Remove(i,str.Length-n); 2.去掉字符串的前 ...

  5. NSURLConnection同步与异步请求 问题

    NSURLConnection目前有两个异步请求方法,异步请求中其中一个是代理.一个同步方法.有前辈已经详细介绍,见:http://blog.csdn.net/xyz_lmn/article/deta ...

  6. shell 统计GMT0 时区的数据

    和某个供应商核对数据,对方是GMT+0时区,我方报表默认北京时间,无法修改为GMT0, 对excel中按照小时级别的数据导出到excel处理,然后转为文本文件,shell转为GMT0进行统计: 前期处 ...

  7. Python中*args 和**kwargs的用法

    当函数的参数不确定时,可以使用*args 和**kwargs,*args 没有key值,**kwargs有key值.还是直接来代码吧,废话少说[python] def fun_var_args(far ...

  8. POJ 1528问题描述

    Description From the article Number Theory in the 1994 Microsoft Encarta: ``If a, b, c are integers ...

  9. 使用openvswitch实现跨主机docker容器互联

    安装openvswitch的步骤请参考上一篇文章:http://www.cnblogs.com/xkops/p/5568167.html 环境:192.168.3.201 node1192.168.3 ...

  10. Android Platform Guide

    This guide shows how to set up your SDK environment to deploy Cordova apps for Android devices, and ...