在没有任何数据时进行无效的读取尝试
代码如下:
protected void Page_Load(object sender, EventArgs e)
{
if (!IsPostBack)
{
Sql_Conn sqlcon = new Sql_Conn();
string str = "select * from TW_channel";
SqlCommand cmd = sqlcon.CreateCommand(str);
SqlDataReader ds = cmd.ExecuteReader();
this.channel.DataSource = ds;
channel.DataTextField = "c_name";
channel.DataValueField = "id";
channel.DataBind();
this.t_name.Text = ds["c_name"].ToString();
ds.Close();
sqlcon.Close();
}
}
奇怪的是把this.t_name.Text = ds["c_name"].ToString();删除,这个channel是可以绑定的 也有数据
用这个ds["c_name"]的时候就变成没任何数据了 郁闷了死了
报错如题
------解决方案--------------------this.t_name.Text = ds["c_name"].ToString();
你并没有取数据呀
------解决方案--------------------唉。reader的行为啊。。。
绑定完了之后,reader的游标已经读到数据末尾了,你再访问当然读不到啦。。。
如果还不懂,那你先回答个问题:datareader和dataset的区别是啥?
------解决方案--------------------this.t_name.Text = ds.rows[rowindex]["c_name"].ToString();
------解决方案--------------------