一.
1.效果圖展示
2.5z.gif
2.功能及后臺(tái)數(shù)據(jù)庫(kù)圖示
在啟動(dòng)程序中能看見數(shù)據(jù)庫(kù)中的信息之類的禾嫉。
捕獲.PNG
三.ADO.NET查詢數(shù)據(jù)庫(kù)流程
1)導(dǎo)入命名空間昌执。
2)定義數(shù)據(jù)庫(kù)連接字符串妙同,創(chuàng)建connection對(duì)象杈湾;
3)打開連接圣勒;
4)利用command對(duì)象的ExecuteReader()方法執(zhí)行Select查詢語(yǔ)句费变;
5)利用ExecuteReader()方法返回的DataReader對(duì)象讀取數(shù)據(jù)摧扇,顯示到界面上;
6)關(guān)閉連接胡控。
四.重要代碼展示
String connStr = "Data Source=.;Initial Catalog=SuperMarketSales;Integrated Security=True";
SqlConnection sqlConn = new SqlConnection(connStr);
try
{
// 連接數(shù)據(jù)庫(kù)
sqlConn.Open();
// 在數(shù)據(jù)庫(kù)中查詢USERS表
String sqlStr = "select * from USERS";
SqlCommand cmd = new SqlCommand(sqlStr, sqlConn);
SqlDataReader dr = cmd.ExecuteReader();
// 解析數(shù)據(jù)
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(“訪問數(shù)據(jù)庫(kù)出錯(cuò)“ + exp.Message);
}
finally
{
sqlConn.Close();
}
String connStr = "Data Source=.;Initial Catalog=SuperMarketSales;Integrated Security=True";
SqlConnection sqlConn = new SqlConnection(connStr);
try
{
sqlConn.Open();
// 數(shù)據(jù)獲取過程扳剿,參見后面PPT
}
catch (Exception exp)
{
MessageBox.Show("數(shù)據(jù)庫(kù)連接失敗“ + exp.Message);
}
finally
{
sqlConn.Close();
}
String sqlStr = "";
if (this.cbb_UserType.Text == "收銀員")
{
// 注意USER是SQL Server關(guān)鍵字,表名不能命名為USER昼激,而應(yīng)當(dāng)用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登錄庇绽,而不是用戶名,用戶名可能會(huì)重復(fù)
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();
// 如果從數(shù)據(jù)庫(kù)中查詢到記錄橙困,則表示可以登錄
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 == "庫(kù)管員")
{
// 顯示庫(kù)管員主界面
MainFormAdmin formAdmin = new MainFormAdmin();
formAdmin.Show();
// 隱藏登錄界面
this.Hide();
}
注:
首先連接數(shù)據(jù)庫(kù)瞧掺,在數(shù)據(jù)庫(kù)中查詢users表,之后解析數(shù)據(jù)凡傅,在數(shù)據(jù)獲取辟狈,注意user是sql,sever關(guān)鍵字夏跷,表命不能夠?yàn)閡ser哼转,而應(yīng)當(dāng)用users,并且注意是用用戶登錄槽华,不是用戶名壹蔓,用戶名可能會(huì)重復(fù),在從數(shù)據(jù)庫(kù)中查詢到記錄猫态,表示可以登錄佣蓉。最后完成登錄。