zoukankan      html  css  js  c++  java
  • ASP.NET Core 2.1使用EF Core操作MySql数据库

    本文转载自https://www.cnblogs.com/alan-lin/p/9997657.html

    一、新建数据表及项目

    1、新建测试用表

    CREATE TABLE `student` (
      `id` int(11) NOT NULL AUTO_INCREMENT,
      `name` varchar(255) DEFAULT NULL,
      `sex` bit(1) DEFAULT NULL,
      `age` int(11) DEFAULT NULL,
      PRIMARY KEY (`id`)
    ) ENGINE=InnoDB AUTO_INCREMENT=3 DEFAULT CHARSET=utf8;

    2、新建项目,添加EF Core 和 MySql驱动依赖项

    新建.net core 2.1 webapi 网站程序,NuGet 添加依赖项 Microsoft.EntityFrameworkCore.Tools(2.1.14) 和 MySql.Data.EntityFrameworkCore(8.0.18) 包

    3、添加实体类Student和数据库上下文

    添加实体类:新建 Entities 目录,在目录下新建 Student 实体类,在类上加  [Table("student")] 表名、属性上加[Column("id")] 字段名等与表对应,代码如下:

    using System;
    using System.Collections.Generic;
    using System.ComponentModel.DataAnnotations.Schema;
    using System.Linq;
    using System.Threading.Tasks;
    
    namespace Test.Entities
    {
        [Table("student")]
        public class Student
        {
            [Column("id")]
            public int ID { get; set; }
    
            [Column("name")]
            public string Name { get; set; }
    
            [Column("sex")]
            public int Sex { get; set; }
    
            [Column("age")]
            public int Age { get; set; }
        }
    }

    添加数据库操作目录 DataAccess,进入目录,添加数据库上下文目录 Base,并在 Base 目录下新建 AlanContext 上下文类,继承 DbContext 类,通过构造函数注入数据库连接,添加 DbSet<Student> 实体属性,代码如下:

    using Microsoft.EntityFrameworkCore;
    using System;
    using System.Collections.Generic;
    using System.Linq;
    using System.Threading.Tasks;
    using Test.Entities;
    
    namespace Test.DataAccess.Base
    {
        public class AlanContext : DbContext
        {
            public AlanContext(DbContextOptions<AlanContext> options)
                : base(options)
            { }
    
            public DbSet<Student> Student { get; set; }
        }
    }

    4、增、删、改、查等数据库操作

    在 DataAccess 目录下新建 Interface 目录,用于保存数据库操作的接口,在该目录下新建 IAlanDao 接口,在接口里增加 CreateStudent(),GetStudents(),GetStudentByID(),UpdateStudent(),UpdateNameByID(),DeleteStudentByID() 数据库 添、删、改、查接口,代码如下:

    using System;
    using System.Collections.Generic;
    using System.Linq;
    using System.Threading.Tasks;
    using Test.Entities;
    
    namespace Test.DataAccess.Interface
    {
        public interface IAlanDao
        {
            //插入数据
            bool CreateStudent(Student student);
    
            //取全部记录
            IEnumerable<Student> GetStudents();
    
            //取某id记录
            Student GetStudentByID(int id);
    
            //根据id更新整条记录
            bool UpdateStudent(Student student);
    
            //根据id更新名称
            bool UpdateNameByID(int id, string name);
    
            //根据id删掉记录
            bool DeleteStudentByID(int id);
        }
    }

    在 DataAccess 目录下新建 Implement 目录,用于保存数据库操作接口的实现,在该目录下新建 AlanDao 类,继承 IAlanDao 接口,实现接口里的数据库操作方法,在构造函数注入 AlanContext 数据库上下文,代码如下:

    using System;
    using System.Collections.Generic;
    using System.Linq;
    using System.Threading.Tasks;
    using Test.DataAccess.Base;
    using Test.DataAccess.Interface;
    using Test.Entities;
    
    namespace Test.DataAccess.Implement
    {
        public class AlanDao : IAlanDao
        {
            public AlanContext Context;
    
            public AlanDao(AlanContext context)
            {
                Context = context;
            }
    
            //插入数据
            public bool CreateStudent(Student student)
            {
                Context.Student.Add(student);
                return Context.SaveChanges() > 0;
            }
    
            //取某id记录
            public Student GetStudentByID(int id)
            {
                return Context.Student.SingleOrDefault(s => s.ID == id);
            }
    
            //取全部记录
            public IEnumerable<Student> GetStudents()
            {
                return Context.Student.ToList();
            }
    
            //根据id更新名称
            public bool UpdateNameByID(int id, string name)
            {
                var state = false;
                var student = Context.Student.SingleOrDefault(s => s.ID == id);
    
                if (student != null)
                {
                    student.Name = name;
                    state = Context.SaveChanges() > 0;
                }
    
                return state;
            }
    
            //根据id更新整条记录
            public bool UpdateStudent(Student student)
            {
                Context.Student.Update(student);
                return Context.SaveChanges() > 0;
            }
    
            //根据id删掉记录
            public bool DeleteStudentByID(int id)
            {
                var student = Context.Student.SingleOrDefault(s => s.ID == id);
                Context.Student.Remove(student);
                return Context.SaveChanges() > 0;
            }
        }
    }

    5、添加 StudentController 控制器,调用数据库操作方法

    在 Controllers 目录下,添加 StudentController 控制器,在构造函数注入 AlanDao 数据库操作,在控制器里 创建 Create(),Gets(),Get(),Update(),UpdateName(),Delete()等方法,调用 AlanDao 数据库操作方法,代码如下:

    using System;
    using System.Collections.Generic;
    using System.Linq;
    using System.Threading.Tasks;
    using Microsoft.AspNetCore.Http;
    using Microsoft.AspNetCore.Mvc;
    using Test.DataAccess.Interface;
    using Test.Entities;
    
    namespace Test.Controllers
    {
        public class StudentController : ControllerBase
        {
            private IAlanDao AlanDao;
    
            public StudentController(IAlanDao alanDao)
            {
                AlanDao = alanDao;
            }
    
            //插入数据
            public ActionResult<string> Create(string name, byte sex, int age)
            {
                if (string.IsNullOrEmpty(name.Trim()))
                {
                    return "姓名不能为空";
                }
    
                if (sex < 0 || sex > 2)
                {
                    return "性别数据有误";
                }
    
                if (age <= 0)
                {
                    return "年龄数据有误";
                }
    
                var student = new Student()
                {
                    Name = name,
                    Sex = sex,
                    Age = age
                };
    
                var result = AlanDao.CreateStudent(student);
    
                if (result)
                {
                    return "学生插入成功";
                }
                else
                {
                    return "学生插入失败";
                }
    
            }
    
            //取全部记录
            public ActionResult<string> Gets()
            {
                var names = "没有数据";
                var students = AlanDao.GetStudents();
    
                if (students != null)
                {
                    names = "";
                    foreach (var s in students)
                    {
                        names += $"{s.Name} 
    ";
                    }
    
                }
    
                return names;
            }
    
            //取某id记录
            public ActionResult<string> Get(int id)
            {
                var name = "没有数据";
                var student = AlanDao.GetStudentByID(id);
    
                if (student != null)
                {
                    name = student.Name;
                }
    
                return name;
            }
    
            //根据id更新整条记录
            public ActionResult<string> Update(int id, string name, byte sex, int age)
            {
                if (id <= 0)
                {
                    return "id 不能小于0";
                }
    
                if (string.IsNullOrEmpty(name.Trim()))
                {
                    return "姓名不能为空";
                }
    
                if (sex < 0 || sex > 2)
                {
                    return "性别数据有误";
                }
    
                if (age <= 0)
                {
                    return "年龄数据有误";
                }
    
                var student = new Student()
                {
                    ID = id,
                    Name = name,
                    Sex = sex,
                    Age = age
                };
    
                var result = AlanDao.UpdateStudent(student);
    
                if (result)
                {
                    return "学生更新成功";
                }
                else
                {
                    return "学生更新失败";
                }
            }
    
            //根据id更新名称
            public ActionResult<string> UpdateName(int id, string name)
            {
                if (id <= 0)
                {
                    return "id 不能小于0";
                }
    
                if (string.IsNullOrEmpty(name.Trim()))
                {
                    return "姓名不能为空";
                }
    
                var result = AlanDao.UpdateNameByID(id, name);
    
                if (result)
                {
                    return "学生更新成功";
                }
                else
                {
                    return "学生更新失败";
                }
            }
    
            //根据id删掉记录
            public ActionResult<string> Delete(int id)
            {
                if (id <= 0)
                {
                    return "id 不能小于0!";
                }
    
                var result = AlanDao.DeleteStudentByID(id);
    
                if (result)
                {
                    return "学生删除成功";
                }
                else
                {
                    return "学生删除失败";
                }
            }
        }
    }

    6、配置数据库连接字符串,注册数据库连接到容器,注册数据库操作类到容器

    在 appsettings.json 中配置数据库连接串

    {
      "ConnectionStrings": {
        "DefaultConnection": "server=localhost;port=3306;database=alan;uid=root;pwd=123456;",
      }
    }

    修改 Startup.cs 类的 ConfigureServices() 方法,注册数据库连接及数据库操作类

    var conn = Configuration.GetConnectionString("DefaultConnection");
    services.AddDbContext<AlanContext>(options => options.UseMySQL(conn));
    services.AddScoped<IAlanDao, AlanDao>();

    二、运行测试

    运行项目

    在浏览器中分别执行

    新增:http://localhost:5000/Student/Create?name=小木&sex=0&age=18

    查询所有:http://localhost:5000/Student/Gets

    指定查询:http://localhost:5000/Student/Get?id=1

    更新:http://localhost:5000/Student/Update?id=1&name=小森&sex=1&age=18

    更新指定信息:http://localhost:5000/Student/UpdateName?id=2&name=amos

    删除指定信息:http://localhost:5000/Student/Delete?id=2 

  • 相关阅读:
    Flutter-动画-原理篇
    Flutter-动画-实践篇
    Flutter-动画-概念篇
    Android-textview图文混排(网络图片)
    Android--解决图片保存到相册显示1970年1月1日 8:00的问题
    Android--使用JobService实现进程保活
    Android--获取手机联系人和Sim卡联系人
    git 代码服务器的网页版gitweb的搭建
    Android 内存管理中的 Shallow heap Retained heap
    欧几里德算法----最大公约数算法
  • 原文地址:https://www.cnblogs.com/chendongbky/p/11978725.html
Copyright © 2011-2022 走看看