如何获取数据集的某些字段值,并赋值给文本控件

我们通常需要在数据库中读取数据记录,以便获得数据值赋予给对应的文本、下拉框和表格等等。那么我们该是如何实现了

先来个实际例子:

//--------输入学号后回车,显示学生信息和其选课成绩信息---------------
  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那列的值
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值