如何修复System.InvalidCastException:'指定的转换无效。'

时间:2019-04-21 11:06:07

标签: c# listbox unhandled-exception sortedlist

我有一个预订系统程序,一个表格列出了根据选择的日期已经进行的预订。所选日期的所有预订时间都将显示在列表框中。然后,列表框中的所选项目将使用所有预订数据填充下面的文本框。

但是,我遇到此错误:

  

System.InvalidCastException:'指定的转换无效。

这是bookingClass:

    public DateTime bookingDate
    {
        get
        {
            return myDate;
        }

        set
        {
            myDate = value;
        }
    }

    public string bookingTime
    {
        get
        {
            return myTime;
        }
        set
        {
            myTime = value;
        }
    }


    public int bookingID
    {
        get
        {
            return myID;
        }
        set
        {
            myID = value;
        }
    }


    public int customerID
    {
        get
        {
            return myCust;
        }
        set
        {
            myCust = value;
        }
    }


    public string bookingTicket
    {
        get
        {
            return myTicket;
        }
        set
        {
            myTicket = value;
        }
    }

    public int bookingQuantity
    {
        get
        {
            return myNum;
        }
        set
        {
            myNum = value;
        }
    }

    public decimal bookingTotal
    {
        get
        {
            return myTotal;
        }
        set
        {
            myTotal = value;
        }
    }


    //A SortedList of booking times is returned for a given Date
    public SortedList GetBookingsByDate(DateTime bookingDate)
    {
        newCon = new System.Data.SqlClient.SqlConnection();

        String firstConStr = "Data Source=.\\SQLEXPRESS;AttachDbFilename=";
        String pathToDB = "F:\\Level 5\\Object Oriented Programs\\Programs\\assignmentPractice\\assignmentPractice\\assignmentDB.mdf;";
        String lastConStr = "Integrated Security=True;Connect Timeout=30;User Instance=True";

        newCon.ConnectionString = firstConStr + pathToDB + lastConStr;

        newCon.Open();

        SqlCommand cmBookList = new SqlCommand();
        cmBookList.Connection = newCon;
        cmBookList.CommandType = CommandType.Text;
        cmBookList.CommandText = "Select bookingID, bookingTime from Booking where bookingDate = '" + bookingDate.ToLongDateString() + "'";
        SqlDataReader drBookList = cmBookList.ExecuteReader();

        //This is a sorted list of key/value pairs
        SortedList BookList = new SortedList();

        //drBookList[0] is the key (Booking ID) and drBookList[1] is the value (Booking Time)
        while (drBookList.Read())
        {
            BookList.Add(drBookList[0], drBookList[1]);

        }
        drBookList.Close();
        newCon.Close();
        return BookList;
    }


}

这是表格:

    public bookingSearch()
    {
        InitializeComponent();
    }

    private SortedList BookList;
    private bookingClass objBooking;

    private void btnList_Click(object sender, EventArgs e)
    {
        lstBook.Items.Clear();

        bookingClass objBooking = new bookingClass();

        BookList = objBooking.GetBookingsByDate(DateTime.Parse(dtpDate.Text));

        //Populate the ListBox with the Booking times
        if (BookList.Count == 0)
        {
            lstBook.Items.Add("No Records");
            return;
        }
        foreach (DictionaryEntry book in BookList)
        {
            lstBook.Items.Add(book.Value);
        }
        lstBook.SelectedIndex = 0;


    }

    private void lstBook_SelectedIndexChanged(object sender, EventArgs e)
    {
        if (BookList.Count > 0)     //Don't process if 'No Records'
        {
            //Get the Booking details for a particular selected time in the list
            //The SelectedIndex is used to read the Key value from the
            //SortedList which holds the bookingID
            objBooking.GetBookingsByDate((DateTime)BookList.GetKey(lstBook.SelectedIndex));

            txtID.Text = objBooking.bookingID.ToString();
            txtCust.Text = objBooking.customerID.ToString();
            txtTime.Text = objBooking.bookingTime;
            txtTicket.Text = objBooking.bookingTicket;
            txtNum.Text = objBooking.bookingQuantity.ToString();
            txtTotal.Text = objBooking.bookingTotal.ToString();
        }
    }

}

出现错误时,它会突出显示此行:

objBooking.GetBookingsByDate((DateTime)BookList.GetKey(lstBook.SelectedIndex))

非常感谢您的帮助。

0 个答案:

没有答案