MVC学习(三)Code-First Demo
前面两篇文章介绍了DataBase-First例子,这里就介绍Code-First。
个人简单理解:就是在程序中编写代码,然后在数据库中生成相应的表、字段、约束等等。听上去蛮神奇的。Now,begin。
这里为了方便,还是用控制台,VS2010与Sql 2005。
为了学习EF Code-First 方法,我们首先需要添加引用,EntityFramework.dll,点击下载
由于是控制台程序,我们需要在App.config文件中写好数据库连接字符串(web程序不需要)。
<add name="TestStudent" connectionString="data source=(local);Initial Catalog=TestStudent;User Id=sa;Password=123456;
persist security info=True;" providerName="System.Data.SqlClient" />
这个数据库中,有用户表User,以及这些学生的成绩表Grade,一对多的关系。
首先先看下面的代码
public class User
{
[Key]
[DatabaseGenerated(DatabaseGeneratedOption.Identity)]
public int Id { get; set; }
public int UserId { get; set; }
public string UserName { get; set; } public virtual ICollection<Grade> Grade { get; set; }
} public partial class Grade
{
[Key]
[DatabaseGenerated(DatabaseGeneratedOption.Identity)]
public int GradeId { get; set; }
public string SourceName { get; set; }
public double SourceGrade { get; set; }
public int GUserId { get; set; } [ForeignKey("GUserId")]
public virtual User User { get; set; }
}
按照Code-First规则,一旦运行此程序,就会生成表名为User、Grade的数据表,User表里面有Id,UserId,UserName三个字段,其中Id是User表的主键,并且是自增。如果你不希望此数据表名为User,可以通过在类名前加上[Table("StudentInfo")],则生成的数据表名为StudentInfo。
其中
代码 public virtual ICollection<Grade> Grade { get; set; } ---》表示该列表延迟加载。
[ForeignKey("GUserId")]
public virtual User User { get; set; } -----》表示列GUserId是User表的外键。
那么,如何创建数据库呢,如下代码
public class StudentDbContext : DbContext
{
public StudentDbContext()
: base("name=TestStudent")
{
this.Database.CreateIfNotExists();
}
public IDbSet<User> User { get; set; }
public IDbSet<Grade> Grade { get; set; }
}
这里,我们写了一个类 StudentDbContext ,继承类DBContext。
其中 DbContext : IDisposable, IObjectContextAdapter
接口 IObjectContextAdapter的原型
public interface IObjectContextAdapter
{
System.Data.Objects.ObjectContext ObjectContext { get; }
}
因此,ObjectContext是师祖。
这里需要注意一下,name="XXX"的名称要与连接数据库的名称一样,否则可能会有小问题出现。
“this.Database.CreateIfNotExists()”表示如果如果不存此数据库,就去创建数据库。
IDbSet原型如下
public interface IDbSet<TEntity> : IQueryable<TEntity>, IEnumerable<TEntity>, IQueryable, IEnumerable where TEntity: class
{
TEntity Add(TEntity entity);
TEntity Attach(TEntity entity);
TDerivedEntity Create<TDerivedEntity>() where TDerivedEntity: class, TEntity;
TEntity Create();
TEntity Find(params object[] keyValues);
TEntity Remove(TEntity entity); ObservableCollection<TEntity> Local { get; }
}
在下面,我们就会用到这些方法去操作数据库的内容。
1、添加数据
代码如下
//使用DBContext 里自带的方法操作数据库
var User = new User() { UserId = , UserName = "刘德华" };
db.User.Add(User);
db.SaveChanges();
//直接使用Sql 语句操作数据库
db.Database.ExecuteSqlCommand("insert into Users(UserId,UserName) values({0},{1})",
new object[] { , "xianrongbin" });
2、查询数据
var ListUsers = db.User.ToList<User>(); //var ListUsers = db.Database.SqlQuery<User>("select * from Users").ToList<User>();
foreach (var item in ListUsers)
{
Console.WriteLine(item.UserName);
//var Grades = db.Grade.Where(a=>a.GUserId==item.UserId); var Grades = from a in db.Grade
where a.GUserId == item.UserId
select a;
foreach (var grade in Grades)
{
Console.WriteLine(grade.SourceName + " " + grade.SourceGrade);
}
}
当然,因为两张表存在主外键的关系,我们可以使用类似Sql语句中的join语法,查询数据,代码如下
var query = from s in db.User
join c in db.Grade
on s.UserId equals c.GUserId
//where s.UserId == 1
select new
{
SID=s.UserId,
SName=s.UserName,
KMName=c.SourceName,
KMScore=c.SourceGrade
};
foreach (var item in query)
{
Console.WriteLine("学生{0} 的{1}成绩是{2}",item.SName,item.KMName,item.KMScore);
}
3、修改数据
int userId = ;
User UserModel = db.User.Find(userId);
UserModel.UserName = "陈小春"; db.Entry(UserModel).State = EntityState.Modified;
db.SaveChanges();
//db.Database.ExecuteSqlCommand("update Users set UserName='刘德华' where Id=2");
4、删除数据
User UserModel = db.User.Find();
if (UserModel != null)
{
db.Entry(UserModel).State = EntityState.Deleted;
db.SaveChanges();
}
OK,Code-First例子这里计算讲完了。
MVC学习(三)Code-First Demo的更多相关文章
- Spring MVC 学习 之 - 配置简单demo
1.环境参数: Maven:3.1.1 JDK :1.6 2.项目文件结构图: 3.各文件配置: 3.1. pom.xml <project xmlns="http://maven. ...
- MVC学习三:Razor视图引擎
1.Razor视图引擎,主要是把View的HTML代码编译到View视图类对象中
- .NET MVC 学习笔记(三)— MVC 数据显示
. NET MVC 学习笔记(三)—— MVC 数据显示 在目前做的项目中,用的最多的数据展示控件就是table展示(说不是的请走开,不是一路人),以下详细阐述下table的使用方法. 先看效果: 上 ...
- MVC学习笔记(三)—用EF向数据库中添加数据
1.在EFDemo文件夹中添加Controllers文件夹(用的是上一篇MVC学习笔记(二)—用EF创建数据库中的项目) 2.在Controllers文件夹下添加一个空的控制器(StudentsCon ...
- ASP.NET MVC学习系列(二)-WebAPI请求
继续接着上文 ASP.NET MVC学习系列(一)-WebAPI初探 来看看对于一般前台页面发起的get和post请求,我们在Web API中要如何来处理. 这里我使用Jquery 来发起异步请求实现 ...
- ASP.NET MVC学习系列(二)-WebAPI请求(转)
转自:http://www.cnblogs.com/babycool/p/3922738.html 继续接着上文 ASP.NET MVC学习系列(一)-WebAPI初探 来看看对于一般前台页面发起的g ...
- (转)ASP.NET MVC 学习第一天
天道酬勤0322 博客园 | 首页 | 发新随笔 | 发新文章 | 联系 | 订阅 | 管理 随笔:10 文章:0 评论:9 引用:0 ASP.NET MVC 学习第一天 今天开始第一天学习as ...
- Spring MVC 学习笔记一 HelloWorld
Spring MVC 学习笔记一 HelloWorld Spring MVC 的使用可以按照以下步骤进行(使用Eclipse): 加入JAR包 在web.xml中配置DispatcherServlet ...
- [转]ASP.NET MVC学习系列(二)-WebAPI请求 传参
[转]ASP.NET MVC学习系列(二)-WebAPI请求 传参 本文转自:http://www.cnblogs.com/babycool/p/3922738.html ASP.NET MVC学习系 ...
- Spring MVC 学习笔记10 —— 实现简单的用户管理(4.3)用户登录显示全局异常信息
</pre>Spring MVC 学习笔记10 -- 实现简单的用户管理(4.3)用户登录--显示全局异常信息<p></p><p></p>& ...
随机推荐
- rocketmq 4.2.0 版本 控制台本地搭建(史上最简单教程)
就像发现新大陆一般,瞎折腾,搞出来了..并没有网上说的一大串....(本人公司的项目从未使用过springboot....) rocketmq 控制台,官方使用springboot 做后端,前端使用 ...
- 尚硅谷springboot学习8-yaml基本语法
1.基本语法 k:(空格)v:表示一对键值对(空格必须有): 以空格的缩进来控制层级关系:只要是左对齐的一列数据,都是同一个层级的 server: port: 8081 path: /hello 属性 ...
- Linux:写一个简单的服务器
开始了新篇章:Linux网络编程. 基础知识: 套接字概念 Socket本身有"插座"的意思,在Linux环境下,用于表示进程间网络通信的特殊文件类型.本质为内核借助缓冲区形成的伪 ...
- 关于AVAYA CM6和Asterisk(Freepbx)对接的笔记
最重要的两份参考文档: http://blog.sina.com.cn/s/blog_6db134880102vipo.html https://personalprojects.wordpress. ...
- 基于Delphi的接口编程入门
为什么使用接口? 举个例子好了:有这样一个卖票服务,电影院可以卖票,歌剧院可以卖票,客运站也可以卖票,那么我们是否需要把电影院..歌剧院和客运站都设计成一个类架构以提供卖票服务?要知道,连经理人都可以 ...
- Android高级控件(下)
Chronometer计时器 常用的方法 getBase() 基准时间 setFormat 设置显示格式 start() 开始计时 stop() 停止计时 setOnChronometerListen ...
- Hosts
Hosts "C:\Windows\System32\drivers\etc\hosts" [最新]2018 hosts 持续更新[更新于:2018-11-13] 本页面WordP ...
- (转)NHibernate+MySql常见问题
http://blog.51cto.com/4837471/1567675 版本: NHibernate :NHibernate 4.0.1GA MySql:MySql 5.0.1 常见问题一: “N ...
- Java中this和super的用法和区别
super(参数):调用父类中的某一个构造函数(应该为构造函数中的第一条语句). this(参数):调用本类中另一种形式的构造函数(应该为构造函数中的第一条语句). this的实例: package ...
- Eclipse kepler 安装 Dynamic Web Project差距WTP
原文地址:http://blog.csdn.net/westrain2010/article/details/25122999, 欢迎转载 Eclipse 标准版是不能创建 Dynamic Web P ...