数据库
首页 > 数据库> > 获取C#以将默认值插入SQL Server

获取C#以将默认值插入SQL Server

作者:互联网

如何将值插入存储在字符串[]中的SQL Server中,以便忽略某些值以支持存储在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中,通过省略insert语句中的值来处理此问题(此省略会触发为表插入默认值,而提供null会产生错误).

解决方法:

如果希望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且它具有默认值,则只需跳过它.

标签:c,sql-server,dbnull,executenonquery,default-constraint
来源: https://codeday.me/bug/20190620/1245448.html