Исключение формата строки ввода ComboBox, когда выбор строки DataGrid пуст - PullRequest
0 голосов
/ 15 апреля 2020

У меня есть 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;
        }

    }

1 Ответ

0 голосов
/ 15 апреля 2020

Если вы выберете null для Selected Value из ComboBox, то возникнет исключение. Если ваши данные являются простой строкой, вы можете использовать SelectedItem вместо SelectedValue. Или выполните нулевую проверку:

if(row_selected["RPTTYPE"] is string rateType) windowToOpen.cmb_UtilityRptTyp.SelectedValue = rateType;
else UtilityRptTyp.SelectedIndex = -1;
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...