Как вставить dbnull.value в параметры.C#

Место общения программистов C#
Ответить
Anonymous
 Как вставить dbnull.value в параметры.

Сообщение Anonymous »

Я искал пару часов и не могу найти решение. < /p>
Я вставляю некоторые строки в SQL, однако в случае метода, который я использую для этого, может содержать строки, которые пустые, то есть "" < /p>
Поэтому я хочу вставить null value wit null nater sturn server вместо Sql Server. Я могу вставить dbnull.value вручную, используя следующее:
cmd.Parameters.AddWithValue("@surname", DBNull.Value); //THIS WORKS OK
< /code>
Однако, когда я пробую следующее ниже, метод работает без какого -либо исключения ошибки, но столбец SQL Server не показывает нулевое значение, он просто пуст, без ничего в нем: < /p>
cmd.Parameters.AddWithValue("@surname", (object)surname ?? DBNull.Value);
< /code>
Я просто хочу эффективное решение, не возившиеся с более распространенными расширениями класса и не написав множество дополнительных кодов. Каждый ответ, который я вижу на форумах, просто сложный для того, что должно быть такой простой задачей. < /P>
Вот полный метод: < /p>
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, @accountActive, @userGroup)";

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);
}
}


Подробнее здесь: https://stackoverflow.com/questions/555 ... -empty-str
Ответить

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

Вернуться в «C#»