一、实体框架(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. [转载]关于Java reference的一篇博文

    不再额外的叨叨了,直接附上原地址: https://community.oracle.com/people/enicholas/blog/2006/05/04/understanding-weak-r ...

  2. hadoop(三)

    hadoop(三) 1.对MapReduce的认识   MapReduce是运行在yarn上面的一个分布式运算框架,它是用来解决海量的分布式运算的.对于MapReduce来说,我们可以把它分成两部分来 ...

  3. 【备忘】C#语言基础-1

    C#基础 注意区别哟! C#是一种托管语言,与C++不同,不能直接操作系统底层,依赖于 framework. 如果局部变量和全局变量同名,全局变量就会被屏蔽. 函数的返回值类型不是签名的一部分,所以不 ...

  4. c#基于Tablet pc实现的手写输入

    需要安装Tablet pc,win7的话 直接在控制面板>程序和应用>添加组建里面勾选上添加 然后就是下面的程序了,看代码 设计文件 namespace 手写识别 { partial cl ...

  5. python正则表达式模块

    正则表达式是对字符串的最简约的规则的表述.python也有专门的正则表达式模块re. 正则表达式函数 释义 re.match() 从头开始匹配,匹配失败返回None,匹配成功可通过group(0)返回 ...

  6. java方法中Collection集合的基本使用与方法

    集合类的由来,对象用于封闭特有数据,对象多了需要存储,如果对象的个数不确定就使用集合容器进行存储. 集合特点:1.用于存储对象的容器.2.集合的长度是可变的.3.集合中不可以存储基本数据类型值. 集合 ...

  7. ORACLE(系统表student) 基本与深入学习

    (一).首先我们先创建student表(系统有的可以跳过往下看)没有直接复制运行即可. create table student(sno varchar2(3) not null, --学号sname ...

  8. java反射机制获取自定义注解值和方法

    由于工作需求要应用到java反射机制,就做了一下功能demo想到这些就做了一下记录 这个demo目的是实现动态获取到定时器的方法好注解名称,废话不多说了直接上源码 1.首先需要自定义注解类 /** * ...

  9. Android项目开发之--------地铁时光机(一,搭建主框架)

    一:先看一下框架搭建后的效果图      , 二:框架结构 (1)底部导航栏采用的是: MainActivity(主框架), MsgFragment(首页), HistoryFragment(历史清单 ...

  10. Centos7 fstab盘符挂载硬盘导致重启系统失败解决办法

    服务器拥有多个硬盘插槽,在进行维护或重启时,这些硬盘的相对位置可能发生变化.利用盘符(dev/vda)方式挂载磁盘,可能由于磁盘顺序变化导致重启时读取fstab文件发生错误,从而无法正常重启服务器. ...