一、实体框架(Entity FrameWork)简介

  • 简称EF

  • 与Asp.Net MVC关系与ADO.NET关系

  • ADO.NET Entity FrameWork是微软以ADO.NET为基础所发展出来的对象关系对应(O/R Mapping)解决方法,早期被称为ObjectSpace,最新版本是EF6.0【CodeOnly功能得到了更好的支持】

  • 实体框架Entity FrameWork 是ADO.NET中的一组支持开发面向数据的软件应用程序的技术。是微软的一个ORM框架。

二、什么是O/R Mapping

  • 广义上:ORM指的是面向对象的对象模型和关系型数据库接口之间的相互转换。

  • 狭义上,ORM可以被认为是,基于关系型数据库的数据存储,实现一个虚拟的面向对象的数据访问接口。理想情况下,基于这样一个面向对象的接口,持久化一个OO对象应该不需要了解任何关系型数据库存储数据的实现细节。

EF简单演示

第一步:右击-->添加新项-->ADO.NET 实体数据模型

第二步:实体数据模型向导,默认即可

第三步:新建连接

第四步:勾上(是,在连接字符串中包含敏感数据),下一步

第五步:选择模型中包括那些数据库表,完成即可

 using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks; namespace EFDemoFirst
{
class Program
{
static void Main(string[] args)
{
//添加一个添加操作
//1、声明一个EF的上下文
DEMOEntities dbContext = new DEMOEntities();
//2、声明一个实体
T_Seats seats = new T_Seats();
seats.userName = "test";
seats.pwdWord = "test1123";
//3、告诉EF做一个插入操作
dbContext.T_Seats.Add(seats);
//4、告诉上下文,把实体的变化保存到数据库里面去
dbContext.SaveChanges();
Console.Write("ok");
Console.ReadKey();
}
}
}

添加DEMO

 using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks; namespace EFDemoFirst
{
class Program
{
static void Main(string[] args)
{
//1、声明一个EF的上下文
DEMOEntities dbContext = new DEMOEntities();
//2、声明一个实体
T_Seats seats = new T_Seats();
seats.userName = "testTest";
seats.pwdWord = "123456 ";
seats.id = ;
//3、告诉EF做更新操作
//System.Data.Entity.EntityState.Added:添加
//System.Data.Entity.EntityState.Deleted:删除
//System.Data.Entity.EntityState.Modified:修改
dbContext.Entry<T_Seats>(seats).State = System.Data.Entity.EntityState.Modified;
//4、告诉上下文,把实体的变化保存到数据库里面去
dbContext.SaveChanges(); //执行SQL脚本的地方
Console.Write("ok");
Console.ReadKey();
}
}
}

修改DEMO

 using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks; namespace EFDemoFirst
{
class Program
{
static void Main(string[] args)
{
//1、声明一个EF的上下文
DEMOEntities dbContext = new DEMOEntities();
////2、声明一个实体
T_Seats seats = new T_Seats();
seats.id = ; //删除的WHERE条件,不加全部删除
//3、告诉ef做更新操作
//system.data.entity.entitystate.added:添加
//system.data.entity.entitystate.deleted:删除
//system.data.entity.entitystate.modified:修改
dbContext.Entry<T_Seats>(seats).State = System.Data.Entity.EntityState.Deleted;
//4、告诉上下文,把实体的变化保存到数据库里面去
dbContext.SaveChanges(); //执行SQL脚本的地方
Console.Write("ok");
Console.ReadKey();
}
}
}

删除DEMO

         static void Main(string[] args)
{
//查询
//1、声明一个EF的上下文
DEMOEntities dbContext = new DEMOEntities();
//把这个表中的数据,全部映射打印出来
//foreach (var item in dbContext.T_Seats)
//{
// Console.WriteLine(item.id+" "+item.userName+" "+item.pwdWord);
//}
#region Linq查询
var temp = from u in dbContext.T_Seats select u;
foreach (var t in temp)
{
Console.WriteLine(t.id+" "+t.userName+" "+t.pwdWord);
}
#endregion
Console.Write("ok");
Console.ReadKey();
}

查询DEMO

         static void Main(string[] args)
{
DataModelContainer dbContext = new DataModelContainer();
var data = dbContext.CustomerSet.Where(u => u.ID > );
foreach (var item in data)
{
Console.WriteLine(item.ID+" ,"+item.CusName);
}
Console.WriteLine("ok..");
Console.ReadKey(); }

查询DEMO Lambda表达式

         static void Main(string[] args)
{
DataModelContainer dbContext = new DataModelContainer();
//升序
//var pageData = dbContext.CustomerSet.Where(u => u.ID > 2).OrderBy<Customer, int>(u => u.ID);
//降序
var pageData = dbContext.CustomerSet.Where(u => u.ID > ).OrderByDescending<Customer, int>(u => u.ID).Skip(*).Take();
foreach (var item in pageData)
{
Console.WriteLine(item.ID+","+item.CusName);
}
Console.WriteLine("ok..");
Console.ReadKey();
}

分页

EF简介及CRUD简单DEMO的更多相关文章

  1. Solr配置与简单Demo[转]

    Solr配置与简单Demo 简介: solr是基于Lucene Java搜索库的企业级全文搜索引擎,目前是apache的一个项目.它的官方网址在http://lucene.apache.org/sol ...

  2. Spring环境搭建及简单demo

    1. Spring框架简介(以下这段话可用于面试求职) Spring为JavaEE开发提供了一个轻量级的解决方案,主要表现为, IOC(或者叫做DI)的核心机制,提供了bean工厂(Spring容器) ...

  3. MVC5+EF6 入门完整教程4 :EF基本的CRUD

    上篇文章主要讲了如何配置EF, 我们回顾下主要过程: 创建Data Model ---> 创建Database Context --->创建databaseInitializer---&g ...

  4. 设计模式之单例模式的简单demo

    /* * 设计模式之单例模式的简单demo */ class Single { /* * 创建一个本类对象. * 和get/set方法思想一样,类不能直接调用对象 * 所以用private限制权限 * ...

  5. Spring的简单demo

    ---------------------------------------- 开发一个Spring的简单Demo,具体的步骤如下: 1.构造一个maven项目 2.在maven项目的pom.xml ...

  6. 使用Spring缓存的简单Demo

    使用Spring缓存的简单Demo 1. 首先创建Maven工程,在Pom中配置 <dependency> <groupId>org.springframework</g ...

  7. Managed DirectX中的DirectShow应用(简单Demo及源码)

    阅读目录 介绍 准备工作 环境搭建 简单Demo 显示效果 其他 Demo下载 介绍 DirectX是Microsoft开发的基于Windows平台的一组API,它是为高速的实时动画渲染.交互式音乐和 ...

  8. angular实现了一个简单demo,angular-weibo-favorites

    前面必须说一段 帮客户做了一个过渡期的项目,唯一的要求就是速度,我只是会点儿基础的php,于是就用tp帮客户做了这个项目.最近和客户架构沟通,后期想把项目重新做一下,就用现在最流行的技术,暂时想的使用 ...

  9. 只是一个用EF写的一个简单的分页方法而已

    只是一个用EF写的一个简单的分页方法而已 慢慢的写吧.比如,第一步,先把所有数据查询出来吧. //第一步. public IQueryable<UserInfo> LoadPagesFor ...

随机推荐

  1. 程序员该如何过好他的整个职业生涯?(最重要的是你得一直往前走。拐点不是你的工资。想起很久前有个人说我“逻辑性”比较强)good

    作者|池建强 编辑|小智   戳阅读原文,获得短信提醒,不错过下次InfoQ大咖说直播! 1 写在前面 加入极客邦的第一天就被拉到了「大咖说」的现场,这也是我始料未及的事情.从锤子科技正式离职之后,我 ...

  2. VS2008 环境中完美搭建 Qt 4.7.4 静态编译的调试与发布(很不错,有六张插图说明,修改qmake.conf里的MD参数等)good

    为什么要在VS2008中使用QT静态编译呢?很简单,因为VS2008编译器编译出来的文件比mingw编译的要几乎小一半. 好了现在我们来做些准备工作,VS2008自然要安装的,然后打上SP1的补丁.然 ...

  3. 梭子鱼VS多备份 虽殊途却同归

    备份,对于企业来说,不仅是一个已经拥有多年历史的传统IT工作,还关系着企业自身的生死存亡.在云计算时代下,备份业务成为企业的必选项,已经成为云计算服务最为热门的领域之一.基于云的备份正在深刻改变着备份 ...

  4. Ubuntu 下压缩软件的安装

    在ubuntu下,系统就自带一个压缩包管理软件,但是,它默认是不支持rar和7zip格式的.因此,我们可以给它直接“增强”一下.就成了万能的了.安装方法,终端里面: sudo apt-get inst ...

  5. linux 十五个原理知识点

    DNS系统架构与解析原理http协议通信原理TCP/IP的3次握手和四次断开原理MySQL主从同步原理Nginx配合php的fastcgi工作原理Lvs的4种模式工作原理Memcached工作原理(内 ...

  6. Appium+python自动化(十一)- 元素定位秘籍助你打通任督二脉 - 下卷(超详解)

    简介 宏哥看你骨骼惊奇,印堂发亮,必是练武之奇才! 按照上一篇的节目预告,这一篇还是继续由宏哥给小伙伴们分享元素定位,是不是按照上一篇的秘籍修炼,是不是感觉到头顶盖好像被掀开,内气从头上冒出去,顿时觉 ...

  7. 微信商城小程序 带java后台源码

    微信小程序商城(Java版) 技术选型 1 后端使用技术 1.1 spring-web-4.0.2.RELEASE 1.2 mybatis3.2.8 1.3 shiro1.2.3 1.4 servle ...

  8. java中方法的重载和覆盖

    java中方法的重载和覆盖 先来了解一下这两个名词的含义. 重载: 在一个类当中才可以重载,方法名相同,参数个数不同或参数个数相同而参数类型不同. 覆盖: 又称重写,在派生类(子类)中重写基类(父类) ...

  9. Ceph原理动画演示

    动图生动刻画Ceph的基本原理之集群搭建及数据写入流程:)

  10. HDU 6181:Two Paths(A* + SPFA)

    题目链接 题意 给出n个点m条边的无向图,求次短路. 思路 和 POJ 2449 类似,只不过大小要开成long long. #include <bits/stdc++.h> using ...