0
  1. 我正在从另一个数据网格视图中导入一行以进行编辑。
  2. 编辑值。
  3. 保存值。但我不希望用户在主键表列中进行更改。

我有主键列的名称

string sql = "SELECT ColumnName = col.column_name FROM information_schema.table_constraints tc INNER JOIN information_schema.key_column_usage col ON col.Constraint_Name = tc.Constraint_Name AND col.Constraint_schema = tc.Constraint_schema WHERE tc.Constraint_Type = 'Primary Key' AND col.Table_name = '" + _lstview_item + "'";
            SqlConnection conn2 = new SqlConnection(cc.connectionString(cmb_dblist.Text));
            SqlCommand cmd_server2 = new SqlCommand(sql);
            cmd_server2.CommandType = CommandType.Text;
            cmd_server2.Connection = conn2;
            conn2.Open();
            string ColumnName = (string)cmd_server2.ExecuteScalar();
            //string ColumnName = (string)cmd_server2.ExecuteScalar();
            conn2.Close();

我正在建立更新声明如下

 u.Append("UPDATE ");
                    u.Append("[Ref].[");
                    u.Append(_lstview_item);
                    u.Append("]");
                    u.Append("SET ");
                    for (i = 0; i < col_no; i++)
                    {
                        u.Append(col_name);
                        u.Append(" = ");
                        u.Append("'");
                        u.Append(col_value);
                        u.Append("'");
                    }

在这种情况下,我如何检测用户是否正在更改主键列的值?

4

1 回答 1

0

你不应该像那样连接你的 SQL 语句。

而是使用 SQL 参数来设置各个属性。

查看此示例中如何使用 SQLParameters 的示例:http: //www.dotnetperls.com/sqlparameter

希望这可以帮助!

于 2013-08-22T09:58:02.350 回答