获取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