comboBox1_SelectedIndexChanged     方法 (省市联动项目练习)   

      在定义的sql语句中想通过之前定义的comboBox1.SelectedValue,通过获得他的值(非dispvalue或者Text的内容)来进行查询另外一张表中的关联字段,但问题就来了,会提示: 

后来经过调试,问题竞出在数据绑定到控件的顺序上,把代码改成如下就好了:

            SqlHelper sh = new SqlHelper();

            string sql = "select provinceid,provinceName from s_province";
            SqlConnection conn = new SqlConnection(strcon);
            conn.Open();
            DataTable dt = sh.ExecuteDataAdpter(sql, strcon);                    
            comboBox1.DisplayMember = "provinceName";
            comboBox1.ValueMember ="provinceid";
            //一定是要赋值在前,数据邦定在后否则会运行出错误 无法绑定由多个部分组成的标识符“System.Data.DataRowView”
            comboBox1.DataSource = dt;  

*注:此方法只适用 comboBox1_SelectedIndexChanged   方法

         comboBox1_SelectedValueChanged  方法没有此问题