初学问题,datdataReader.GetString(dataReader.GetOrdinal("MyFieldName")) 无法取值

microd 2012-02-08 11:12:24
初学问题
dataReader.GetString(dataReader.GetOrdinal("MyFieldName")); 无法取字符字段的值,而数据类型的字段的取值却没有问题,所工
---代码如下
using (SqlCommand cmd = conn.CreateCommand())
{
cmd.CommandText = "select * from TUSER WHERE name=@n";
cmd.Parameters.Add(new SqlParameter("n",textBox1.Text));
SqlDataReader reder = cmd.ExecuteReader();
if (reder.Read())
{
int ErrorTimes = reder.GetInt32(reder.GetOrdinal("ErrorT")); //这句OK
if (ErrorTimes > 3)
{
MessageBox.Show("登录次数过多,禁止登录");
return;
}
else
{
string dbpwd = reder.GetString(reder.GetOrdinal("name"));//这句就取不取值,确认后台有值不为空
if (dbpwd == textBox2.Text)
{
ReErrorTimes();
MessageBox.Show("登录成功");

}
else
{
MessageBox.Show("登录失败");
IncErrorTimes();
}
}
}
else
{
MessageBox.Show("用户名不存在!");
}
}
...全文
162 5 打赏 收藏 转发到动态 举报
写回复
用AI写文章
5 条回复
切换为时间正序
请发表友善的回复…
发表回复
Ultimate 2012-02-09
  • 打赏
  • 举报
回复
楼上指出了错误,参数少了一个@
microd 2012-02-09
  • 打赏
  • 举报
回复
问题解决了,但仍不知真正的问题,把后台的表重新建过OK,至于参数年加@,加不加一样。
microd 2012-02-09
  • 打赏
  • 举报
回复
谢谢,加了,可是结果还是取不取?
catmax 2012-02-08
  • 打赏
  • 举报
回复
cmd.Parameters.Add(new SqlParameter("n",textBox1.Text));
cmd.Parameters.Add(new SqlParameter("@n",textBox1.Text));
microd 2012-02-08
  • 打赏
  • 举报
回复
找了好久没有找到原因。

62,046

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术交流专区
javascript云原生 企业社区
社区管理员
  • ASP.NET
  • .Net开发者社区
  • R小R
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

.NET 社区是一个围绕开源 .NET 的开放、热情、创新、包容的技术社区。社区致力于为广大 .NET 爱好者提供一个良好的知识共享、协同互助的 .NET 技术交流环境。我们尊重不同意见,支持健康理性的辩论和互动,反对歧视和攻击。

希望和大家一起共同营造一个活跃、友好的社区氛围。

试试用AI创作助手写篇文章吧