4

如何将INSERT值放入存储在 SQL Server 中string[]的值,以便忽略某些值而将存储在 SQL Server 中的值作为表上的默认约束?我需要传递什么(例如 NULL 或其他)才能使用这些默认值?

目前,我在我的代码中添加了所有默认值,并且它变得越来越庞大。

下面是我的代码:

if (value == "") value = "0";

string insert = "INSERT INTO " + table + " (" + columns + ") VALUES (" + atColumns + ")";

using (SqlConnection connect = new SqlConnection(connection))
{                               
    using (SqlCommand command = new SqlCommand(insert, connect))
    {
        //adds values to corresponding parameters
        for (int i = 0; i < table_cols.Length; i++)
        {
            command.Parameters.AddWithValue("@" + table_cols[i], table_vals[i]);
        }

        foreach (SqlParameter Parameter in command.Parameters)
        {
            if (Convert.ToString(Parameter.Value) == "")
            {
                Parameter.Value = DBNull.Value;
            }
        }

        connect.Open();
        command.ExecuteNonQuery();
        response = "Success";
        return response;

如果一个特定Parameter.Value的不是 null 并且 SQL Server 设置了默认值,则此代码不适用于 null。

在 SQL Server 中,这是通过省略插入语句中的值来处理的(这种省略会触发插入表的默认值,而提供 null 会产生错误)。

4

5 回答 5

4

如果您希望 SQL Server 对列使用默认值约束,则不要将该列作为插入参数的一部分。

例子:

--From SQL Server
CREATE TABLE Orders
(
     Id INT IDENTITY PRIMARY KEY
    ,Amount INT NOT NULL
    ,Cost MONEY NOT NULL
    ,SaleDate DATE NOT NULL DEFAULT GETUTCDATE()
);



//From C#
public int Insert(decimal cost, int amount)
{
    using (var connection = new SqlConnection(connectionString))
    {
        var command = connection.CreateCommand();
        //Don't specify the SaleDate and it will insert the current time
        command.CommandText = "INSERT INTO Orders(Amount, Cost) VALUES(@Amount, @Cost); SELECT SCOPE_IDENTITY();";
        command.Parameters.AddWithValue("@Amount", amount);
        command.Parameters.AddWithValue("@Cost", cost);

        using(var reader = command.ExecuteReader())
        {
            if(reader.Read())
                return Convert.ToInt32(reader[0]);
        }
    }

    return 0;
}

如果您想在 C# 代码中使用参数列表,则只需将参数名称与其值分组,如果值为 null 并且具有默认值,则跳过它。

于 2013-02-14T20:20:59.823 回答
2

传入 NULL 告诉 SQL 您希望该列中的 NULL 覆盖默认值。如果你想在关键字 DEFAULT 中传递一些东西。我写了一篇文章,“keyword DEFAULT”,关于用法:

DEFAULT 关键字导致将默认值(来自约束)插入到列中。

请记住,当您传入 DEFAULT 时,不要在其周围加上引号。这使它成为字符串 DEFAULT 而不是关键字 DEFAULT。

于 2013-02-14T19:57:52.287 回答
0

我能想到的唯一其他方法是基于您的方法的触发器(并且您最好在那时对其进行编码)。

但是,如果您更改使用存储过程的方法,您可以在 SQL 中本地处理您的值,否则您将无法将其编码到您的应用程序中......我是否可以推荐三元语句作为您的示例:http://msdn。 microsoft.com/en-us/library/ty67wk28%28v=vs.80%29.aspx

于 2013-02-14T19:55:17.650 回答
0

如果您在列列表中包含一列,它会尝试插入您给它的值。它不会假设这NULL意味着“只插入默认值”。

如果您不想在该列中插入值,请不要将其包含在列列表(或值列表,显然)中。

虽然循环遍历表列并且不知道列名、类型等似乎更有效。从长远来看,您最好明确处理每一列,以便您可以选择是否使用默认值,验证价值等。

于 2013-02-14T19:57:07.850 回答
0

我实际上使用该INFORMATION_SCHEMA.COLUMNS表从 SQL Server 中拉回所有列默认值。然后我只是将默认值组织成 astring[]并循环通过它来插入默认值而不是空值(一些默认值是空值)。

于 2013-02-26T18:18:40.933 回答