登陆用户验证功能设计(2)

一.

1.效果图展示

2.5z.gif

2.功能及后台数据库图示

在启动程序中能看见数据库中的信息之类的。


捕获.PNG

三.ADO.NET查询数据库流程

1)导入命名空间。
2)定义数据库连接字符串,创建connection对象;
3)打开连接;
4)利用command对象的ExecuteReader()方法执行Select查询语句;
5)利用ExecuteReader()方法返回的DataReader对象读取数据,显示到界面上;
6)关闭连接。

四.重要代码展示

String connStr = "Data Source=.;Initial Catalog=SuperMarketSales;Integrated Security=True";
SqlConnection sqlConn = new SqlConnection(connStr);

try
{
    // 连接数据库
    sqlConn.Open();

    // 在数据库中查询USERS表
    String sqlStr = "select * from USERS";
SqlCommand cmd = new SqlCommand(sqlStr, sqlConn);
SqlDataReader dr = cmd.ExecuteReader();

    // 解析数据
while (dr.Read())
{
    String Id = dr["ID"].ToString();
    String Name = dr["NAME"].ToString();
    String Password = dr["PASSWORD"].ToString();
    String Phone = dr["PHONE"].ToString();

    // 注意是累加
    this.tb_Users.Text += Id + ", " + Name + ", " + Password + ", " + Phone + "\r\n";
}

}
catch (Exception exp)
{
    MessageBox.Show(“访问数据库出错“ + exp.Message);
}
finally
{
    sqlConn.Close();
}
String connStr = "Data Source=.;Initial Catalog=SuperMarketSales;Integrated Security=True";

SqlConnection sqlConn = new SqlConnection(connStr);
try
{
    sqlConn.Open();

    // 数据获取过程,参见后面PPT
}
catch (Exception exp)
{
    MessageBox.Show("数据库连接失败“ + exp.Message);
}
finally
{
    sqlConn.Close();
}
String sqlStr = "";
if (this.cbb_UserType.Text == "收银员")
{
    // 注意USER是SQL Server关键字,表名不能命名为USER,而应当用USERS
    sqlStr = "select * from USERS where ID=@id and PASSWORD=@pwd";
}
else
{
    sqlStr = "select * from ADMIN where ID=@id and PASSWORD=@pwd";
}

SqlCommand cmd = new SqlCommand(sqlStr, sqlConn);

// 注意是用用户ID登录,而不是用户名,用户名可能会重复
cmd.Parameters.Add(new SqlParameter("@id", this.tb_User.Text.Trim()));
cmd.Parameters.Add(new SqlParameter("@pwd", this.tb_Password.Text.Trim()));

SqlDataReader dr = cmd.ExecuteReader();
// 如果从数据库中查询到记录,则表示可以登录
if (dr.HasRows)
{
    dr.Read();
    UserInfo.userId = int.Parse(dr["ID"].ToString());
    UserInfo.userName = dr["NAME"].ToString();
    UserInfo.userPwd = dr["PASSWORD"].ToString();
    UserInfo.userPhone = dr["PHONE"].ToString();
    UserInfo.userType = this.cbb_UserType.Text;

    MessageBox.Show(UserInfo.userType + "登录成功");
if (UserInfo.userType == "收银员")
{
    // 显示收银员主界面
    MainFormUser formUser = new MainFormUser();
    formUser.Show();

    // 隐藏登录界面
    this.Hide();
}

if (UserInfo.userType == "库管员")
{
    // 显示库管员主界面
    MainFormAdmin formAdmin = new MainFormAdmin();
    formAdmin.Show();

    // 隐藏登录界面
    this.Hide();
}

注:

首先连接数据库,在数据库中查询users表,之后解析数据,在数据获取,注意user是sql,sever关键字,表命不能够为user,而应当用users,并且注意是用用户登录,不是用户名,用户名可能会重复,在从数据库中查询到记录,表示可以登录。最后完成登录。

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 关于Mongodb的全面总结 MongoDB的内部构造《MongoDB The Definitive Guide》...
    中v中阅读 32,038评论 2 89
  • ORA-00001: 违反唯一约束条件 (.) 错误说明:当在唯一索引所对应的列上键入重复值时,会触发此异常。 O...
    我想起个好名字阅读 5,447评论 0 9
  • 壹爱厨房是萃展科技旗下专注宠物饮食健康的鲜食定制品牌,壹爱厨房希望为您的爱宠小毛孩儿做更多更多。当您想要真正的了解...
    壹爱厨房阅读 160评论 0 0
  • 创作目的 摒弃泛滥的图片和个人情感抒发,用简洁的语言进行直观的说明。帮助自由行的朋友免去调查的时间。下面都是以la...
    分迪_竹阅读 213评论 0 1
  • Vim的前世今生 Vim是一个类似于Vi的著名的功能强大、高度可定制的文本编辑器,在Vi的基础上改进和增加了很多特...
    18K纯帅咸鱼阅读 537评论 0 0