Почему я не могу вставить DBNull.Value в поле изображения, допускающее значение NULL, в sql server 2005?
-
13-11-2019 - |
Вопрос
Почему я не могу вставить DBNull.Value
в обнуляемое значение image
-поле на сервере sql 2005?
Я попробовал этот код:
SqlConnection conn = new SqlConnection(@"Data Source=.\sqlexpress;Initial Catalog=PrescriptionTrackingSystem;Integrated Security=True");
conn.Open();
SqlTransaction transaction = conn.BeginTransaction();
SqlCommand command = new SqlCommand(@"INSERT INTO Customer(
ID
,Name
,TelephoneNumber
,DateOfBirth,
InsuranceProvider,
PolicyNumber,Photo)
VALUES(
@ID
,@Name
,@TelephoneNumber
,@DateOfBirth,
@InsuranceProvider,
@PolicyNumber,
@Photo)", conn);
command.Transaction = transaction;
command.Parameters.AddWithValue("@ID", 1000);
command.Parameters.AddWithValue("@Name", item.Name);
command.Parameters.AddWithValue("@TelephoneNumber", item.TelephoneNumber);
if (item.DateOfBirth != null)
{
command.Parameters.AddWithValue("@DateOfBirth", item.DateOfBirth);
}
else
{
command.Parameters.AddWithValue("@DateOfBirth", DBNull.Value);
}
command.Parameters.AddWithValue("@InsuranceProvider", item.InsuranceProvider);
command.Parameters.AddWithValue("@PolicyNumber", item.PolicyNumber);
if (item.Photo != null)
{
command.Parameters.AddWithValue("@Photo", item.Photo);
}
else
{
command.Parameters.AddWithValue("@Photo", DBNull.Value);
}
int count = command.ExecuteNonQuery();
transaction.Commit();
conn.Close();
элемент типа Customer
.
public class Customer
{
public string Name { get; set; }
public DateTime? DateOfBirth { get; set; }
public string TelephoneNumber { get; set; }
public string InsuranceProvider { get; set; }
public int? PolicyNumber { get; set; }
public byte [] Photo { get; set; }
}
При вставке я получаю это исключение:
Operand type clash: nvarchar is incompatible with image
Почему DBNull.Value
есть проблемы только с image
?Почему бы не с datetime
?
Решение
Вы можете попробовать это:
command.Parameters.Add("@Photo", SqlDbType.Image).Value = DBNull.Value;
Другие советы
Я думаю, это может быть связано с тем, что вы явно не определяете SqlParameter.SqlDbType и думаете, что он будет использовать NVARCHAR.Вместо использования AddWithValue попробуйте добавить новый SqlParameter и явно установить для SqlDbType значение SqlDbType.Image.
Вот ссылка на MSDN в котором указано, что по умолчанию используется NVARCHAR.
Вам необходимо явно указать тип параметра как SqlDbType.Image.
Я решил это так:
If (Photo.Equals(DBNull.Value)) Then
cmd.Parameters.Add("Photo", SqlDbType.Image).Value = DBNull.Value
Else
cmd.Parameters.AddWithValue("Photo", Photo)
End If
Не связан с StackOverflow