How to make a nullable property in EF Codefirst?

前端 未结 3 1630
感动是毒
感动是毒 2021-01-27 02:43

I have two POCOs in my \"Bookshelf\" test application:

/// 
/// Represents a book
/// 
public class Book
{
    public int ID { get         


        
3条回答
  •  春和景丽
    2021-01-27 03:16

    You don't need to do anything special. Classes are always nullable.

    I just tried this (with MVC3):

    In my Models directory:

    namespace MvcApplication2.Models
    {
        public class Book
        {
            public int ID { get; set; }
            public string Title { get; set; }
            public string Author { get; set; }
            public string ISBN { get; set; }
            public virtual Loaner LoanedTo { get; set; }
        }
    
        public class Loaner
        {
            public int ID { get; set; }
            public string Name { get; set; }
            public virtual ICollection Loans { get; set; }
        }
    
        public class BookContext : System.Data.Entity.DbContext
        {
            public System.Data.Entity.DbSet Books { get; set; }
            public System.Data.Entity.DbSet Loaners { get; set; }
        }
    }
    

    In my HomeController:

    namespace MvcApplication2.Controllers
    {
        public class HomeController : Controller
        {
            //
            // GET: /Home/
    
            public ActionResult Index()
            {
                string message = "OK";
    
                try
                {
                    var context = new Models.BookContext();
                    var book = new Models.Book();
                    book.Title = "New Title";
                    book.Author = "New Author";
                    book.ISBN = "New ISBN";
                    context.Books.Add(book);
                    context.SaveChanges();
                }
                catch (Exception err)
                {
                    message = err.ToString();
                }
    
                ViewBag.Message = message;
    
                return View();
            }
    
        }
    }
    

    The connectionstring in Web.Config:

    
    

    When I run the application, the view displays "OK". This means that no exception was thrown. When I look in my App_Data folder, a BookContext.sdf file has been created. That database contains a table for the Books and the Loaners. The table for the Loaners is empty. The one for the Books contains one record:

    ID: 1; Title: "New Title"; Author: "New Author"; ISBN: "New ISBN"; LoanerID: null
    

提交回复
热议问题