特性
用来具体的设置数据库属性
 
[Table("表名")]//设置表名
public class User
{
[Key] //设置主键
[Column("列名")] //设置列名
[DatabaseGenerated(DatabaseGeneratedOption.None)]
//None 不自增
//Identity 自增
//Computed 数据库计算生成
public int Id{get;set;} [StringLength()] //varchar长度 public int Name{get;set;} [Required] //必要的(非空)
[Column(TypeName="varchar")] //类型设置 public int LoginName{get;set;} public int Password{get;set;} [foreignKey("stu")] //设置外键
public int sid{get;set;}
public student stu{get;set;} Nullable<int> age{get;set;} //让int 类型可以赋空值
//缩写为 int? age [NotMapped] //不在数据库生成
public string SumMoney{get;set;}
}

EF生成数据库设置

public SQLContext():base("conStr")
{
Database.SetInitializer(new DropCreateDatabaseAlways<SQLContext>());//生成数据库设置
Database.SetInitializer<SQLContext>(null);
//DropCreateDatabaseAlways<SQLContext> 执行一次删除重建一次数据库
//DropCreateDatabaseIfModelChanges<SQLContext> 当数据库模型发生变化时才删除重建数据库
//null 不会自动删除重建数据库
}
long 类型 长度
922 0000 0000 0000 0000
 
输出EF所做的操作
context.Database.Log = (msg) =>
{
Console.WriteLine(msg);
}

联表

EF做联表操作时,使用Include

foreach(var item in context.stu.Include("表名"))
{ }
//或者
foreach(var item in context.stu.Include(m=>m.User)) //lambda
{ } //只拿出指定的列
foreach(var item in context.stu.Include(m=>m.User).Select(m=>new {m.title,m.user,...}))
{
}

EF中在属性中加上virtual,它就会变成懒加载,在使用时才会加载

直接用sql语句操作数据库,即使在上下文中没有的表也可以操作

context.Database.ExecuteSqlCommand("sql语句");

直接用sql语句操作数据库,并把结果封装到一个模型类中

context.Database.SqlQuery<封装的类>("sql语句");

EF不是所有lambda写法都能被支持,出错的时候,把那条语句单独提取出来用变量接收一下就行了

EF 对象的状态
Detached(游离态),Unchanged(未修改),Added(新增),Deleted(删除),modified(被修改)
 
游离态 → 保存到数据库 → 未修改
游离态 → 添加(集合) → 新增(Add) → 保存到数据库 (SavaChange)→ 未修改
未修改 → 修改属性→ 被修改 → 保存到数据库(SavaChange) → 未修改
未修改 → 删除(集合) → 删除 → 游离态
 
强制修改对象的状态可以省掉一些状态的转换,提高性能
如:查询出的数据为未修改,通过remove变为删除状态,保存后就会删除这条数据
        但如果直接把数据从未修改 改为 删除状态,则不需要remove,直接保存即可删掉这条数据
Context.Entry(对象).State = EntityState.xxxx;//强制修改对象状态

保存时不进行验证

Context.Configuration.ValidateOnSaveEnabled = false;

加上AsNoTracking() 可以让查询出来的对象直接变成游离态

Context.stu.AsNoTracking().Where(XXX);

关闭级联删除检测

protected override void OnModelCreating(DbModelBuilder modelBuider)
{
modelBuilder.Conventions.Remove<OneToManyCascadeDeleteConvention>();
modelBuilder.Conventions.Remove<ManyToManyCascadeDeleteConvention>();
}

当不确定是什么对象时使用set (例如使用泛型时)

Context.set<T> //set中给什么对象,他就会相当于什么对象使用

EntityFramework 二的更多相关文章

  1. SqlServer切换MySql总结

    最近项目任务不多就琢磨着把SqlServer换成MySql(数据访问使用的ado.net),初步想了下方案有2种: 方案一:继续使用ado.net,重写所有的sql语句 优势:数据访问效率高,改写Sq ...

  2. 使用EF Oracle实现DevExpress绑定大数据的ServerMode模式

    前提:需要引入EntityFramework组件,注意几个使用点后使用上其实比较简单. 一.引入Oracle EF支持组建 1.可手动引入附件中的DLL(需手动合并web.config配置) 2.也可 ...

  3. Entity Framework技术导游系列 开篇 (转)

    在微软平台写程序有年头了,随着微软数据存取技术的持续演化,我在程序中先后使用过ODBC.DAO.ADO.ADO.NET.LINQ to SQL. Entity Framework这些技术. 近几年来, ...

  4. EF架构~通过EF6的DbCommand拦截器来实现数据库读写分离~再续~添加对各只读服务器的心跳检测

    回到目录 上一讲中基本实现了对数据库的读写分离,而在选择只读数据库上只是随机选择,并没有去检测数据库服务器是否有效,如服务器挂了,SQL服务停了,端口被封了等等,而本讲主要对以上功能进行一个实现,并对 ...

  5. EF架构~CodeFirst模型下的数据初始化

    回到目录 我为什么会来 在传统的大型系统设计中,数据库建模是个比开发更早的环节,先有数据库,然后是ORM模型,最后才是开发程序,而这种模型在EF出现后发生了转变,而且有可能将来会被code first ...

  6. [转]Entity Framework技术导游系列开篇与热身

    学习Entity Framework技术期间查阅的优秀文章,出于以后方便查阅的缘故,转载至Blog,可查阅原文:http://blog.csdn.net/bitfan/article/details/ ...

  7. Entity Framework技术导游系列开篇与热身

    在微软平台写程序有年头了,随着微软数据存取技术的持续演化,我在程序中先后使用过ODBC.DAO.ADO.ADO.NET.LINQ to SQL. Entity Framework这些技术. 近几年来, ...

  8. 一步一步学EF系列2【最简单的一个实例】

    整个文章我都会用最简单,最容易让人理解的方式给大家分享和共同学习.(由于live Writer不靠谱 又得补发一篇) 一.安装 Install-Package EntityFramework 二.简单 ...

  9. 一步一步学EF系列一【最简单的一个实例】

    整个文章我都会用最简单,最容易让人理解的方式给大家分享和共同学习.(由于live Writer不靠谱 又得补发一篇) 一.安装 Install-Package EntityFramework 二.简单 ...

随机推荐

  1. Windows GUI程序自动化之pywinauto

    一. pywinauto知识点总结 官方英文版文档网址:https://pywinauto.readthedocs.io/en/latest/index.html 1.1 pywinauto的安装与配 ...

  2. js操作url参数

    function getQueStr(url, ref) //获取参数值 { var str = url.substr(url.indexOf('?') + 1); if (str.indexOf(' ...

  3. robot Framework选择单选框

  4. snmp--CentOS安装Net-SNMP小计

    http://blog.csdn.net/tmpbook/article/details/39620549

  5. [SharePoint][SharePoint Designer 入门经典]Chapter13 客户端Silverlight编程

    1.使用Silverlight,CAML和Linq取得数据 2.编程性创建更新删除列表数据项 3.修饰列表和库的配置 4.管理文件和文件夹 5.修改快速启动和顶部导航条 [使用Silverlight, ...

  6. Unity3D中C#和JS的方法互相調用

    因为Unity3D中一些腳本的方法仅仅能用在JS中.在C#中是無效的,而C#能够與服務器端通訊,JS本身卻不行.所以勢必會遇到這兩種語言腳本中方法的互相調用,下面是演示样例. 兩個文件 test1.j ...

  7. C语言实现使用动态数组实现循环队列

    我在上一篇博客<C语言实现使用静态数组实现循环队列>中实现了使用静态数组来模拟队列的操作. 因为数组的大小已经被指定.无法动态的扩展. 所以在这篇博客中,我换成动态数组来实现. 动态数组能 ...

  8. Android菜鸟笔记- 获取未安装的APK图标、版本号、包名、名称、是否安装、安装、打开

    周末闲来无事,把Android的基础知识拿出来复习复习,今天主题是<获取未安装的APK图标.版本号.包名.名称.是否安装.跳转安装.打开> 一.获取APK图标 通常读取APK的图标能够用, ...

  9. multiset多重集合容器

    跟set集合容器相比,multiset多重集合容器也使用红黑树组织元素,仅仅是multiset多重集合容器同意将反复的元素键值插入.元素的搜索依旧具有对数级的算法时间复杂度,find和equal_ra ...

  10. bzoj1924: [Sdoi2010]所驼门王的宝藏

    陈年老题又来水一发啊啊啊 构图狗了一点,然后其实强连通缩点dij找最长路就没了. 没调出来有点气,直接打了第9个点的表.... 来逛blog的你教教我呗 #include<cstdio> ...