.net core 1.1下的EntityFramework Code First
新建asp.net core项目,然后把.net core引用的类库升级到1.1,这时,需要手动在project.json下添加一个runtimes节点,如下:
"runtimes":{
"win10-x64":{}
}
同时在Nuget中添加下面三个类库(1.1版本):
Microsoft.EntityFrameworkCore.Design
Microsoft.EntityFrameworkCore.SqlServer
Microsoft.EntityFrameworkCore.Tools
接下来定义DbContext,用来生成数据库,代码如下:
usingMicrosoft.EntityFrameworkCore;usingSystem.Collections.Generic;usingSystem.ComponentModel.DataAnnotations;namespaceEntityFrameworkDemo.Model{///<summary>///数据库对象///</summary>publicclassPermissionContext:DbContext{publicPermissionContext(DbContextOptions<PermissionContext>opt):base(opt){}protectedoverridevoidOnModelCreating(ModelBuildermodelBuilder){//确定UserRole表中的两个字段是联合主键modelBuilder.Entity<UserRole>().HasKey(u=>new{u.UserID,u.RoleID});}publicDbSet<User>Users{get;set;}publicDbSet<Role>Roles{get;set;}publicDbSet<UserRole>UserRoles{get;set;}}///<summary>///用户表///</summary>publicclassUser{[Key]publicintID{get;set;}publicstringUserName{get;set;}publicstringPassword{get;set;}publicList<UserRole>UserRoles{get;set;}}///<summary>///角色表///</summary>publicclassRole{[Key]publicintID{get;set;}publicstringRoleName{get;set;}publicList<UserRole>UserRoles{get;set;}}///<summary>///用户角色关系///</summary>publicclassUserRole{publicintUserID{get;set;}publicintRoleID{get;set;}publicUserUser{get;set;}publicRoleRole{get;set;}}}
这时,需要在StartUp.cs中添加数据连字符串,来指导自动生成数据库时的服务器,数据库名等信息
publicvoidConfigureServices(IServiceCollectionservices){varconnection=@"Server=.;Database=PermissionDb;Trusted_Connection=True;";services.AddDbContext<PermissionContext>(options=>options.UseSqlServer(connection));services.AddMvc();}
现在,先Build一下项目,用两个命令在程序包管理器控制台(vs的菜单“工具”-“NuGet包管理器”-“程序包管理器控制台”)中执行:
Add-Migration MyFirstMigration
用来生成命令,生成数据库和表的C#代码
Update-Database
执行生成的代码
在用Add-Migration MyFirstMigration时会报个错,在netcoreapp1.1中没有需要的项目配置文件(.json的),这时打开bin目录,会发现在netcoreapp1.1下会多一个win10-x64文件夹,这正是我们手工在project.json中添加的,打开这个文件夹,把里面对应的.json复制出来就可以(这里应该是Add-MigrationMyFirstMigration生成代码时,默认的寻找配置文件与我们手工添加runtimes的路径不一直导致)
复制完后再Add-Migration MyFirstMigration一次
会发现在项目中添加了一个文件夹Migrations,并在下面生成两个文件,这便是生成数据库所需的指令。
现在再执行Update-Database
当执行成功后,用SQL Server的管理工具查看,生成的数据库,并且表中的表关系入下:
声明:本站所有文章资源内容,如无特殊说明或标注,均为采集网络资源。如若本站内容侵犯了原著者的合法权益,可联系本站删除。