我有一个课程,我在那里写了我所有的方法。 然后我有我的第一页Web应用程序,我在那里有一些代码。 我面对这个
在该行:
sda.Fill(dsUsers.tblMembers);
这是我的代码,所以我希望你能帮助我:
namespace MosquesNetwork
{
public class cUsers2
{
SqlConnection scn;
SqlDataAdapter sda;
SqlCommandBuilder scb;
SqlCommand SqlStr;
public cUsers2()
{
SqlConnection scn = new SqlConnection (ConfigurationManager.ConnectionStrings["MosquesDBConnectionString"].ConnectionString);
sda = new SqlDataAdapter();
scb = new SqlCommandBuilder(sda);
}
public bool CheckUserName(string UserName)
{
DsUsers2 dsUsers=new DsUsers2();
bool Success;
string SqlStr="select * from tblUsers where Username='"+UserName+"' ";
sda.SelectCommand=new SqlCommand(SqlStr, scn);
sda.Fill(dsUsers.tblMembers);
sda.Fill(dsUsers.tblMembers);
Success=dsUsers.tblMembers.Rows.Count>0;
return Success;
}
然后我在webform中按下登录按钮时有这段代码:
protected void Button1_Click(object sender, EventArgs e)
{
if (txtuser.Text.Trim().Length>0 && txtpass.Value.Length>0 )
{
cUsers2 cUsers=new cUsers2();
DsUsers2 dsUser=new DsUsers2();
bool Success;
if (txtuser.Text.Trim()=="admin")
{
Success=cUsers.CheckAdminPass(txtuser.Text.Trim(),txtpass.Value.Trim());
if (Success)
{
Response.Redirect("WebForm2.aspx");
}
}
dsUser=cUsers.Checkpassword(txtuser.Text.Trim(), txtpass.Value.Trim(),out Success);
if(Success)
{
Session["ID"]=dsUser.tblMembers.Rows[0][dsUser.tblMembers.IDUserColumn].ToString();
System.Web.HttpContext.Current.Response.Redirect("frmProfile.aspx");
}
else lblerror.Text="invalid username & password";
}
}
答案 0 :(得分:3)
看看你的构造函数:
SqlConnection scn = new SqlConnection(...);
宣布单独的 scn
局部变量,因此scn
实例变量保持为null。如果您只是将其更改为:
scn = new SqlConnection(...);
可能很好地解决了眼前的问题。在我看来,这不是一个好的设计 - 我更喜欢在SqlConnection
区块中创建using
,而实际需要它 - 但那是什么&#39 ;现在出错了......
答案 1 :(得分:0)
我也遇到了这个问题。搜索后问题发现我提供SqlDataAdapter的连接对象不是Initialize所以连接传递为null
答案 2 :(得分:0)
//Try To Fetch The Value Like this...
protected void Search_Emp_Click(object sender, EventArgs e)
{
SqlCommand cmd;
SqlConnection con;
SqlDataAdapter ad;
con = new SqlConnection(); //making instance of SqlConnection
con.ConnectionString = ConfigurationManager.ConnectionStrings["cn"].ConnectionString; //Invoking Connection String
con.Open(); //Opening Connection
if (Ddl_Emp_Search.SelectedItem.Text == "Date Of Joining")
{
cmd = new SqlCommand("Select Emp_Name,Contact_No,City,Emp_Desig,Place_Code from emp_registration where Emp_Doj=@Emp_Doj",con);
cmd.Parameters.Add("@Emp_Doj", SqlDbType.NVarChar, 50).Value = TextBox1.Text;
}
else if (Ddl_Emp_Search.SelectedItem.Text == "Name")
{
cmd = new SqlCommand("Select Emp_Name,Place_Code,Emp_Code,Emp_Desig from emp_registration where Emp_Name=@Emp_Name", con);
cmd.Parameters.Add("@Emp_Name", SqlDbType.NVarChar, 50).Value = TextBox1.Text;
}
else if (Ddl_Emp_Search.SelectedItem.Text == "Employee Code")
{
cmd = new SqlCommand("Select Emp_Name,Contact_No,City,Emp_Desig,Place_Code from emp_registration where Emp_Code=@Emp_Code", con);
cmd.Parameters.Add("@Emp_Code", SqlDbType.NVarChar, 50).Value = TextBox1.Text;
}
else if (Ddl_Emp_Search.SelectedItem.Text == "City")
{
cmd = new SqlCommand("Select Emp_Name,Contact_No,City,Emp_Desig,Place_Code from emp_registration where City=@City", con);
cmd.Parameters.Add("@City", SqlDbType.NVarChar, 50).Value = TextBox1.Text;
}
else
{
Response.Write("There is Something Worng....");
}
ad = new SqlDataAdapter(cmd); // Here IS THE PROBLEM WHEN YOU DOES'NT PASS CMD (Command instance) to the Data Adapter then there is a problem of ( Fill: SelectCommand.Connection property has not been initialized)
DataSet ds = new DataSet();
ad.Fill(ds);
GridView1.DataSource = ds;
GridView1.DataBind();
}
答案 3 :(得分:0)
Vishal Sir,如果您遇到了这个问题,请确定是否将'cmd'传递给SQL DATA ADAPTER。 例如:
ad = new SqlDataAdapter(cmd);