c#中如何用SqlDataReader sqlDR.read()?
usingSystem;usingSystem.Data;usingSystem.Configuration;usingSystem.Collections;usingS...
using System;
using System.Data;
using System.Configuration;
using System.Collections;
using System.Web;
using System.Web.Security;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Web.UI.WebControls.WebParts;
using System.Web.UI.HtmlControls;
using System.Data.SqlClient;
public partial class Default : System.Web.UI.Page
{
protected void Page_Load(object sender, EventArgs e)
{
}
protected void Button1_Click(object sender, EventArgs e)
{
string strConn = "server=WOK-MA0220\\CUI;database=design;uid=sa;pwd=sa;";
SqlConnection conn = new SqlConnection(strConn);
String strComm = "Select*from Users where UserName= ' " + UserName.Text + " ' and PassWord=' " + PassWord.Text + " ' ";
SqlCommand comm = new SqlCommand(strComm, conn);
conn.Open();
SqlDataReader dr = comm.ExecuteReader();
if (dr.Read())
{
//Session["Default"] == ok;
//string Name = (string)read["UserName"];
//string PWd = (string)read["PassWord"];
Response.Redirect("LogSuccess.aspx");
{
dr.Close();
}
}
else
{
//Session["Default"] ==null;
Response.Redirect("error.aspx");
//dr.Close();
//执行到下列语句,退出浏览器
//Response.Write("<script language='javascript'>window.opener =null;window.close();</script>");
}
//dr.Close();
conn.Close();
}
}
PS:数据库查询正确,可是用户名和密码正确时跳到了error.aspx 展开
using System.Data;
using System.Configuration;
using System.Collections;
using System.Web;
using System.Web.Security;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Web.UI.WebControls.WebParts;
using System.Web.UI.HtmlControls;
using System.Data.SqlClient;
public partial class Default : System.Web.UI.Page
{
protected void Page_Load(object sender, EventArgs e)
{
}
protected void Button1_Click(object sender, EventArgs e)
{
string strConn = "server=WOK-MA0220\\CUI;database=design;uid=sa;pwd=sa;";
SqlConnection conn = new SqlConnection(strConn);
String strComm = "Select*from Users where UserName= ' " + UserName.Text + " ' and PassWord=' " + PassWord.Text + " ' ";
SqlCommand comm = new SqlCommand(strComm, conn);
conn.Open();
SqlDataReader dr = comm.ExecuteReader();
if (dr.Read())
{
//Session["Default"] == ok;
//string Name = (string)read["UserName"];
//string PWd = (string)read["PassWord"];
Response.Redirect("LogSuccess.aspx");
{
dr.Close();
}
}
else
{
//Session["Default"] ==null;
Response.Redirect("error.aspx");
//dr.Close();
//执行到下列语句,退出浏览器
//Response.Write("<script language='javascript'>window.opener =null;window.close();</script>");
}
//dr.Close();
conn.Close();
}
}
PS:数据库查询正确,可是用户名和密码正确时跳到了error.aspx 展开
3个回答
2012-03-30
展开全部
不进if语句 说明dr.Read()为null也就是说更本就没查出数据,你的sql语句出问题了,你把' " + UserName.Text 复制到vs代码编辑器里面会发现'后面有一个空格在加上你输入的参数 也就成了UserName=空格+UserName.Text 当然查不出数据
展开全部
你把if改成while循环试一下,把数据表的所有数据循环比对一次,如果出现用户名、密码和你输入的一样的话,不可能跳转到error.aspx页面的
跳转到error.aspx页面,上面的if分支就没进去过。所以,问题就应该在if那里
先while,在循环裏if比对,正确跳出循环就行
祝你好运
跳转到error.aspx页面,上面的if分支就没进去过。所以,问题就应该在if那里
先while,在循环裏if比对,正确跳出循环就行
祝你好运
追问
我也觉得可能是这里出现了问题。因为是新手,所以不太懂,dr.Read()返回的是什么值啊?
追答
if裏面当然是bool了!
断点 跟踪,一步步调试就知道毛病出错在什麼地方了
祝你好运
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
好像又没错。。。试下断点后,把解析后的sql语句去sql里面试试能不能找到。
或试试把conn.Open();放上面一点。。
或试试把conn.Open();放上面一点。。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询