雖然知道 Database First 被移除很久了,但目前專案還是主要使用資料庫為主,所以一直沒有機會使用。
但 Core 至少還是有提供 Scaffold-DbContext 可以使用 :
安裝 Microsoft.EntityFrameworkCore.SqlServer
data:image/s3,"s3://crabby-images/5cec1/5cec10ee00a81a63829f133c4bdd2ec1ee296ee7" alt=""
到 Domain 裡面把 Word Class 刪除,建立 EFModels 資料夾
data:image/s3,"s3://crabby-images/8c9f2/8c9f26a900c58bb33ea43a02923d3263a2420bcd" alt=""
安裝 Microsoft.EntityFrameworkCore.Tools
有噴錯請求 Vocabulary專案也要裝 Microsoft.EntityFrameworkCore.Tools ,這邊我就不先探討原因了…(裝! 都裝!)
data:image/s3,"s3://crabby-images/97d04/97d048b67de9cd211d7394e774fe33416894a88c" alt=""
改使用 Package Manager Console 指令產生 Model :
data:image/s3,"s3://crabby-images/be446/be446d9107b3f7e72546dc9e52caf642de4697d8" alt=""
執行
Scaffold-DbContext "Data Source=localhost;Initial Catalog=VocabularyDb;User ID=sa;Password=[你的密碼]" Microsoft.EntityFrameworkCore.SqlServer -OutputDir EFModels
data:image/s3,"s3://crabby-images/d170e/d170e57719c30cdeead214b2dc915870bb40c16c" alt=""
回到 Web 專案,在 Startup 註冊
data:image/s3,"s3://crabby-images/b6c4a/b6c4a7d207419c21ca23f30c3b228775b3b82f29" alt=""
將連線加到 appsettings.json
data:image/s3,"s3://crabby-images/50ebc/50ebc0f7f17942436f15aee3cf0a90c6d237335e" alt=""
回到 WordsController 修改程式 :
[Route("api/[controller]")]
[ApiController]
public class WordsController : ControllerBase
{
private readonly VocabularyDbContext _dbContext;
public WordsController(VocabularyDbContext dbContext)
{
_dbContext = dbContext;
}
[HttpGet]
public IActionResult Get()
{
try
{
var result = _dbContext.Words.ToList();
return Ok(result);
}
catch (Exception e)
{
return BadRequest(e.Message);
}
}
}
在 資料庫直接添加一筆資料測試
data:image/s3,"s3://crabby-images/de2e3/de2e33e565bc9d5b31c3bd1bf377a47db247ed16" alt=""
執行 Postman 查詢後可以正常存取(灑花
data:image/s3,"s3://crabby-images/82084/820847a01ff8c0d57a2de351405eff89e29b0cc0" alt=""
其他 : 如果資料庫有異動,則在參數多加一個 -f 複寫檔案
Scaffold-DbContext "Data Source=localhost;Initial Catalog=VocabularyDb;User ID=sa;Password=[你的密碼]" Microsoft.EntityFrameworkCore.SqlServer -OutputDir EFModels -f