我们通常需要在数据库中读取数据记录,以便获得数据值赋予给对应的文本、下拉框和表格等等。那么我们该是如何实现了
先来个实际例子:
//--------输入学号后回车,显示学生信息和其选课成绩信息---------------
private void txt1_KeyPress(object sender, System.Windows.Forms.KeyPressEventArgs e)
{
if(e.KeyChar==13)
{
txt2.Clear();//先清空信息
txt3.Clear();
dataSet21.Clear();
string strConn="workstation id=localhost;Integrated Security=SSPI;database=eisbook;";
SqlConnection cn=new SqlConnection(strConn);
cn.Open();
SqlCommand cmd=cn.CreateCommand();
cmd.CommandText="select a.姓名,b.班级名称,a.学籍编号 from 学生信息 a,班级信息 b "
+"where(a.班级编号=b.班级编号)and(学号='"+txt1.Text.Trim()+"')";
// 可以改为以下:
// string sqlStr="select a.姓名,b.班级名称,a.学籍编号 from 学生信息 a,班级信息 b "
+"where(a.班级编号=b.班级编号)and(学号='"+txt1.Text.Trim()+"')";
// SqlCommand cmd=new Sqlcommand(sqlStr,cn)
SqlDataReader dr=cmd.ExecuteReader();
dr.Read();//读入学生的数据
if(!dr.HasRows)//判断学号是否输入正确
{
MessageBox.Show("无此学生,请重新输入学号","提示",Me ssageBoxButtons.OK,MessageBoxIcon.Stop);
dr.Close();
return;
}
txt2.Text=dr.GetValue(0).ToString().Trim();//显示姓名
txt3.Text=dr.GetValue(1).ToString().Trim();//显示班级名称
dr.Close();
da1.SelectCommand.Parameters[0].Value=txt1.Text.Trim();
da1.Fill(dataSet21);
}
}
>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
分析案例:
案例中采用SqlDataReader类创建对象dr,使用ExecuteReader()方法执行SQL语句,Read()方法,读取数据。相当于填充到dr中,如何读取数据值?假设我继续定义各个TextBox控件,那么我们可以采用这种方法:TextBox1.Text=dr.GetValue(0).ToString().Trim();
这里:GetValue(0)指取得该行第一列的值。括号里可以是int型的,取得的时第i+1列的值 或者是string类型,如GetValue("name"),指取得列名为name那列的值