EF的学习
今天学习了ORM中的Entity FrearmeWork框架,其实之前看到orm框架,感觉好高大上啊,还没准备去了解它那,今天我们就学习了这个,其实Entity FrearmeWork框架和Nhibernate实现ORM的两套方案,一是用于系统与数据库之间的操作交互和实体类与SQL语句之间的转换。另一个为ORM自动生成工具,用于实体类,前台HTML代码,业务逻辑调用代码的自动生成。但是我们目前仅仅学习了Entity FrearmeWork框架,下面就简单的总结一下它的建构。
一.从数据库映射C#项目
添加一个ADO.NET实体数据模型,然后我们根据向导添加完成。
下面来看下他们的内容,需要注意的有四部分,我们需要注意两部分,分别为StudentContext.cs和Register.cs,Student.cs,在这里说一下连接的境像:
在这里我么可以看到StudentEntities继承了DbContext的连接,而DbContext存在一个方法连接我们的数据库,参数中存在一个属性ConnectionString,关系就是这样的。
这里就是一个自动映射成的实体类,和数据库中的字段是一样的。
二.现在C#中创建实体,然后映射到数据库
仍然不变的使我们要添加一个ADO.NET实体数据模型,然后建立一个空模型即可,然后添加实体,设置关系以及属性的类型,最后选择根据模型生成数据库,最重要的是需要执行一个“执行”即可,这个是不能忘记的,然后我们即可把C#中的实体映射到我们的数据库中。
在这里,我们可以好奇为什么它们没有关系怎么可以映射那,其实还是创建了SQL语句,上面就是在User.edmx.sql中查找到的,嘿嘿,所以还不是很神奇的。被我们发现啦。在这里需要区别的是我们从数据库映射时间创建的是StudentEntities,而从C#映射到数据库创建的是UserContainer,就是Entities与Container的不同,另外在创建C#映射到数据库还创建了一个.edmx.sql,这些都是我们可以区分的地方,这就是我们创建的EF模型。
三.EF中增删改查的语句:
static void Main(string[] args)
{
StudentEntities entities = new StudentEntities(); //初始化对象
Register register = new Register();
#region 增加
//register.UserName = "张三";
//register.Pwd = "123";
//register.Sex = "男";
//register.Phone = "123456";
//register.Age = "20";
//register.Address = "河南郑州";
//entities.Register.Add(register); //添加一个集合使用Add
//entities.SaveChanges(); //保存
#endregion #region 删除
//Register r = entities.Register.Where(i=>i.Id==39).SingleOrDefault(); //在这里需要注意的是Lambda表达式的i属性Register,它是一个集合,所以需要它.出来他的id项
//entities.Register.Remove(r); //删除使用的是Remove
//entities.SaveChanges();
#endregion #region 修改
//Register rr = entities.Register.Where(i => i.Id == 40).SingleOrDefault(); //修改时间记得先查询要修改的条件
//rr.UserName = "zhangsan"; //在这里需要注意的是接受的对象
//rr.Pwd = "456";
//rr.Sex = "女";
//rr.Phone = "123456789";
//rr.Age = "20";
//rr.Address = "北京";
//entities.SaveChanges(); //保存
#endregion #region 查询
//Register rrr = entities.Register.Where(i => i.Id == 41).SingleOrDefault();
//Console.WriteLine("{0},{1},{2}",rrr.Id,rrr.UserName,rrr.Pwd); //Register rrr = entities.Register.SelectMany(i=>i.Id==40&&i.Id==41).SelectMany();
#endregion Console.WriteLine("ok");
Console.ReadKey();
}
嘿嘿,这就是我们在EF模型中对数据库操作的语句,需要注意的是,我们在执行完后记得保存一下数据,就是当前状态记得保存,这个是容易忘记的,另外在这里参数为Lambda表达式时间要准确使用。
四.实体中存在约束执行的语句
static void Main(string[] args)
{
UserContainer container = new UserContainer();
Tea t = new Tea();
//t.ID = 1;
t.Name = "lisi";
t.Pwd = "";
t.Sid = ; Stu stu = new Stu();
//stu.ID = 1;
stu.Name = "zhangsan";
stu.Pwd = "";
container.Tea.Add(t);
container.Stu.Add(stu);
container.SaveChanges(); Console.WriteLine("ok");
Console.ReadKey();
}
存在外键关系的我们需要注意的是,当我们在添加一个表的数据时,另外一个外键的属性也需啊哟赋值,如果我们设置Id的属性为自动增长,那么我们设置的外键的值则每次自动增长,如果设置不变,则只需要不填写即可。
其实这个EF模型的总结我感觉我们学习的不多,但是不知道从哪开始总结,也向更深入的了解一下,接下来还是自己查找吧,好啦,就写到这里,嘿嘿。
EF的学习的更多相关文章
- EF框架学习手记
转载: [ASP.NET MVC]: - EF框架学习手记 1.EF(Entity Framework)实体框架EF是ADO.NET中的一组支持开发面向数据的软件应用程序的技术,是微软的一个ORM框架 ...
- [ASP.NET MVC]: - EF框架学习手记
1.EF(Entity Framework)实体框架EF是ADO.NET中的一组支持开发面向数据的软件应用程序的技术,是微软的一个ORM框架. 2.什么是ORM?ORM指的是面向对象的对象模型和关系型 ...
- EF Core学习Code First
下面通过实例来学习EF Core Code First,也就是通过EF Core迁移来完成从模型生成数据库. 本实例使用EntityFrameworkCore SQLite 数据库进行介绍,大家也可以 ...
- EF Code-First 学习之旅 继承策略
Code First中有三种不同的方法表示继承层次关系 1.Table per Hierarchy (TPH): 这种方法建议用一个表来表示整个类的继承层次关系,表中包含一个识别列来区分继承类,在En ...
- EF CodeFirst学习
EF CodeFirst 真是时光如梦,岁月如歌,自己一不留神就被后浪拍在了沙滩上,就连我要学的这个东西也是12年就在博客园很火了. EF有三种开发模式,DatabaseFirst, ModelFir ...
- EF框架学习
简称EF,ADO.NET Entity Framework是微软以ADO.NET为基础所发展出来的对象关系对应(O/R Mapping)解决方案,是微软的一个ORM(面向对象的对象模型和关系型数据库的 ...
- EF CodeFirst学习笔记004--足够聪明
将BlogTypes注释掉,但因为Blogs中定义了BlogType 这样类型的属性,所以Ef会聪明的找到BlogType类. public class BlogEntities:DbContext ...
- EF CodeFirst学习笔记001--主键约定
Code First 的核心是约定,这些默认的规则使我们可以用我们自己的类来创建模型.EF框架要求一个类必须有一个键属性.规则约定如果一个属性名为Id或者是类名+Id的形式(如PatientId),这 ...
- EF Code-First 学习之旅 配置一对一的关系
1对1.1对0 的关系 例如:Entity1与零个或一个Entity2的实例有关系 public class Student { public Student() { } public int Stu ...
随机推荐
- Ogre 编辑器二(用Ogre的地形组件加载天龙八部地形)
主界面如上文设计完成后,场景刚开始添加了是Ogre例子里的,发现场景里实物太少,于是想到直接把天龙的场景拿下来,天龙网上有源码,参考了下,把天龙的地形用Ogre的地形组件完成了下,如下是效果图: 因为 ...
- SpringMVC系列(二): SpringMVC各个注解的使用
1.@RequestMapping 1.@RequestMapping除了能修饰方法,还能修饰类(1)修饰类:提供初步的请求映射信息,相对于web请求的根目录(2)修饰方法:提供进一步的细分映射信息相 ...
- JDBC SQL语法
结构化查询语言(SQL)是一种标准化语言,允许对数据库执行操作,例如:创建数据记录,读取内容,更新内容和删除数据记录等. 本教程中将概述SQL,这是了解和学习JDBC概念的前提条件. 经过本章后,您将 ...
- JUnit介绍,JUnit是什么?
JUnit是什么? JJUnit是用于编写和运行可重复的自动化测试的开源测试框架, 这样可以保证我们的代码按预期工作.JUnit可广泛用于工业和作为支架(从命令行)或IDE(如Eclipse)内单独的 ...
- Maven自动化部署
在项目开发中,通常是部署过程包含以下步骤 检入代码在建项目全部进入SVN或源代码库中,并标记它. 从SVN下载完整的源代码. 构建应用程序. 生成输出要么WAR或EAR文件存储到一个共同的网络位置. ...
- JAVA平台在手机上广泛应用
JAVA平台由于在手机上广泛应用,使得扩展名为jar的游戏成为目前手机游戏市场上最大的家族,直接传入手机直接安装即可. 众所周知,JAVA是一种跨平台的程序设计语言.由于其高可移植性.简单.可靠.安全 ...
- (转)关于C++ const 的全面总结
转自:http://blog.csdn.net/Eric_Jo/article/details/4138548 C++中的const关键字的用法非常灵活,而使用const将大大改善程序的健壮性,本人根 ...
- js jquery 按钮点击后 60秒之后才能点击 60秒倒计时
var wait = 60; function time(o) { if (wait == 0) { $(o).attr("disabled", false); $(o).val( ...
- zabbix 配置SNMP监控
什么是SNMP? 简单网络管理协议(SNMP),由一组网络管理的标准组成,包含一个应用层协议(application layer protocol).数据库模型(database schema)和一组 ...
- vncviewer 通过ipv6连接
vncserver 填为: [ipv6-address]:port 即可,例如 [:da8::81f:f292:1cff:fe07:da3c]: