我正在一个简单的注册页面中工作,在该页面中,用户无法输入相同的用户名或电子邮件,我编写了一个阻止用户输入用户名的代码,但该代码有效,但是当我尝试防止用户输入相同的用户名时或通过电子邮件发送无效的邮件。
我的问题是,“如何添加用户无法输入已经存在的电子邮件的其他条件?”
我试图在这段代码中做到这一点,但没有成功:
protected void Button_Click(object sender, EventArgs e) { SqlConnection con = new SqlConnection( ConfigurationManager.ConnectionStrings["ConnectionString"].ConnectionString ); SqlCommand cmd1 = new SqlCommand("select 1 from Table where Name =@UserName", con); SqlCommand cmd2 = new SqlCommand("select 1 from Table where Email=@UserEmail", con); con.Open(); cmd1.Parameters.AddWithValue("@UserName", Name_id.Text); cmd2.Parameters.AddWithValue("@UserEmail", Email_id.Text); using (var dr1 = cmd1.ExecuteReader()) { if (dr1.HasRows) { Label1.Text = "user name already exists"; } using (var dr2 = cmd2.ExecuteReader()) { if (dr2.HasRows) { Label1.Text = "email already exists"; } else { dr1.Close(); dr2.Close(); //add new users con.Close(); } } } }
但我得到这个错误:
已经有一个与此命令相关联的打开的DataReader,必须先关闭它。
就像我在评论中说的那样,您的设计很糟糕!
首先,您应该具有数据访问层。这应该是大型解决方案中的项目,但是在您的情况下,您可以将其放置为新目录。在此目录中,创建SqlManager类,代码如下:
public class SqlManager { public static string ConnectionString { get { return ConfigurationManager.ConnectionStrings["DevConnString"].ConnectionString; } } public static SqlConnection GetSqlConnection(SqlCommand cmd) { if (cmd.Connection == null) { SqlConnection conn = new SqlConnection(ConnectionString); conn.Open(); cmd.Connection = conn; return conn; } return cmd.Connection; } public static int ExecuteNonQuery(SqlCommand cmd) { SqlConnection conn = GetSqlConnection(cmd); try { return cmd.ExecuteNonQuery(); } catch { throw; } finally { conn.Close(); } } public static object ExecuteScalar(SqlCommand cmd) { SqlConnection conn = GetSqlConnection(cmd); try { return cmd.ExecuteScalar(); } catch { throw; } finally { conn.Close(); } } public static DataSet GetDataSet(SqlCommand cmd) { return GetDataSet(cmd, "Table"); } public static DataSet GetDataSet(SqlCommand cmd, string defaultTable) { SqlConnection conn = GetSqlConnection(cmd); try { DataSet resultDst = new DataSet(); using (SqlDataAdapter adapter = new SqlDataAdapter(cmd)) { adapter.Fill(resultDst, defaultTable); } return resultDst; } catch { throw; } finally { conn.Close(); } } public static DataRow GetDataRow(SqlCommand cmd) { return GetDataRow(cmd, "Table"); } public static DataRow GetDataRow(SqlCommand cmd, string defaultTable) { SqlConnection conn = GetSqlConnection(cmd); try { DataSet resultDst = new DataSet(); using (SqlDataAdapter adapter = new SqlDataAdapter(cmd)) { adapter.Fill(resultDst, defaultTable); } if (resultDst.Tables.Count > 0 && resultDst.Tables[0].Rows.Count > 0) { return resultDst.Tables[0].Rows[0]; } else { return null; } } catch { throw; } finally { conn.Close(); } } }
之后,您应该具有业务对象层。在更大的解决方案是您的案例目录中的项目。如果在页面TaxesEdit.aspx中,则应在BO(业务对象)中添加Tax.cs类。
第一个按钮的类方法示例:
public DataSet GetTaxesByUserName(string userName) { SqlCommand cmd = new SqlCommand(@" select 1 from Table where Name =@UserName"); cmd.Parameters.AddWithValue("@UserName", userName); return DA.SqlManager.GetDataSet(cmd); }
您在数据集中获取所有需要的数据。之后,您进行检查,如taxsDst.Tables [0] .Rows.Count> 0(或== 0)
对于插入,您可以使用如下方法:
public virtual void Insert(params object[] colValues) { if (colValues == null || colValues.Length % 2 != 0) throw new ArgumentException("Invalid column values passed in. Expects pairs (ColumnName, ColumnValue)."); SqlCommand cmd = new SqlCommand("INSERT INTO " + TableName + " ( {0} ) VALUES ( {1} )"); string insertCols = string.Empty; string insertParams = string.Empty; for (int i = 0; i < colValues.Length; i += 2) { string separator = ", "; if (i == colValues.Length - 2) separator = ""; string param = "@P" + i; insertCols += colValues[i] + separator; insertParams += param + separator; cmd.Parameters.AddWithValue(param, colValues[i + 1]); } cmd.CommandText = string.Format(cmd.CommandText, insertCols, insertParams); DA.SqlManager.ExecuteNonQuery(cmd); }
为此,您需要在当前BO类中具有属性TableName。
在这种情况下,可以在任何地方使用此方法,并且只需要一行代码即可调用它们,并且不会发生像您这样的问题。