Я искал пару часов и не могу найти решение.
Я вставляю некоторые строки в SQL, однако в некоторых случаях используемый для этого метод может содержать пустые строки, т. Е. ""
Поэтому я хочу вместо этого вставить SQL-значение в SQL Server.
Сначала я проверяю свой метод, чтобы убедиться, что я могу вставить DBNull.Value
вручную, используя следующую команду:
cmd.Parameters.AddWithValue("@surname", DBNull.Value); // THIS WORKS OK
ОДНАКО, когда я пытаюсь выполнить следующее ниже, метод запускается без каких-либо исключений ошибки, НО столбец SQL Server не показывает нулевое значение, он просто пустой, в котором ничего нет:
cmd.Parameters.AddWithValue("@surname", (object)surname ?? DBNull.Value);
Мне просто нужно эффективное решение, не связанное с более распространенными расширениями классов и не пишущее много дополнительного кода. Каждый ответ, который я вижу на форумах, слишком сложен для такой простой задачи.
Есть идеи? Заранее спасибо ...
Вот полный метод:
public static void AddUserToUserTable(string username,
string forename,
string surname,
string emailAddress,
string password,
string accountActive,
string userGroup)
{
string cmdText1 = "INSERT INTO Users (Username, Forename, Surname, EmailAddress, Password, AccountActive, UserGroup) VALUES (@username, @forename, @surname, @emailAddress, @password, @userGroup, @accountActive)";
try
{
// The using statement will take care of the disposing of the reader and the command object.
using (SqlConnection connection = new SqlConnection(connectionString))
{
SqlCommand cmd = new SqlCommand(cmdText1, connection);
cmd.Parameters.AddWithValue("@username", username);
cmd.Parameters.AddWithValue("@forename", forename);
cmd.Parameters.AddWithValue("@surname", surname, null);
cmd.Parameters.AddWithValue("@emailAddress", emailAddress);
cmd.Parameters.AddWithValue("@password", password);
cmd.Parameters.AddWithValue("@userGroup", accountActive);
cmd.Parameters.AddWithValue("@accountActive", userGroup);
connection.Open();
cmd.ExecuteNonQuery();
log.Info("NEW User [" + username + "] Created");
}
}
catch (Exception ex)
{
log.Error(ex);
}
}