c#用datareader访问sql的一个问题!
SqlCommandcmd=newSqlCommand();cmd.CommandText="selectmach_nofromreg";//第一个表表名regcmd.C...
SqlCommand cmd = new SqlCommand();
cmd.CommandText = "select mach_no from reg";//第一个表表名reg
cmd.Connection = conn;
SqlDataReader rs = cmd.ExecuteReader();//开一个datereader
while (rs.Read())//逐行返回
{
cmd.CommandText = "select mach_no,to_char(SITE_TIME,'yyyy-mm-dd
hh24:mi:ss'),lng,lat from site where mach_no=" +
rs.getvalue(0).ToString() + " order by to_char(SITE_TIME,'yyyy-mm-dd
hh24:mi:ss') asc";//利用rs的返回值在表site中查询对应的几个字段数据
cmd.Connection = conn;
SqlDataReader rs2 = cmd.ExecuteReader();//开一个新的datereader
while (rs2.Read())//逐行返回
{
}
rs2.Close();
}
rs.Close();
我用c#对sql数据库中两个表做这样的查询。但是报错在SqlDataReader rs2 = cmd.ExecuteReader();:已有打开的与此command相关联的datareader,必须首先将其关闭。
我不知道为什么access,sql数据库这么写都会报错。这是不让我在datareader中套循环么?要将rs先关闭么?但是rs我没法做循环了啊。这里请教各位做sql开发过的大神了、! 展开
cmd.CommandText = "select mach_no from reg";//第一个表表名reg
cmd.Connection = conn;
SqlDataReader rs = cmd.ExecuteReader();//开一个datereader
while (rs.Read())//逐行返回
{
cmd.CommandText = "select mach_no,to_char(SITE_TIME,'yyyy-mm-dd
hh24:mi:ss'),lng,lat from site where mach_no=" +
rs.getvalue(0).ToString() + " order by to_char(SITE_TIME,'yyyy-mm-dd
hh24:mi:ss') asc";//利用rs的返回值在表site中查询对应的几个字段数据
cmd.Connection = conn;
SqlDataReader rs2 = cmd.ExecuteReader();//开一个新的datereader
while (rs2.Read())//逐行返回
{
}
rs2.Close();
}
rs.Close();
我用c#对sql数据库中两个表做这样的查询。但是报错在SqlDataReader rs2 = cmd.ExecuteReader();:已有打开的与此command相关联的datareader,必须首先将其关闭。
我不知道为什么access,sql数据库这么写都会报错。这是不让我在datareader中套循环么?要将rs先关闭么?但是rs我没法做循环了啊。这里请教各位做sql开发过的大神了、! 展开
展开全部
SqlCommand cmd = new SqlCommand();
你试试声明cmd1,cmd2试试,一个cmd怎么可以嵌套一个同名的cmd。
你试试声明cmd1,cmd2试试,一个cmd怎么可以嵌套一个同名的cmd。
追问
SqlCommand cmd = new SqlCommand();
SqlCommand cmd2 = new SqlCommand();
cmd.Connection = conn;
cmd2.Connection = conn;
SqlDataReader rs2 = cmd2.ExecuteReader();/
还是报错了...同样的位置。我再oracle里这么写就行..
追答
一个connection只能存在一个datareader,可以试试数据集的方式。
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询