1.打開vs2017>Websql
1:建立實體類:數據庫
namespace ProductMvc.Models {
//商品類型 public class ProductType { public int ID { get; set; } public string TypeName { get; set; } public Product Product { get; set; } } } namespace ProductMvc.Models {
//商品 public class Product { public int ID { get; set; } public string ProductName { get; set; } public DateTime ProductDate { get; set; } public decimal Price { get; set; }
public int TypeID { get; set; } public ICollection<ProductType> ProductType; } }
2:建立數據庫上下文json
namespace ProductMvc.Models { public class ProductContext:DbContext { public ProductContext(DbContextOptions<ProductContext> options):base (options) { } public DbSet<ProductType> ProductType { get; set; } public DbSet<Product> Product { get; set; } protected override void OnModelCreating(ModelBuilder modelBuilder) { modelBuilder.Entity<ProductType>().ToTable("ProductType"); modelBuilder.Entity<Product>().ToTable("Product"); } } }
3:打開Startup.cs文件,上下文依賴注入關係app
public void ConfigureServices(IServiceCollection services) { services.AddDbContext<SchoolContext>(options => options.UseSqlServer(Configuration.GetConnectionString("ProductConnection"))); services.AddMvc(); }
打開appsettings.json文件並添加鏈接字符串ide
{ "Logging": { "IncludeScopes": false, "LogLevel": { "Default": "Warning" } }, "ConnectionStrings": { "ProductConnection": "Server=(localdb)\\mssqllocaldb;Database=DBProcuct;Trusted_Connection=True;MultipleActiveResultSets=true" } }
添加數據:添加類DbInitializerui
public class DbInitializer { public static void Initialize(ProductContext context) { context.Database.EnsureCreated(); if (context.Product.Any()) { return; } var products = new Product[] { new Product{ProductName="牙膏",ProductDate=DateTime.Parse("2017-12-12"),Price=25,TypeID=1}, new Product{ProductName="毛巾",ProductDate=DateTime.Parse("2017-12-15"),Price=15,TypeID=1}, new Product{ProductName="電磁爐",ProductDate=DateTime.Parse("2017-12-12"),Price=25,TypeID=2}, new Product{ProductName="蘋果",ProductDate=DateTime.Parse("2018-01-15"),Price=6,TypeID=3}, }; foreach (var item in products) { context.Product.Add(item); } context.SaveChanges(); var productType = new ProductType[] { new ProductType{ID=1,TypeName="百貨類"}, new ProductType{ID=2,TypeName="電器類"}, new ProductType{ID=3,TypeName="水果類"}, }; foreach (var item in productType) { context.ProductType.Add(item); } context.SaveChanges(); } }
在Program.cs,修改Main
方法來執行如下操做,在應用程序啓動:spa
using (var scope = BuildWebHost(args).Services.CreateScope()) { var services = scope.ServiceProvider; try { var context = services.GetRequiredService<ProductContext>(); DbInitializer.Initialize(context); } catch (Exception ex) { var logger = services.GetRequiredService<ILogger<Program>>(); logger.LogError(ex, "Have error!!!"); } } BuildWebHost(args).Run();
添加控制器和視圖:視圖帶有EF的MVC控制器.net
以上操做即建立好了一個簡單的 .net Core項目code