栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

检查用户名或用户电子邮件已存在

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

检查用户名或用户电子邮件已存在

就像我在评论中说的那样,您的设计很糟糕!

首先,您应该具有数据访问层。这应该是大型解决方案中的项目,但是在您的情况下,您可以将其放置为新目录。在此目录中,创建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。

在这种情况下,可以在任何地方使用此方法,并且只需要一行代码即可调用它们,并且不会发生像您这样的问题。



转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/405371.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号