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>& ...
随机推荐
- cpu-io.sh
CPU-IO.SH #!/bin/bash #Edit by laozuo.org cname=$(cat /proc/cpuinfo|grep name|head -1|awk '{ $1=$2=$ ...
- Structs复习 Action
引入jar包 web.xml <?xml version="1.0" encoding="UTF-8"?> <web-app version= ...
- webservice调用dll
今天客户那里报出来,ws通讯不成功.但是在本机和windows2003上都可以测试成功.WS的页面(asmx)可以出来,但是点击接口方法,调用就报http500错误. 网站无法显示该页面 HTT ...
- arcgis_SDE安装步骤
弄了将近一个星期的Oracle和ArcSDE终于让我给弄好了!下面把过程跟大家分享一下: 首先是Oracle10gR2的安装,在Oracle的官方网站上可以下到Oracle10gR2的安装程序,安装过 ...
- MySQL 数据 导入到 SQL Service
1.下载安装ODBC驱动程序 地址:http://dev.mysql.com/downloads/connector/odbc/ 注意:系统的版本问题( 我的是64位的win7系统,但是SQL Ser ...
- Python基础学习Day7 基础数据类型的扩展 集合 深浅copy
一.基础数据类型的扩展 1.1GBK ---> UTF - 8 # str --->bytes s1 = '太白' # 字符串是unicode编码 b1 = s1.encode('gbk' ...
- echart生成饼状图
//绘制图表. echarts.init(document.getElementById('main')).setOption({ tooltip : { trigger: 'item', //触发类 ...
- @JsonInclude(JsonInclude.Include.NON_NULL) 加在对象上
@JsonInclude(JsonInclude.Include.NON_NULL) public class ViewWorkermessage implements Serializable { ...
- shell 通过shift获得某位后的入参
有时shell的入参个数不定,想要获得第2位后的参数,作为新的入参调用其他脚本 通常这时候想到的方法是用遍历,例如下面的方法: for (( i=2;i<=$#;i++)) do ...
- 每月IT摘录201901
技术 1.Jsessionid只是tomcat的对sessionid的叫法,其实就是sessionid:在其它的容器也许就不叫jsessionid了. 2.在 InnoDB 中,索引使用的数据结构是 ...