WinForm中DataGridView如何显示主键表值

原创|其它|编辑:郝浩|2009-08-26 11:53:52.000|阅读 1546 次

概述:WinForm在很多项目中应用广泛,同时也会遇到很多问题,本文所提到的一些解决方法和思路,希望对大家有所帮助。

# 界面/图表报表/文档/IDE等千款热门软控件火热销售中 >>

  WinForm在很多项目中应用广泛,同时也会遇到很多问题,本文所提到的一些解决方法和思路,希望对大家有所帮助。

  在项目中经常遇到比如:客户管理项目设计时,客户信息表包含客户级别表中的级别编号字段,客户级别表中的每个级别编号将对应一个级别说明,下面就是具体的做法:

  客户管理界面中的DataGridView绑定kh表,包括字段:客户类别(绑定客户类型表主键id),客户公司,客户电话……

  界面中的类别采用了combox控件绑定类别表主键id,combox控件的name为LB_CB显示值为字段lbmc,绑定方法为:

  string sql = "select * from lb";

  SqlDataAdapter DA = new SqlDataAdapter(sql, Constr);

  DataTable DT = new DataTable(); LB_CB.DataSource = DT;

  LB_CB.DisplayMember = "lbmc";

  LB_CB.ValueMember = "id";

  连接字符串Constr可以从config里读取也可以直接写在类里。

  界面中的DataGridView控件name为DGV绑定的是客户信息表,绑定的代码如下:

  string sql = "select * from kh";

  SqlDataAdapter DA = new SqlDataAdapter(sql, Constr);

  DataTable DT = new DataTable();

  DGV.DataSource = DA.Fill(DT);

  现在设置一下DataGridView中显示客户类别的列的显示方式:

  改变columtype属性和DisplayStyle属性值如下截图

  同时在显示数据内容的方法中加入如下代码:

  改变DataGridView的列类型

  string sql = "select * from lb";    
  SqlDataAdapter DA = new SqlDataAdapter(sql, Constr);    
  DataTable DT = new DataTable();    
  LB_CB.DataSource = DT;    
  LB_CB.DisplayMember = "lbmc";    
  LB_CB.ValueMember = "id"; 

  在点击DGV的列时,想实现将本条记录显示想下面的文本框里代码如下:

  string sql = "select * from kh";    
  SqlDataAdapter DA = new SqlDataAdapter(sql, Constr);    
  DataTable DT = new DataTable();    
  DGV.DataSource = DA.Fill(DT); 

  现在设置一下DataGridView中显示客户类别的列的显示方式:

  改变columtype属性和DisplayStyle属性值如下截图

  同时在显示数据内容的方法中加入如下代码:

  string sql = "select * from lb";   
  SqlDataAdapter DA = new SqlDataAdapter(sql, Constr);   
  DataTable DT = new DataTable();   
  ((DataGridViewComboBoxColumn)DGV.Columns[1]).DataSource = DA.Fill(DT);   
  ((DataGridViewComboBoxColumn)DGV.Columns[1]).DisplayMember = "lbmc";   
  ((DataGridViewComboBoxColumn)DGV.Columns[1]).ValueMember = "id";

  改变DataGridView的列类型

  在点击DGV的列时,想实现将本条记录显示想下面的文本框里代码如下:

  private void DGV_CellClick(object sender, DataGridViewCellEventArgs e)   
  {   
    if (e.RowIndex > -1)   
    {   
      id = DGV.Rows[e.RowIndex].Cells[0].Value.ToString();   
      LB_CB.SelectedValue = DGV.Rows[e.RowIndex].Cells[1].Value;   
      gs_TB.Text = DGV.Rows[e.RowIndex].Cells[2].Value.ToString();   
      sj_TB.Text = DGV.Rows[e.RowIndex].Cells[3].Value.ToString();   
      yx_TB.Text = DGV.Rows[e.RowIndex].Cells[4].Value.ToString();   
      fzr_TB.Text = DGV.Rows[e.RowIndex].Cells[5].Value.ToString();   
    }   
  }  


标签:

本站文章除注明转载外,均为本站原创或翻译。欢迎任何形式的转载,但请务必注明出处、不得修改原文相关链接,如果存在内容上的异议请邮件反馈至chenjj@evget.com

文章转载自:IT专家网

为你推荐

  • 推荐视频
  • 推荐活动
  • 推荐产品
  • 推荐文章
  • 慧都慧问
扫码咨询


添加微信 立即咨询

电话咨询

客服热线
023-68661681

TOP