EF简介及CRUD简单DEMO
一、实体框架(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的更多相关文章
- Solr配置与简单Demo[转]
Solr配置与简单Demo 简介: solr是基于Lucene Java搜索库的企业级全文搜索引擎,目前是apache的一个项目.它的官方网址在http://lucene.apache.org/sol ...
- Spring环境搭建及简单demo
1. Spring框架简介(以下这段话可用于面试求职) Spring为JavaEE开发提供了一个轻量级的解决方案,主要表现为, IOC(或者叫做DI)的核心机制,提供了bean工厂(Spring容器) ...
- MVC5+EF6 入门完整教程4 :EF基本的CRUD
上篇文章主要讲了如何配置EF, 我们回顾下主要过程: 创建Data Model ---> 创建Database Context --->创建databaseInitializer---&g ...
- 设计模式之单例模式的简单demo
/* * 设计模式之单例模式的简单demo */ class Single { /* * 创建一个本类对象. * 和get/set方法思想一样,类不能直接调用对象 * 所以用private限制权限 * ...
- Spring的简单demo
---------------------------------------- 开发一个Spring的简单Demo,具体的步骤如下: 1.构造一个maven项目 2.在maven项目的pom.xml ...
- 使用Spring缓存的简单Demo
使用Spring缓存的简单Demo 1. 首先创建Maven工程,在Pom中配置 <dependency> <groupId>org.springframework</g ...
- Managed DirectX中的DirectShow应用(简单Demo及源码)
阅读目录 介绍 准备工作 环境搭建 简单Demo 显示效果 其他 Demo下载 介绍 DirectX是Microsoft开发的基于Windows平台的一组API,它是为高速的实时动画渲染.交互式音乐和 ...
- angular实现了一个简单demo,angular-weibo-favorites
前面必须说一段 帮客户做了一个过渡期的项目,唯一的要求就是速度,我只是会点儿基础的php,于是就用tp帮客户做了这个项目.最近和客户架构沟通,后期想把项目重新做一下,就用现在最流行的技术,暂时想的使用 ...
- 只是一个用EF写的一个简单的分页方法而已
只是一个用EF写的一个简单的分页方法而已 慢慢的写吧.比如,第一步,先把所有数据查询出来吧. //第一步. public IQueryable<UserInfo> LoadPagesFor ...
随机推荐
- C++数组指针、指针数组、函数指针的核心概念
1.什么叫数组指针? 数组指针:一个指向一维或者多维数组的指针. 比如:int * b=new int[10];指向一维数组的指针b ; 注意,这个时候释放空间一定要delete [] ,否则会造成内 ...
- Qt5---ftp上传功能(使用组合的办法实现功能,QNetworkAccessManager自动管理分片上传,用QLoggingCategory屏蔽SSL警告)
从Qt的版本进化中可以知道,在Qt4中的QFtp类到了Qt5中已经没有了,虽然可以通过在Qt5中自己编译出QFtp,但是Qt5中提供的QNetworkAccessManager在发送和请求网络方面 ...
- delphi LPT1端口打印与开钱箱
{设置打印机}Assignfile(RPrinter,'LPT1'); {准备写文件}Rewrite(RPrinter); {向后倒纸}//Writeln(RPrinter,chr($b)+chr(2 ...
- 窗体图片背景(两种方法:设置Brush.Bitmap指向图片,别的控件也可以这样)
var Bitmap: TBitmap; procedure TForm1.FormCreate(Sender: TObject); begin Bitmap := TBitmap.Creat ...
- UILabel实现自适应宽高需要注意的地方(二)
需求图如下所示 UILabel "上期" 距离屏幕最左边 有35px UILabel "下期" 距离屏幕最右边 有35px 进行中文字在UIlabe ...
- 深入浅出Ajax
原文(我的GitHub):https://github.com/liangfengbo/frontend-ability/issues/1 学习大纲 理解Ajax的工作原理 Ajax核心-XMLHtt ...
- F#周报2019年第26期
新闻 逐渐演化的.NET Core框架 Visual Studio提示与技巧 Windows Termina(预览) Microsoft在GitHub上的工程师从2000名增加至25000名 视频及幻 ...
- Centos7安装Typecho详细教程
Centos7安装Typecho详细教程 首先搭建LAMPH环境 L linux 服务器(centos或者ubunt) .A Apache .M mysql .P PHP 安装Apache.PHP ...
- 一文秒懂CPU使用率
目录 CPU:Cores, and Hyper-Threading 超线程(Hyper-Threading ) 多核(multi-cores) CPU使用率计算 CPU使用率测试 如何计算CPU使用 ...
- 微服务之服务注册与发现--Consul(转载)
http://blog.csdn.net/buxiaoxia/article/details/69788114 https://www.cnblogs.com/xiaohanlin/p/8016803 ...