-2

尝试用数据库中的数据填充 Combobox,我正在使用 ExecuteReader,如下所示,但是当我尝试实例化我的连接时,它向我显示错误

无法隐式转换类型错误

我的 DBConnect 类代码:

public class DBConnect
{
        private SqlConnection connection;
        private string servername = "10.1.76.109,1433";
        private string database = "EngLib";
        private string dbuser;
        private string userpassword;


        public DBConnect()
        {

        }

        public void doDBConnect(string dbuserform, string userpasswordform)
        {
            dbuser = dbuserform;
            userpassword = userpasswordform;
        }


        public void Initialize()
        {

        }

        public bool openConnection()
        {
            string connectionString;
            connectionString = "Server=" + servername + ";Database=" + database + ";user id=" + dbuser + ";Password=" + userpassword;
            Console.WriteLine(connectionString);
            connection = new SqlConnection(connectionString);
            try
            {
                connection.Open();
                return true;
            }
            catch (SqlException ex)
            {
                switch (ex.Number)
                {
                    case 0:
                        MessageBox.Show("Não é possível contactar o servidor. Entre em contato com o administrador");
                        break;

                    case 18456:
                        MessageBox.Show("Usuário/Senha inválidos, tente novamente");
                        break;
                }
                return false;
            }

}

我的表单代码:

{
    public Form2()
    {
        InitializeComponent();
    }

    public void Form2_Load(object sender, EventArgs e)
    {
        SqlDataReader rdr = null;
        DBConnect sqlConnection;
        sqlConnection = new DBConnect();
        sqlConnection.doDBConnect(dbuserform: "usertest", userpasswordform: "usertest");
         {
            try
            {

                {
                    sqlConnection.openConnection();
                    SqlCommand sqlCmd;
                    sqlCmd = new SqlCommand("SELECT Material FROM EngLib");
                    sqlCmd.Connection = sqlConnection;
                    SqlDataReader sqlReader = sqlCmd.ExecuteReader();

                    while (sqlReader.Read())
                    {
                        comboBox1.Items.Add(sqlReader["Material"].ToString());
                    }

                    sqlReader.Close();
                }
            }
            finally
            {
                // close the reader
                if (rdr != null)
                {
                    rdr.Close();
                }
            }
        }
    }
}

代码中的用户名和密码只是临时的。

4

1 回答 1

1

我认为问题出在这里:

DBConnect sqlConnection;
SqlCommand sqlCmd;
sqlCmd.Connection = sqlConnection;

SqlCommand期望那Connection是类型SqlConnection,但您正在分配自己的类DBConnect

可能的修复:

暴露connection财产DBConnect并使用它。

继承DBConnectSqlConnection

直接使用SqlConnection

附加说明:您没有在班级SqlConnection内部处置DBConnect,这可能导致StackOverflowException. 你应该实施IDisposable.

于 2016-08-22T14:00:05.613 回答