以.net framework为例,包括数据库管理类库和启动项目两个项目文件数据库
新建一个类库,名称为XXX.Database
管理nuget包,引入库EntityFramework 6.2.0
建立表c#
public class Student { [Key] public int Id { get; set; } public string Name { get; set; } }
建立DbContext,设置nameOrConnectionString为"YourDatabase"ide
public class YourDbContext: DbContext { public DbSet<Student> Students { get; set; } public YourDbContext(): base("YourDatabase") { } }
这里启动项为一个控制台程序,一样添加EntityFramework 6.2.0
在App.config文件中添加链接字符串,注意,名称为"YourDatabase"
这里是Sql Server数据库的链接字符串学习
<configuration> <connectionStrings> <add name="YourDatabase" providerName="System.Data.SqlClient" connectionString="Data Source=YourIp;Initial Catalog=XXXDb;User Id=userId;Password=password;"/> </connectionStrings> </configuration>
其中providerName的名称,和App.config中的provider对应,后者是引入EntityFramework的时候自动添加的
至此,两个项目都可识别EntityFramework,添加了数据库上下文、数据库表、链接字符串,能够开始迁库.net
打开包管理控制台(Package Manager Console),设置默认程序(Default project)为XXX.Database,启动项为上述的控制台程序
首先,容许迁库code
Enable-Migrations
会自动生成Migrations文件夹及相关文件
而后建立迁移文件xml
add-migration add_Student_table
执行更新blog
update-database
查询字符串
using (var dbContext = new YourDbContext()) { var s = dbContext.Students.FirstOrDefault(x => x.Id == 1); }
其余再也不赘述get