就像我在评论中说的那样,您的设计很糟糕!
首先,您应该具有数据访问层。这应该是大型解决方案中的项目,但是在您的情况下,您可以将其放置为新目录。在此目录中,创建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。
在这种情况下,可以在任何地方使用此方法,并且只需要一行代码即可调用它们,并且不会发生像您这样的问题。



