91手机视频在线-91手机视频在线观看-91手机在线-91手机在线播放-91手机在线观看

完善主體資料,免費贈送VIP會員!
* 主體類型
* 企業名稱
* 信用代碼
* 所在行業
* 企業規模
* 所在職位
* 姓名
* 所在行業
* 學歷
* 工作性質
請先選擇行業
您還可以選擇以下福利:
行業福利,領完即止!

下載app免費領取會員

NULL

ad.jpg

二次開發教程:ef 查詢相關數據

發布于:2019-07-24 16:27:06

網友投稿

更多

    public class DefaultContext : DbContext

    {

        private static string _conStr =

            @"Data Source=(LocalDB)\MSSQLLocalDB;AttachDbFilename=E:\code\gits\EntityFramework6\MultiTableDemo\MultiTableTest.mdf;Integrated Security=True";

        public DefaultContext()

            :base(_conStr)

        {

            //this.Configuration.LazyLoadingEnabled = false;

        }

        public DbSet<Person> Persons { get; set; }

 

        public DbSet<Book> Books { get; set; }

 

    }

    [Table("persons")]

    public class Person

    {

        [Key]

        [Column("person_id")]

        public int Id { get; set; }

        [Column("person_name")]

        public string Name { get; set; }        

        public Person()

        {

            Books = new List<Book>();

        }        

        public virtual List<Book> Books { get; set; }

    }

    [Table("books")]

    public class Book

    {

        [Key]

        [Column("book_id")]

        public int Id { get; set; }

        [Column("book_name")]

        public string Name { get; set; }

        [Column("person_id")]

        [ForeignKey("Person")]

        public int PersonId { get; set; }

        public Book()

        {

        }

        public virtual Person Person { get; set; }

    }

先使用下面的方法創建數據:


        static void CreateData()

        {

            using (DefaultContext context = new DefaultContext())

            {

                Person person1 = new Person

                {

                    Name = "Jim"

                };

                Book book1 = new Book()

                {

                    Name = "Book1_Name"

                };

                Book book2 = new Book()

                {

                    Name = "Book2_Name"

                };

 

                person1.Books.Add(book1);

                person1.Books.Add(book2);

                context.Persons.Add(person1);

                context.SaveChanges();

            }

        }

ef 里面查詢相關數據有三種方法:延遲加載,預先加載,顯式加載


延遲加載:這個需要將相關屬性設為virtual  如:


Person類里的public virtual List<Book> Books { get; set; } 


Book類里的 public virtual Person Person { get; set; }


并且將 DbContext的Configuration.LazyLoadingEnabled 屬性設為true(默認是true)


現在查詢Person的時候會自動查詢出相關的Book


        static void Main(string[] args)

        {

            using (DefaultContext context = new DefaultContext())

            {

                var p = context.Persons.FirstOrDefault();

                var bk1 = p.Books.FirstOrDefault();                

            }

        }


顯式加載:


首先將在DefaultContext構造函數里禁用 延遲加載,上面的代碼將查不到Book數據了


        public DefaultContext()

            :base(_conStr)

        {

            this.Configuration.LazyLoadingEnabled = false;

        }


查詢方法如下:       


       static void Main(string[] args)

        {

            using (DefaultContext context = new DefaultContext())

            {

                var p = context.Persons.FirstOrDefault();

                context.Entry(p).Collection(tp => tp.Books).Load();     //顯式加載           

                var bk1 = p.Books.FirstOrDefault();         

            }

        }


或:


        static void Main(string[] args)

        {

            using (DefaultContext context = new DefaultContext())

            {

                var bk = context.Books.FirstOrDefault();

                context.Entry(bk).Reference(b => b.Person).Load();//顯式加載     

                var p1 = bk.Person;

            }

        }


預先加載


        static void Main(string[] args)

        {

            using (DefaultContext context = new DefaultContext())

            {

                var p = context.Persons.Where(tp => tp.Name == "Jim").Include(tp => tp.Books).FirstOrDefault();

            }

        }

本文版權歸腿腿教學網及原創作者所有,未經授權,謝絕轉載。

未標題-1.jpg

上一篇:二次開發教程:HttpWebRequest&&multipart/form-data

下一篇:二次開發教程:entity framework 遷移

主站蜘蛛池模板: 免费国产99久久久香蕉 | 视频在线观看一区二区三区 | 午夜三级在线 | 亚洲国产精品免费在线观看 | 精品视频午夜一区二区 | 99久久精品国产综合一区 | 免费爱爱的视频太爽了 | 欧美成人免费全部色播 | 成人午夜大片免费7777 | 成人夜色 | 免费观看日本人成影片 | 欧美黄网站 | 日韩精品在线观看免费 | 永久精品免费影院在线观看网站 | 免费摸碰碰视频在线观看 | 国产区精品| 欧美日韩国产综合视频在线看 | 国内自拍一区 | 成人国产精品一级毛片了 | 一区中文字幕 | 久久久久欧美精品观看 | 国产精品成人一区二区 | 国产精品第1页在线观看 | 国产黄在线观看 | 免费一级毛片在线播放欧美 | 521色香蕉网在线观看免费 | 国内精品九一在线播放 | 亚洲精品视频在线播放 | 国产国产成人人免费影院 | 久久99亚洲综合精品首页 | 欧美护士激情第一欧美精品 | 亚洲999| 成人交性视频免费看 | 91麻豆影视 | 国产大片免费看 | 日本一级级特黄特色大片 | 伊人中文字幕在线观看 | 牛牛a级毛片在线播放 | 91在线看视频 | 夜恋全部国产精品视频 | 中国一级黄色毛片 |