- 1、本文档共12页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
MVC3EF4.1學习系列(一)创建EF4.1codefirst的第一个实例
窗体顶端
MVC3+EF4.1学习系列(一)-------创建EF4.1 code first的第一个实例
文章索引和简介
这次要做的是个学校管理的demo(通俗些)
先建一个MVC3的应用程序? 因为我们是code first 所以 开始创建实体类
一.创建Model
学生和学生成绩登记表是一对多的关系? 一个学生可以有多次登记 (因为有多个课程)? 一个课程也可以有多个登记?? 可以看出 其实就是 学生和课程 存在一个多对多的关系
为什么这么建立模型呢?这节主要不是讨论关系 关系这个会放到? 第三节来讨论~~
现在开始创建学生的实体类
using System;using System.Collections.Generic;namespace ContosoUniversity.Models{ public class Student { public int StudentID { get; set; } public string LastName { get; set; } public string FirstMidName { get; set; } public DateTime EnrollmentDate { get; set; } public virtual ICollectionEnrollment Enrollments { get; set; } }}
在这里面 这个StudentID将被默认的设为主键? EF将会默认的给名字为ID的或者带ID的设置为主键
而Enrollments是一个导航属性? 将做为外键 ?? 导航属性定义为virtual 以便于实现延迟加载?
? 接下来 创建登记录入表(关系表)的实体类?
using System;using System.Collections.Generic;namespace ContosoUniversity.Models{ public class Enrollment { public int EnrollmentID { get; set; } public int CourseID { get; set; } public int StudentID { get; set; } public decimal? Grade { get; set; } public virtual Course Course { get; set; } public virtual Student Student { get; set; } }}
这里面 我们的成绩是可空类型???? 学生实体有多个 Enrollment 而Enrollment有一个学生实体的导航属性 这里面 我们既有学生ID 又有学生实体属性 我们会担心 会不会生成两个呢StudentID?不用担心 EF很聪明 在关系表里 只有一个studentID
接下来就是创建课程实体了
using System;using System.Collections.Generic;namespace ContosoUniversity.Models{ public class Course { public int CourseID { get; set; } public string Title { get; set; } public int Credits { get; set; } public virtual ICollectionEnrollment Enrollments { get; set; } }}
OK了 实体创建好了 接下来 我们要创建一个 数据库上下文
二.Creating the Database Context
这个类主要是把上面创建的实体类包含再里面? 指定哪些实体类包含在我们的数据模型中 还有 这个类可以指定我们的映射关系 还可以指定一些生成的约束关系总之 很有用的
这里面 我们先创建一个DAL的文件夹 然后在下面新建一个类 叫做SchoolContext? 并且继承DbContext
using System;using System.Collections.Generic;using System.Linq;using System.Web;using System.Data;using System.Data
您可能关注的文档
- ms5.5的安裝.doc
- MSA四合一檢测仪的结构功能及操作.doc
- MSN無法登录常用解决办法.docx
- MSP430與I2C总线接口技术的研究.doc
- MSSQL數据库备份和还原图文教程.doc
- MSSQL轉ACCESS的方法和常见问题解决办法(图文).doc
- mstp應用技术研究.doc
- MS的一些問题归拢.doc
- MT1104-2009煤巷錨杆支护技术规范.doc
- MT1104-2009煤巷錨杆支护技术规范(仿宋).doc
- 2024年江西省高考政治试卷真题(含答案逐题解析).pdf
- 2025年四川省新高考八省适应性联考模拟演练(二)物理试卷(含答案详解).pdf
- 2025年四川省新高考八省适应性联考模拟演练(二)地理试卷(含答案详解).pdf
- 2024年内蒙通辽市中考化学试卷(含答案逐题解析).docx
- 2024年四川省攀枝花市中考化学试卷真题(含答案详解).docx
- (一模)长春市2025届高三质量监测(一)化学试卷(含答案).pdf
- 2024年安徽省高考政治试卷(含答案逐题解析).pdf
- (一模)长春市2025届高三质量监测(一)生物试卷(含答案).pdf
- 2024年湖南省高考政治试卷真题(含答案逐题解析).docx
- 2024年安徽省高考政治试卷(含答案逐题解析).docx
文档评论(0)