ICode9

精准搜索请尝试: 精确搜索
首页 > 数据库> 文章详细

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

2019-06-20 14:55:13  阅读:265  来源: 互联网

标签:c sql-server dbnull executenonquery default-constraint


如何将值插入存储在字符串[]中的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

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有