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>& ...
随机推荐
- Oracle相关文章
1.oracle 11g常用命令 2.Oracle的在windows下的安装及使用 3.Oracle scott账户被锁定,scott默认密码,sys,system默认密码 4.NaviCat Pri ...
- Servlet开发
源地址:http://www.cnblogs.com/xdp-gacl/p/3760336.html 一.Servlet简介 Servlet是sun公司提供的一门用于开发动态web资源的技术. Sun ...
- Go语言学习笔记(1)
包 package 声明包,import 导入包,导入的包名要用"",包中导出的名字以大写字母打头. package main import "fmt" imp ...
- 正则表达式(TypeScript, JavaScript)
课题 使用正则表达式匹配字符串 使用正则表达式 "\d{3}-(\d{4})-\d{2}" 匹配字符串 "123-4567-89" 返回匹配结果:'" ...
- Ubuntu下的LNMP环境
保证联网的情况下,直接参照http://lnmp.org/install.html进行安装,以下花括号内为原文引用: { 1.使用putty或类似的SSH工具登陆VPS或服务器: 登陆后运行:scre ...
- 2.Servlet基础.md
目录 1.定义 2.特点 3.手动编写一个Servlet 3.1创建一个Servlet类 3.2找到编写类的class文件,将这个类的整个包拷贝到一个web应用中的WEB-INF/classes目录下 ...
- 21 week4 submit buidAndRun() node-rest-client
. 我们想实现一个提交代码的功能 这个功能有nodeserver 传到后边的server 验证 在返回给nodeserver 我们稍微修改一下ui ATOM修改文件权限不够 用下面命令 我们 Cont ...
- eclipse git 分享项目到GitHub上
先在github上创建仓库
- CentOS添加环境变量
添加这个两个路径:/usr/local/webserver/python/bin:/usr/local/webserver/mysql/bin 方法一:直接运行命令export PATH=$PATH: ...
- 获取tensorflow中tensor的值
tensorflow中的tensor值的获取: import tensorflow as tf #定义变量a a=tf.Variable([[[1,2,3],[4,5,6]],[[7,8,9],[10 ...