NullReferenceException при вызове InsertOnSubmit в Linq для Sql
Я пытаюсь вставить новый объект в свою базу данных, используя LINQ to SQL, но получаю исключение NullReferenceException, когда я вызываю InsertOnSubmit () в фрагменте кода ниже. Я передаю производный класс с именем FileUploadAudit, и все свойства объекта установлены.
public void Save(Audit audit)
{
try
{
using (ULNDataClassesDataContext dataContext = this.Connection.GetContext())
{
if (audit.AuditID > 0)
{
throw new RepositoryException(RepositoryExceptionCode.EntityAlreadyExists, string.Format("An audit entry with ID {0} already exists and cannot be updated.", audit.AuditID));
}
dataContext.Audits.InsertOnSubmit(audit);
dataContext.SubmitChanges();
}
}
catch (Exception ex)
{
if (ObjectFactory.GetInstance<IExceptionHandler>().HandleException(ex))
{
throw;
}
}
}
Вот трассировка стека:
at System.Data.Linq.Table`1.InsertOnSubmit(TEntity entity)
at XXXX.XXXX.Repository.AuditRepository.Save(Audit audit)
C:\XXXX\AuditRepository.cs:line 25"
Я добавил в класс Audit вот так:
public partial class Audit
{
public Audit(string message, ULNComponent component) : this()
{
this.Message = message;
this.DateTimeRecorded = DateTime.Now;
this.SetComponent(component);
this.ServerName = Environment.MachineName;
}
public bool IsError { get; set; }
public void SetComponent(ULNComponent component)
{
this.Component = Enum.GetName(typeof(ULNComponent), component);
}
}
И производный FileUploadAudit выглядит так:
public class FileUploadAudit : Audit
{
public FileUploadAudit(string message, ULNComponent component, Guid fileGuid, string originalFilename, string physicalFilename, HttpPostedFileBase postedFile)
: base(message, component)
{
this.FileGuid = fileGuid;
this.OriginalFilename = originalFilename;
this.PhysicalFileName = physicalFilename;
this.PostedFile = postedFile;
this.ValidationErrors = new List<string>();
}
public Guid FileGuid { get; set; }
public string OriginalFilename { get; set; }
public string PhysicalFileName { get; set; }
public HttpPostedFileBase PostedFile { get; set; }
public IList<string> ValidationErrors { get; set; }
}
Есть идеи, в чем проблема? Ближайший вопрос, который я смог найти, -Вот но мой частичный класс Audit вызывает конструктор без параметров в сгенерированном коде, и я все еще получаю проблему.
ОБНОВИТЬ:
Эта проблема возникает, только когда я передаю производный класс FileUploadAudit, класс Audit работает нормально. Класс Audit генерируется как класс linq to sql, и в производном классе нет свойств, сопоставленных с полями базы данных.