一、环境
开发环境:Sqlserver2008 R2、Visual Studio2012
 
二、准备工作
1、新建MVC空项目
2、通过NuGet获取 EntityFramework 包
 操作截图:
 
 
 
三、代码实现 
  1.建立实体类 
  

  [Table("User")]
public class User
{
[Display(Name="id")]
public int Id {get;set;}
[Display(Name="UserName")]
[Required(ErrorMessage="用户名必填")]
public string UserName { get; set; }
[Display(Name="Password")]
public string Password { get; set; }
}

  

2.构建数据库访问类
   a)、继承DbContext
   b)、创建数据库连接字符串,字符串名称与a)步骤类名称一致,也可不一致(需指定数据库访问串)
  public class DemoConnectionContext : DbContext
{
public DbSet<User> dbuser { get { return Set<User>(); } }
public DemoConnectionContext()
: base("name=DemoConnectionContext") //指定数据库访问串
{
}
static DemoConnectionContext()
{
Database.SetInitializer<DemoConnectionContext>(new DropCreateDatabaseIfModelChanges<DemoConnectionContext>());
}
}

3.数据库操作

//声明数据库操作类
DemoConnectionContext db = new DemoConnectionContext();

  a)、增加数据

User user = new Models.User{UserName = "jay", Password = ""};
db.dbuser.Add(user);
db.SaveChanges();

   b)、查询数据

//指定ID查询
var userObj=db.dbuser.Find(); //写法一
var userObj = db.dbuser.Where(u => u.Id == ).FirstOrDefault(); //写法二
//写法三
var userObj = (from u in db.dbuser
where u.Id ==
select u).ToList();

  c)、更新数据

      //更新表
var userObj = (from u in db.dbuser
where u.UserName == "jay"
select u).ToList();
userObj[].Password = "";
db.dbuser.Attach(userObj[]);
//更新指定列
var setEntry = ((IObjectContextAdapter)db).ObjectContext.ObjectStateManager.GetObjectStateEntry(userObj[]);
setEntry.SetModifiedProperty("Password");
db.SaveChanges();

  d)、删除数据

  

      //删除数据 指定ID即可
User userObj = new User { Id = };
db.dbuser.Attach(userObj);//附加对象
db.dbuser.Remove(userObj);//删除对象
db.SaveChanges();

  e)、事物操作 多表操作,操作放在 TransactionScope

  

       try
{
//事物 多表操作,操作放在 TransactionScope
using (var trac = new TransactionScope())
{
User user = new User { UserName = "jack", Password = "" };
db.dbuser.Add(user);
//throw new Exception("抛出异常");
user = new User { UserName = "David", Password = "" };
db.dbuser.Add(user);
db.SaveChanges();
trac.Complete();//事物提交,如未执行该方法,出事务作用范围自动回滚
}
}
catch (Exception ex)
{
throw; }

  f:)、T-SQL查询
     1) sql 查询,实体类

     //sql 查询,实体类
var userList = db.Database.SqlQuery<User>("select id,UserName,Password from [User]").ToList();

2)指定对象查询实体

  var userList= db.dbuser.SqlQuery("select id,UserName,Password from  [User]").ToList();

3) 执行SQL命令

  db.Database.ExecuteSqlCommand("update [User] set UserName='Michel' where UserName='jay'");
常见错误解答
1、错误信息:The model backing the 'DemoConnectionContext' context has changed since the database was created. Consider using Code First Migrations to update the database (http://go.microsoft.com/fwlink/?LinkId=238269).
错误信息大体意思为:因实体类属性或实体关系、实体名称发生变化,EF脚本需重新更新数据库信息与实体保持一致。
解决方法:1.备份数据库,关闭所有数据库操作,EF框架自动更新脚本(通常删除库后重新创建库,如果数据库已经在使用,并且不想删除现有数据,不建议使用运行脚本) 
                  2.指定不同步更新数据库,可设置为  Database.SetInitializer<DemoConnectionContext>(null);,手动更新数据库与实体类保持一致
 

.Net EntityFramwork6.0 EF框架开发入门的更多相关文章

  1. LLBL Gen Pro 5.0 企业应用开发入门

    Solutions Design 公司于2016年5月发布了LLBL Gen Pro 5.0,这个新版本的发布出乎于我的意料.我的猜想是从4.2升级到4.5,再升级5.x版本,主版本号的变更会给原有客 ...

  2. Vue实例:vue2.0+ElementUI框架开发pc项目

    开发前准备 vue.js2.0中文,项目所使用的js框架 vue-router,vue.js配套路由 vuex,状态管理 Element,UI框架 1,根据官方指引,构建项目框架 安装vue npm ...

  3. 从零3D基础入门XNA 4.0(1)——3D开发基础

    [题外话] 最近要做一个3D动画演示的程序,由于比较熟悉C#语言,再加上XNA对模型的支持比较好,故选择了XNA平台.不过从网上找到很多XNA的入门文章,发现大都需要一些3D基础,而我之前并没有接触过 ...

  4. Eclipse_luna_J2EE_For_JS+tomcat8.0环境搭建、配置、开发入门

    一.所有需要的软件.插件等下载地址 J2SE的官方下载路径:http://www.oracle.com/technetwork/java/javase/downloads/index.html Ecl ...

  5. Python云端系统开发入门——框架基础

    Django框架基础 这是我学习北京理工大学嵩天老师的<Python云端系统开发入门>课程的笔记,在此我特别感谢老师的精彩讲解和对我的引导. 1.Django简介与安装 Django是一个 ...

  6. 跨平台移动框架iMAG开发入门

    iMAG是一个非常简洁高效的移动跨平台开发框架,开发一次能够同一时候兼容Android和iOS平台,有点儿Web开发基础就能非常快上手.当前移动端跨平台开发的框架有非常多,但用iMAG另一个优点,就是 ...

  7. .NET EF框架的安装、及三种开发模式

    一.EF框架的安装: 要在VS(如Visual Studio 2012)中使用EF框架,就需要先进行安装. 我们需要给这个应用安装EntityFramework包,引入EF框架相关的内容,我们需要引入 ...

  8. net core体系-web应用程序-4asp.net core2.0 项目实战(1)-5项目数据库操作封装操作-EF框架

    EF框架有三种基本的方式:DB First(数据库优先),Model First(模型优先),Code First(代码优先). Entity Framework4.1之前EF支持“Database  ...

  9. ThinkPHP5.0框架开发实现简单的页面跳转

    ThinkPHP5.0框架开发实现简单的页面跳转 一.效果 登录界面 登录成功界面 登录失败界面 二.目录结构 三.代码 控制器中的Login.php <?php // 声明命名空间 names ...

随机推荐

  1. [解决]Linux Tomcat启动慢--Creation of SecureRandom instance for session ID generation using [SHA1PRNG] took [236,325] milliseconds

    一.背景 今天部署项目到tomcat,执行./startup.sh命令之后,访问项目迟迟加载不出来,查看日志又没报错(其实是我粗心了,当时tomcat日志还没打印完),一开始怀疑是阿里云主机出现问题, ...

  2. CSS滚动条设置

    /*IE滚动条颜色设置*/ body { scrollbar-arrow-color:#f2f2f3; /*上下箭头*/ scrollbar-track-color:#1589ce; /*底层背景色* ...

  3. google提示恶意软件解决办法

    对于没有安全经验的小白来说 google的一张图可能就会让吓得不轻(我会说我就是小白么~~) 就是这么一张图~ 其实解决办法很简单 google会向用户推荐几款比较不错的软件 进行检测 其中我认为比较 ...

  4. linux PMBus总线及设备驱动分析

    PMBus协议规范介绍 PMBus是一套对电源进行配置.控制和监控的通讯协议标准.其最新版本为1.3,该规范还在不断演进中,比如新标准中新增的zone PMBus.AVSBus等特性.在其官网上有详细 ...

  5. 客户端用TortoiseSVN检出代码

    在桌面空白处右键选择SVN检出,如图: 在弹出的对话框中填写服务端版本库的URL (URL获取方式在前面一章中介绍过)选择检出目录点击确定,如图: 开始检出项目,如图: 检出完成之后打开副本,即可看到 ...

  6. Git分支(2/5) -- Fast Forward 合并

    快捷操作: 切换并创建分支: git checkout -b 分支名. git checkout -b some-change 然后我打开某个文件(index.html)修改一下标题. Commit之 ...

  7. fail2ban防止SSH暴力破解

    [root@kazihuo /srv]# wget https://github.com/fail2ban/fail2ban/archive/0.8.14.tar.gz [root@kazihuo / ...

  8. 神奇的Python

    不断学习新的知识,不断掌新的技能是一件非常有趣的事情,其实Python在我学习这门课之前从没听过,刚上第一节课老师给我们讲了一个它的应用比如可以筛选单词,定时放歌等,虽然感觉自己还没有真正理解这门课程 ...

  9. Java线程sleep,yield,join,wait方法详解

    1.sleep() 当一个线程调用sleep方法后,他就会放弃cpu,转到阻塞队列,sleep(long millis)方法是Thread类中的静态方法,millis参数设定线程睡眠的时间,毫秒为单位 ...

  10. MySQL数据库学习三 数据库对象和基本操作

    3.1 数据库和数据对象 1. 系统数据库 information_schema:主要存储系统中的一些数据库对象信息,如用户列表信息.列信息.权限信息.字符集信息和分区信息等. performance ...