2010-06-23 210 views
1

我有一个C#程序,我正在处理,但我不能让ComboBoxColumn显示为我想要的。C#DataGridView组合框绑定问题

我有两个表。一个包含价格列表。 (列:PriceID,PartID,Price,MinimumQuantity,CustomerID,ExpiryDate)另一张表,零件列表包含(列:PartID,PartNumber)。什么

我想要做的是显示PartNumber在一个ComboBoxColumn与PartID作为值。但是我想为每个价格行自动选择相应的零件编号。

这是否有意义!?

我目前在每一行得到的是价格,数量和到期日期以及ComboBoxColumn,其中部件列表填充了组合框,但未选择任何值。

请有人可以帮助我这个。

请参阅下面的代码。

 DbConnection dbConn = new DbConnection(getConnectionStr()); 
     dbConn.execQuery("EXEC RBS_CustomerSpecificPriceListSelect " + customerID + ";", "CustomerPriceList"); 
     dbConn.execQuery("EXEC RBS_PartsSelect;", "Parts"); 

     DataTable dtCustomerPrices = dbConn.getDataTable("CustomerPriceList"); 
     DataTable dtParts = dbConn.getDataTable("Parts"); 

     dgvCustomerPrices.AutoGenerateColumns = false; 
     dgvCustomerPrices.DataSource = dtCustomerPrices; 
     dgvCustomerPrices.AutoSizeRowsMode = DataGridViewAutoSizeRowsMode.AllCells; 

     SetupDGVColumns(dtCustomerPrices, dtParts); 

然后生成列。

private void SetupDGVColumns(DataTable dtCustomerPrices, DataTable dtParts) 
    { 
     // Parts Dropdown 
     DataGridViewComboBoxColumn cboPartsColumn = new DataGridViewComboBoxColumn(); 
     cboPartsColumn.DisplayStyle = DataGridViewComboBoxDisplayStyle.Nothing; 
     cboPartsColumn.DataSource = dtParts; 
     cboPartsColumn.HeaderText = "PartNumber"; 
     cboPartsColumn.DisplayMember = "PartNumber"; 
     cboPartsColumn.ValueMember = "PartID"; 
     cboPartsColumn.DataPropertyName = "PartID"; 
     cboPartsColumn.Width = 110; 
     cboPartsColumn.AutoComplete = true; 
     dgvCustomerPrices.Columns.Add(cboPartsColumn); 

     // MinimumQuantity Textbox 
     DataGridViewTextBoxColumn tbcMinimumQuantityColumn = new DataGridViewTextBoxColumn(); 
     tbcMinimumQuantityColumn.DataPropertyName = "MinimumQuantity"; 
     tbcMinimumQuantityColumn.HeaderText = "MinimumQuantity"; 
     tbcMinimumQuantityColumn.ValueType = typeof(double); 
     tbcMinimumQuantityColumn.Width = 140; 
     tbcMinimumQuantityColumn.DefaultCellStyle.Format = "#####0.00"; 
     dgvCustomerPrices.Columns.Add(tbcMinimumQuantityColumn); 

     // Price Textbox 
     DataGridViewTextBoxColumn tbcPriceColumn = new DataGridViewTextBoxColumn(); 
     tbcPriceColumn.DataPropertyName = "Price"; 
     tbcPriceColumn.HeaderText = "Price"; 
     tbcPriceColumn.ValueType = typeof(double); 
     tbcPriceColumn.Width = 100; 
     tbcPriceColumn.DefaultCellStyle.Format = "#####0.00"; 
     dgvCustomerPrices.Columns.Add(tbcPriceColumn); 

     // ExpiryDate Textbox 
     DataGridViewTextBoxColumn tbcExpiryDateColumn = new DataGridViewTextBoxColumn(); 
     tbcExpiryDateColumn.DataPropertyName = "ExpiryDate"; 
     tbcExpiryDateColumn.HeaderText = "ExpiryDate"; 
     tbcExpiryDateColumn.ValueType = typeof(string); 
     tbcExpiryDateColumn.DefaultCellStyle.Format = "d"; 
     dgvCustomerPrices.Columns.Add(tbcExpiryDateColumn); 
    } 
+0

可以肯定的是,这只是Cb列中不起作用的初始选择?你能改变一行的PartId吗? – 2010-06-23 12:36:16

+0

是的,我会认为你可以将两个表绑定在一起,也许组合框将选择正确的ID值,因为它绑定到另一个表。有什么我失踪? – ShaunBokenham 2010-06-24 08:28:24

+0

它看起来不错,这就是为什么我问它是否在其他方面的作品。可能在列名或其他东西中显示错字。 – 2010-06-24 11:53:24

回答

0

好,所以这是完全白痴的我的一部分。选择组合列数据的SQL查询在SELECT子句中没有相应的行ID。

尽管谢谢大家的帮助!我感到很傻!