商超系统界面设计

|项目|

|2.6|登陆用户验证功能设计

2.6.1登录界面效果图

登录用户验证功能设计.gif

2.6.2

2.6.2.1本次界面的主要功能:

能够成功连接数据库,能够登录界面

2.6.2.2

![EY$E{%YUZCFK2@6[`{)QBZ4.png](https://upload-images.jianshu.io/upload_images/11123573-b165c4f9c5c6a545.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/1240)
![HPD}$EQ(0TFYPSR9}[YX{LN.png](https://upload-
![HPD}$EQ(0TFYPSR9}YX{LN.png

2.6.3ADO.NET查询数据库的流程

商超系统界面设计_第1张图片
图片1.png

具体步骤:

  1. 导入命名空间;
  2. 运用Connection对象建立与数据库连接;
  3. 打开连接;
  4. 利用Command对象的ExecuteReader()方法执行Select查询语句;
  5. 利用ExecuteReader()方法返回的DataReader对象读取数据,显示到界面上;
  6. 关闭连接。

2.6.4重要代码

、、、
String connStr = "Data Source=.;Initial Catalog=SuperMarketSales;Integrated Security=True";

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

// 数据获取过程,参见后面PPT

}
catch (Exception exp)
{
MessageBox.Show("数据库连接失败");
}
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();

}
、、、

|2.7|密码修改界面功能设计

2.7.1修改界面效果图

密码修改界面功能设计.gif

2.7.2

2.7.2.1本次界面的主要功能:

能够连接数据库,能够进入界面修改密码。

2.7.2.2

2.7.3ADO.NET更新数据库的流程

商超系统界面设计_第3张图片
图片3.png

具体步骤:

  1. 导入命名空间;
  2. 定义数据库连接字符串,运用Connection对象建立与数据库连接;
  3. 打开连接;
  4. 利用Command对象的ExecuteNoQuery()方法执行Update语句;
  5. 通过ExecuteNoQuery()方法返回值判断是否修改成功,并在界面上提示;
  6. 关闭连接。

2.7.4关键代码

、、、

String userName = this.tb_User.Text.Trim();
String newPwd = this.tb_NewPwd.Text.Trim();
String confPwd = this.tb_ConfirmPwd.Text.Trim();

// 验证输入信息
if (newPwd.Equals(""))
{
MessageBox.Show("请输入新密码", "提示", MessageBoxButtons.OK, MessageBoxIcon.Warning);
return;
}
else if (confPwd.Equals(""))
{
MessageBox.Show("请输入确认密码", "提示", MessageBoxButtons.OK, MessageBoxIcon.Warning);
return;
}
else if (newPwd != confPwd)
{
MessageBox.Show("两次密码不一致", "提示", MessageBoxButtons.OK, MessageBoxIcon.Warning);
return;
}
// 连接字符串,注意与实际环境保持一致
String connStr = "Data Source=.;Initial Catalog=SuperMarketSales;Integrated Security=True";
SqlConnection sqlConn = new SqlConnection(connStr);
try
{
// 连接数据库
sqlConn.Open();

// 构造UPDATE命令,更改数据库,参见后面PPT

}
catch (Exception exp)
{
MessageBox.Show("访问数据库错误:" + exp.Message);
}
finally
{
sqlConn.Close();
}
// 构造UPDATE命令
String sqlStr = "update EMPLOYEE set PASSWORD=@pwd where ID=@id";
SqlCommand cmd = new SqlCommand(sqlStr, sqlConn);

// SQL字符串参数赋值
cmd.Parameters.Add(new SqlParameter("@pwd", newPwd));
cmd.Parameters.Add(new SqlParameter("@id", UserInfo.userId));

// 将命令发送给数据库
int res = cmd.ExecuteNonQuery();

// 根据返回值判断是否修改成功
if (res != 0)
{
MessageBox.Show("密码修改成功");
this.Close();
}
else
{
MessageBox.Show("密码修改错误");
}
、、、

你可能感兴趣的:(商超系统界面设计)