asp.net coremvc+efcore增删改查

下面是一个使用 EF Core 在 ASP.NET Core MVC 中完成增删改查的示例:

  1. 创建一个新的 ASP.NET Core MVC 项目。

  2. 安装 EF Core 相关的 NuGet 包。在项目文件 (.csproj) 中添加以下依赖项:

xml 复制代码
<ItemGroup>
  <PackageReference Include="Microsoft.EntityFrameworkCore.SqlServer" Version="5.0.10" />
  <PackageReference Include="Microsoft.EntityFrameworkCore.Tools" Version="5.0.10">
    <PrivateAssets>all</PrivateAssets>
    <IncludeAssets>runtime; build; native; contentfiles; analyzers; buildtransitive</IncludeAssets>
  </PackageReference>
</ItemGroup>

确保将 Version 指定为你当前使用的 EF Core 版本。

  1. 创建一个名为 TodoItem 的实体类,定义在你的应用程序中需要存储的数据。
csharp 复制代码
public class TodoItem
{
    public int Id { get; set; }
    public string Title { get; set; }
    public bool IsCompleted { get; set; }
}
  1. 创建一个继承自 DbContext 的类 AppDbContext,并在其中定义实体集。
csharp 复制代码
public class AppDbContext : DbContext
{
    public AppDbContext(DbContextOptions<AppDbContext> options)
        : base(options)
    {
    }

    public DbSet<TodoItem> TodoItems { get; set; }
}
  1. Startup.csConfigureServices 方法中添加数据库上下文的配置。
csharp 复制代码
public void ConfigureServices(IServiceCollection services)
{
    services.AddDbContext<AppDbContext>(options =>
        options.UseSqlServer(Configuration.GetConnectionString("DefaultConnection")));

    // ...
}

确保在 appsettings.json 文件中添加名为 DefaultConnection 的数据库连接字符串。

  1. 创建一个简单的控制器 TodoItemsController,并添加以下操作方法。
csharp 复制代码
public class TodoItemsController : Controller
{
    private readonly AppDbContext _dbContext;

    public TodoItemsController(AppDbContext dbContext)
    {
        _dbContext = dbContext;
    }

    public IActionResult Index()
    {
        var todoItems = _dbContext.TodoItems.ToList();
        return View(todoItems);
    }

    public IActionResult Create()
    {
        return View();
    }

    [HttpPost]
    public IActionResult Create(TodoItem todoItem)
    {
        if (ModelState.IsValid)
        {
            _dbContext.TodoItems.Add(todoItem);
            _dbContext.SaveChanges();
            return RedirectToAction(nameof(Index));
        }
        return View(todoItem);
    }

    public IActionResult Edit(int id)
    {
        var todoItem = _dbContext.TodoItems.Find(id);
        if (todoItem == null)
        {
            return NotFound();
        }
        return View(todoItem);
    }

    [HttpPost]
    public IActionResult Edit(int id, TodoItem todoItem)
    {
        if (id != todoItem.Id)
        {
            return NotFound();
        }

        if (ModelState.IsValid)
        {
            _dbContext.Update(todoItem);
            _dbContext.SaveChanges();
            return RedirectToAction(nameof(Index));
        }
        return View(todoItem);
    }

    public IActionResult Delete(int id)
    {
        var todoItem = _dbContext.TodoItems.Find(id);
        if (todoItem == null)
        {
            return NotFound();
        }
        return View(todoItem);
    }

    [HttpPost, ActionName("Delete")]
    public IActionResult DeleteConfirmed(int id)
    {
        var todoItem = _dbContext.TodoItems.Find(id);
        if (todoItem == null)
        {
            return NotFound();
        }
        _dbContext.TodoItems.Remove(todoItem);
        _dbContext.SaveChanges();
        return RedirectToAction(nameof(Index));
    }
}
  1. 创建对应的视图文件。在 Views/TodoItems 目录下创建 Index.cshtmlCreate.cshtmlEdit.cshtmlDelete.cshtml

  2. 运行应用程序,并访问 https://localhost:{port}/TodoItems,将能够执行增删改查操作。

这是一个简单的使用 EF Core 完成增删改查的示例,你可以根据实际需求进行适当的调整和扩展。

相关推荐
Shadow(⊙o⊙)15 小时前
智能指针、循环引用、锁、删除器
开发语言·c++·后端·visual studio
星浩AI15 小时前
OpenAI 大神 Karpathy 开源:用 Obsidian 实现 LLM Wiki 知识库管理方法
后端·openai·agent
长河15 小时前
基于 Jib 实现无 Dockerfile 的 Spring Boot 应用容器化
java·spring boot·后端
架构源启16 小时前
2026 进阶篇:深入理解Spring Reactor响应式编程的核心引擎(源码级解析+实战避坑)
java·后端·spring
用户9623779544816 小时前
Ghost Bits:高位截断如何让 Java WAF 形同虚设
后端
薪火铺子16 小时前
SpringMVC请求处理流程源码解析(第2篇):处理器执行与参数绑定
java·后端·spring
SamDeepThinking16 小时前
一个跑了三年没出过问题的系统,我是怎么设计的
java·后端·架构
写了20年代码的老程序员16 小时前
做接口开发最烦的,不是 JSON 深,而是它打断你思考业务
后端
Walter先生16 小时前
Python 行情数据清洗实战:Z-Score、MAD 与分位数过滤的异常值检测
后端·websocket·架构·实时行情数据源·美股行情api
Cache技术分享16 小时前
397. Java 文件操作基础 - 创建常规文件与临时文件
前端·后端