前言:

  本章主要通过一个完整的示例讲解ASP.NET Core MVC+EF Core对MySQL数据库进行简单的CRUD操作,希望能够为刚入门.NET Core的小伙伴们提供一个完整的参考实例。关于ASP.NET Core MVC+EF操作MsSQL Server详情请参考官方文档(https://docs.microsoft.com/zh-cn/aspnet/core/data/ef-mvc/?view=aspnetcore-3.1)。

示例实现功能预览:

博客实例源码下载地址:

https://github.com/YSGStudyHards/ASP.NET-Core-MVC-Layui-EF-Core-CRUD_Sample

一、创建ASP.NET Core Web应用程序:

注意,本章节主要以APS.NET Core 3.1版本作为博客的样式实例!

二、添加EF Core NuGet包:

  若要在项目中使用EF Core操作MySQL数据库,需要安装相应的数据库驱动包。 本章教程主要使用 MySQL数据库,所以我们需要安装相关驱动包MySql.Data.EntityFrameworkCore。

安装方式:

点击工具=>NuGet包管理器=>程序包管理器控制台输入以下命令:

Install-Package MySql.Data.EntityFrameworkCore -Version 8.0.20

点击工具=>NuGet包管理器=>管理解决方案的NuGet程序包:

搜索:MySql.Data.EntityFrameworkCore  点击安装。

三、创建对应数据库表的实体模型:

  注意该篇博客使用的是手动模型优先的方式进行数据库表字段与模型属性映射,当然如果大家觉得这样子比较麻烦的话可以真正意义上的模型优先,直接创建模型在program.cs中配置创建对应模型的数据库逻辑代码即可无需手动创建数据库,可参考官网文档教程(https://docs.microsoft.com/zh-cn/aspnet/core/data/ef-rp/intro?view=aspnetcore-3.1&tabs=visual-studio#create-the-database)。

创建用户模型(UserInfo):

注意:属性大小写和数据库中的表字段保持一致,Id 属性成为此类对应的数据库表的主键列。 默认情况下,EF Core 将名为 Id 或 xxxID 的属性视为主键。 有关详细信息,请参阅 F Core - 密钥

    /// <summary>
/// 学生信息模型
/// </summary>
public class UserInfo
{
/// <summary>
/// 学生编号
/// </summary>
[Description("学生编号")]
public int? Id { get; set; } /// <summary>
/// 学生姓名
/// </summary>
[Description("学生姓名")]
public string UserName { get; set; } /// <summary>
/// 学生性别
/// </summary>
[Description("学生性别")]
public string Sex { get; set; } /// <summary>
/// 学生联系电话
/// </summary>
[Description("学生联系电话")]
public string Phone { get; set; } /// <summary>
/// 学生描述
/// </summary>
[Description("学生描述")]
public string Description { get; set; } /// <summary>
/// 学生爱好
/// </summary>
[Description("学生爱好")]
public string Hobby { get; set; }
}

四、将数据库连接字符串添加到 appsettings.json:

{
"Logging": {
"LogLevel": {
"Default": "Information",
"Microsoft": "Warning",
"Microsoft.Hosting.Lifetime": "Information"
}
},
"AllowedHosts": "*",
"ConnectionStrings": {
"MySqlConnection":"Data Source=127.0.0.1;User ID=root;Password=root;DataBase=SchoolUserInfo_db"
}
}

五、创建数据库上下文:

概述:

数据库上下文类是为给定数据模型协调 EF Core 功能的主类。 上下文派生自 Microsoft.EntityFrameworkCore.DbContext。 上下文指定数据模型中包含哪些实体。 在此项目中将数据库上下文类命名为 SchoolUserInfoContext。

创建:

using Microsoft.EntityFrameworkCore;
using Model; namespace Dal
{
public class SchoolUserInfoContext : DbContext
{
public SchoolUserInfoContext(DbContextOptions<SchoolUserInfoContext> options)
: base(options)
{
} /// <summary>
/// DbSet实体集属性对应数据库中的表(注意实体集名必须与表明一致)
/// </summary>
public DbSet<UserInfo> UserInfos { get; set; } /// <summary>
/// TODO:当数据库创建完成后, EF 创建一系列数据表,表名默认和 DbSet 属性名相同。 集合属性的名称一般使用复数形式,但不同的开发人员的命名习惯可能不一样,
/// 开发人员根据自己的情况确定是否使用复数形式。 在定义 DbSet 属性的代码之后,添加下面代码,对DbContext指定单数的表名来覆盖默认的表名。
/// </summary>
/// <param name="modelBuilder"></param>
protected override void OnModelCreating(ModelBuilder modelBuilder)
{
modelBuilder.Entity<UserInfo>().ToTable("UserInfo");
}
}
}

六、将上下文添加到 Startup.cs 中的依赖项注入:

        // This method gets called by the runtime. Use this method to add services to the container.
public void ConfigureServices(IServiceCollection services)
{
//注入EF Core数据库上下文服务
services.AddDbContext<SchoolUserInfoContext>(options =>
options.UseMySQL(Configuration.GetConnectionString("MySqlConnection"))); services.AddControllersWithViews();
}

七:引入Layui样式和js:

前往官网下载Layui相关样式和js包,下载地址:https://www.layui.com/

Layui弹出层插件layer.js(有很多地方需要用到弹窗),下载地址:https://layer.layui.com/

将相关文件存放到wwwroot文件下:

将相关文件引入默认布局页面中:

八、 ASP.NET Core MVC 和 EF Core实现MySQL  CRUD功能:

注意在这里主要展示的EF Core与数据库操作的部分代码,详细代码可下载实例源码查看。

Create:

        /// <summary>
/// 学生信息添加
/// </summary>
/// <param name="addUserInfo"></param>
/// <returns></returns>
public async Task<bool> Create(AddUserInfoViewModel addUserInfo)
{
try
{
var userInfo=new UserInfo()
{
UserName = addUserInfo.UserName,
Sex = addUserInfo.Sex,
Hobby = addUserInfo.Hobby,
Phone = addUserInfo.Phone,
Description = addUserInfo.Description
}; _shoSchoolUserInfoContext.UserInfos.Add(userInfo); await _shoSchoolUserInfoContext.SaveChangesAsync(); return true;
}
catch
{
return false;
}
}

Retrieve:

        /// <summary>
/// 获取用户信息
/// </summary>
/// <param name="page">当前页码</param>
/// <param name="limit">显示条数</param>
/// <param name="userName">用户姓名</param>
/// <returns></returns>
public async Task<PageSearchModel> GetPageListData(int page = , int limit = , string userName = "")
{
try
{
List<UserInfo> listData;
var totalCount = ;
if (!string.IsNullOrWhiteSpace(userName))
{
listData = await _shoSchoolUserInfoContext.UserInfos.Where(x => x.UserName.Contains(userName)).OrderByDescending(x => x.Id).Skip((page - ) * limit).Take(limit).ToListAsync(); totalCount = _shoSchoolUserInfoContext.UserInfos
.Count(x => x.UserName.Contains(userName));
}
else
{
listData = await _shoSchoolUserInfoContext.UserInfos.OrderByDescending(x => x.Id).Skip((page - ) * limit).Take(limit).ToListAsync(); totalCount = _shoSchoolUserInfoContext.UserInfos.Count();
} return new PageSearchModel()
{
ResultMsg = "success",
Code = ,
TotalCount = totalCount,
DataList = listData
};
}
catch (Exception e)
{
return new PageSearchModel() { Code = , ResultMsg = e.Message };
}
}

Update:

        /// <summary>
/// 学生信息修改
/// </summary>
/// <param name="userInfo"></param>
/// <returns></returns>
public async Task<bool> Update(UserInfo userInfo)
{ try
{
_shoSchoolUserInfoContext.UserInfos.Update(userInfo); await _shoSchoolUserInfoContext.SaveChangesAsync(); return true;
}
catch
{
return false;
}
}

Delete:

        /// <summary>
/// 学生信息删除
/// </summary>
/// <param name="id"></param>
/// <returns></returns>
public async Task<bool> Delete(int? id)
{
try
{
var searchUserInfo = await _shoSchoolUserInfoContext.UserInfos.FindAsync(id); if (searchUserInfo == null)
{
return false;
} _shoSchoolUserInfoContext.UserInfos.Remove(searchUserInfo);
await _shoSchoolUserInfoContext.SaveChangesAsync(); return true;
}
catch
{
return false;
}
}

ASP.NET Core MVC+Layui使用EF Core连接MySQL执行简单的CRUD操作的更多相关文章

  1. ASP.NET Core MVC 2.x 全面教程_ASP.NET Core MVC 10. 使用EF Core

    支持的数据库:可以查看官方网站 https://docs.microsoft.com/en-us/ef/core/providers/ 安装了VS2017后会安装了LocalDB,验证localDB ...

  2. Working with Data » 使用Visual Studio开发ASP.NET Core MVC and Entity Framework Core初学者教程

    原文地址:https://docs.asp.net/en/latest/data/ef-mvc/intro.html The Contoso University sample web applica ...

  3. .NET Core 1.0、ASP.NET Core 1.0和EF Core 1.0简介

    .NET Core 1.0.ASP.NET Core 1.0和EF Core 1.0简介 英文原文:Reintroducing .NET Core 1.0, ASP.NET Core 1.0, and ...

  4. 使用ASP.NET Core MVC 和 Entity Framework Core 开发一个CRUD(增删改查)的应用程序

    使用ASP.NET Core MVC 和 Entity Framework Core 开发一个CRUD(增删改查)的应用程序 不定时更新翻译系列,此系列更新毫无时间规律,文笔菜翻译菜求各位看官老爷们轻 ...

  5. ASP.NET Core 开发-Entity Framework (EF) Core 1.0 Database First

    ASP.NET Core 开发-Entity Framework Core 1.0 Database First,ASP.NET Core 1.0 EF Core操作数据库. Entity Frame ...

  6. ASP.NET Core 开发 - Entity Framework (EF) Core

    EF Core 1.0 Database First http://www.cnblogs.com/linezero/p/EFCoreDBFirst.html ASP.NET Core 开发 - En ...

  7. 在Asp.Net Core 5 中使用EF Core连接MariaDB

    升级到Asp.Net Core 5,使用EF Core连接MariaDB,使用的Nuget包Pomelo.EntityFrameworkCore.MySql也升级到了5.0.0-alpha.2,然后发 ...

  8. 【.Net Core 学习系列】-- EF Core 实践(Code First)

    一.开发环境: VS2015, .Net Core 1.0.0-preview2-003156 二解决方案: 新建项目: File --> New --> Project -->   ...

  9. 【.Net Core 学习系列】-- EF Core实践(DB First)

    一.开发环境: VS2015, .Net Core 1.0.0-preview2-003156 二.准备数据: CREATE DATABASE [Blogging]; GO USE [Blogging ...

随机推荐

  1. H - Fire CodeForces - 864E 01背包

    https://codeforces.com/problemset/problem/864/E 这个题目要把这个按照物品毁灭时间进行排序,如果时间短就要排在前面,这个是因为要保证之后的物品的拯救不会影 ...

  2. Qt插件系统

    说明 近期入职新公司,新公司的项目用到了Qt的插件系统,花时间了解了一下,还以为Qt的插件系统有多么高级呢,原来归根到底还是 dll 的动态调用时获取其中的类那一招啊,原理和之前的文章<DLL的 ...

  3. node.js开发指南系列(1)partial is not defined

    ejs视图引擎中使用partial函数: <ul><%- partial('listitem', items) %></ul> 报错:partial is not ...

  4. matlab 提示 Continuous sample time is not supported by discrete derivative 错误的解决办法

    Simulink仿真的时候,出行错误提示:Continuous sample time is not supported by discrete derivative 中文意思是:连续采样时间不支持离 ...

  5. 自己动手在Linux系统实现一个everything程序

    大家好,我是良许. 我们知道,在 Windows 下,有一款非常实用的神器,叫作 Everything ,它可以在极短的时间里,搜索出来你所想要的文件/目录,如下图示: Linux 下也有一些类似于 ...

  6. spring源码解析--上

    本文是作者原创,版权归作者所有.若要转载,请注明出处. 首先是配置类 package com.lusai.config; import org.springframework.context.anno ...

  7. Zkeys:低门槛、易操作的智能云管理系统

    ZKEYS系统是一个功能强大的智能化管理系统,目前国内最大的IDC业务管理系统之一.功能模块涵盖用户中心系统.财务系统.工单系统.备案系统和云服务器.服务托管器.虚拟主机等产品的弹性在线购买及及时开通 ...

  8. 4-JVM 参数

    JVM 参数 标准参数:不会随着jdk版本的变化而变化.比如:java -version.java -help 非标准参数:随着JDK版本的变化而变化. -X参数[用的较少]非标准参数,也就是在JDK ...

  9. springDataJPQL实现增删改查及分页,原生sql查询,根据方法命名规则实现查询以及Specification查询

    一.使用方法 1.在dao中定义开一个方法,使用方法的参数设置jpql,并且使用方法的返回值接受查询结果,在方法上添加@query注解,在注解中写jpql语句进行增删改查,测试 2.使用原生的sql语 ...

  10. Linux --remote (ssh and VNC)

    远程管理 与个人计算机不同,服务器一般都是运行IDC机房中,所以我们通常不会接触到服务器硬件,而是通过各种远程管理方式对服务器进行控制. 常见的远程管理工具方式: -RDP(remote deskto ...