У меня есть DataGrid
, который заполняется из базы данных SQL Server, и у меня есть событие двойного щелчка мыши, которое открывает новое окно и заполняет Textboxes
и ComboBoxes
.
У меня есть одна маленькая проблема. если столбец с именем "RTTYPE" пуст для выбранной строки, я получаю System.FormatException: Input string was not in a correct format
, а затем ComboBox
показывает первый элемент значения из списка.
Я бы хотел, чтобы ComboBox
оставить пустым, если выбранная строка пуста. Пожалуйста, помогите!
private void dtGrid_MouseDoubleClick(object sender, MouseButtonEventArgs e)
{
// User double clicks on DataGrid Row
// Open new Window
// Populate selected textboxes with selected datarow
DataGrid gd = (DataGrid)sender;
DataRowView row_selected = gd.SelectedItem as DataRowView;
var windowToOpen = new Window1();
if (gd != null)
{
// Textboxes
windowToOpen.txt_RowRecrd.Text = row_selected["DSP_ID"].ToString();
windowToOpen.txt_acctnumber.Text = row_selected["ACCOUNT"].ToString();
windowToOpen.txt_analyst.Text = row_selected["TX_EMPLOYEE"].ToString();
windowToOpen.txt_custname.Text = row_selected["CUST_NAME"].ToString();
windowToOpen.txt_address.Text = row_selected["PREM_ADDR"].ToString();
windowToOpen.txt_Status.Text = row_selected["Status"].ToString();
windowToOpen.txt_opened.Text = row_selected["OPENED"].ToString();
windowToOpen.txt_deadline.Text = row_selected["DEADLINE"].ToString();
windowToOpen.txt_DaysOpen.Text = row_selected["DaysOpen"].ToString();
windowToOpen.txt_DateResolved.Text = row_selected["DATERSLVD"].ToString();
windowToOpen.txt_revcls.Text = row_selected["RateType"].ToString();
windowToOpen.txt_WFMissuedBy.Text = row_selected["NM_USER"].ToString();
windowToOpen.txt_firstreview.Text = row_selected["FR_DT_FIRSTREV"].ToString();
windowToOpen.txt_Latestupdate.Text = row_selected["FR_TS_LATESTUPD"].ToString();
windowToOpen.txt_reviewNotes.Text = row_selected["FR_CMMNT"].ToString();
windowToOpen.txt_ResolutionNotes.Text = row_selected["COMMENT"].ToString();
// ComboBoxes
SqlConnection connection = new SqlConnection("Data Source=WINDOWS-B1AT5HC\\SQLEXPRESS;Initial Catalog=CustomerRelations;Integrated Security=True;");
try
{
SqlDataAdapter Status_data = new SqlDataAdapter("SELECT RPTID, ReportType FROM [hb_RptType]", connection);
DataSet ds = new DataSet();
Status_data.Fill(ds, "t");
windowToOpen.cmb_UtilityRptTyp.ItemsSource = ds.Tables["t"].DefaultView;
windowToOpen.cmb_UtilityRptTyp.DisplayMemberPath = "ReportType";
windowToOpen.cmb_UtilityRptTyp.SelectedValuePath = "RPTID";
windowToOpen.cmb_UtilityRptTyp.SelectedValue = row_selected["RPTTYPE"].ToString();
// windowToOpen.cmb_UtilityRptTyp.SelectedIndex = 3; // Convert.ToInt32( row_selected["RPTTYPE"].ToString());
}
catch (Exception ex)
{
MessageBox.Show(ex.ToString());
}
windowToOpen.Show();
}
else
{
return;
}
}