时间:2021-07-01 10:21:17 帮助过:6人阅读
也可以参照 https://www.nuget.org/packages/MySql.Data.EntityFrameworkCore 中其它方法。其它数据库提供程序可参照 https://docs.microsoft.com/zh-cn/ef/core/providers/index 。
安装成功后可以在依赖项中看到 MySql.Data.EntityFrameworkCore
接下来创建一个数据表结构,并添入示例数据,例如下图。
C#中创建对应的实体类,另外创建一个类继承dbContext,dbContext是EF框架中非常重要的一个环节,是建立实体类与数据库连接的桥梁,具体的原理,这里不进行赘述。
创建过程如下代码所示(注意要自行在项目中添加 Models 文件夹,并添加实体类文件,如 Person.cs)。
Models/Person.cs
using System.ComponentModel.DataAnnotations; namespace WebApi.Models { public class Person { [Key] public int Id { get; set; } [MaxLength(20)] public string Name { get; set; } [MaxLength(3)] public int Age { get; set; } } }
Models/CoreDbContext.cs
using Microsoft.EntityFrameworkCore;namespace WebApi.Models { public class CoreDbContext : DbContext { public virtual DbSet<Person> Person { get; set; } //创建实体类添加Context中 protected override void OnConfiguring(DbContextOptionsBuilder optionsBuilder) { if (!optionsBuilder.IsConfigured) { optionsBuilder.UseMySQL(@"server=localhost;uid=YourUserId;pwd=YourPassword; port=3306;database=DbName;sslmode=Preferred;"); } } } }
下面改写 ValuesController.cs 中相关代码,以测试 GET 方法。
Controllers/ValuesController.cs
using Microsoft.AspNetCore.Mvc; using System.Collections.Generic; using System.Linq; using WebApi.Models; namespace WebApi.Controllers { [Route("api/[controller]")] [ApiController] public class ValuesController : ControllerBase { // GET api/values [HttpGet] public List<Person> Get() { using (CoreDbContext _coreDbContext = new CoreDbContext()) { return _coreDbContext.Set<Person>().ToList(); } }
......
}
}
调试运行结果如下
表示数据库已经连接成功,并以 GET 方法取得数据。
针对上述的连接属性的情况来看,我们不应该把连接的属性编写在代码中,因此我们要设计一下,把连接的属性编写在配置文件中,对appsettings.json,Startup.cs,CoreDbContext.cs进行相关的配置,如下所示。
appsettings.json
{ "ConnectionStrings": { "DefaultConnection": "server=localhost;uid=YourUserId;pwd=YourPassword;port=3306;database=DbName;sslmode=Preferred;" }, "Logging": { "LogLevel": { "Default": "Warning" } }, "AllowedHosts": "*" }
Startup.cs
// This method gets called by the runtime. Use this method to add services to the container. public void ConfigureServices(IServiceCollection services) { //连接 mysql 数据库,添加数据库上下文 services.AddDbContext<CoreDbContext>(options =>
options.UseMySQL(Configuration.GetConnectionString("DefaultConnection"))); services.AddMvc().SetCompatibilityVersion(CompatibilityVersion.Version_2_2); }
CoreDbContext.cs
using Microsoft.EntityFrameworkCore; namespace WebApi.Models { public class CoreDbContext : DbContext { public virtual DbSet<Person> Person { get; set; } //创建实体类添加Context中 public CoreDbContext(DbContextOptions<CoreDbContext> options) : base(options) { } } }
上述代码高亮部分就是要修改或添加的内容,这时其实是已经把coreDbContext注入到容器中进行操作,而容器中对Context的注入方式为瞬时注入,因此后面要用到依赖注入的时候,很多时候,在数据层使用context的时候需要把对应的注入都设计为瞬时注入的形式,此处就不进行过多的提及。
我们在进行测试一下,这下我们就不用自己进行context的new操作,由于我们一开始进行设置的时候就已经进行了依赖注入的形式,不过,.netCore中只有构造注入,没有属性注入,因此我们就用构造注入的方式进行,如下所示。
Controllers/ValuesController.cs
using Microsoft.AspNetCore.Mvc; using System.Collections.Generic; using System.Linq; using WebApi.Models; namespace WebApi.Controllers { [Route("api/[controller]")] [ApiController] public class ValuesController : ControllerBase { private readonly CoreDbContext _coreDbContext; public ValuesController(CoreDbContext coreDbContext) { _coreDbContext = coreDbContext; } // GET api/values [HttpGet] public List<Person> Get() { return _coreDbContext.Set<Person>().ToList(); } ...... } }
至此写法改进完成。
在 Controllers/ValuesController.cs 中将模板文件的 Post 方法替换为
// POST api/values [HttpPost] public List<Person> Post() { return _coreDbContext.Set<Person>().ToList(); }
发布API后(搭建及发布过程此处不做讲解),用 Postman 测试。由下图可以看到获取了返回值。
【参考】开源中国:.netCore搭建WebAPI,以及MySQL,SQL server数据库连接方式
.net core WebAPI 初探及连接MySQL
标签:操作 工具 web 连接 技术 index values data install