.netcore基于mysql的codefirst
.netcore基于mysql的codefirst
此文仅是对于netcore基于mysql的简单的codefirst实现的简单记录。示例为客服系统消息模板的增删改查实现
第一步、创建实体项目,并在其中建立对应的实体类,以及数据库访问类
须引入Pomelo.EntityFrameworkCore.MySql和Microsoft.EntityFrameworkCore
/// <summary>
/// 消息模板
/// </summary>
public class MessatgeTemplate
{
/// <summary>
/// id
/// </summary>
[Key]
public System.Guid Id { get; set; }
/// <summary>
/// 名称
/// </summary>
[MaxLength(250)]
public string Name { get; set; }
/// <summary>
/// 关键字
/// </summary>
[MaxLength(500)] public string Keywords { get; set; }
/// <summary>
/// 内容
/// </summary> public string Content { get; set; }
/// <summary>
/// 语言
/// </summary>
[MaxLength(80)]
public string CultureCode { get; set; }
/// <summary>
/// 类别
/// </summary>
[MaxLength(250)] public string Category { get; set; }
/// <summary>
/// 备注信息
/// </summary>
public string Remark { get; set; }
/// <summary>
/// 是否启用
/// </summary>
public bool Enabled { get; set; }
/// <summary>
/// 创建时间
/// </summary> public DateTime Created { get; set; }
/// <summary>
/// 最近修改时间
/// </summary>
public DateTime LastModified { get; set; }
}
/// <summary>
///
/// </summary>
public class CustomerServiceContext : DbContext
{
public CustomerServiceContext(DbContextOptions<CustomerServiceContext> options)
: base(options)
{
}
/// <summary>
/// 配置
/// </summary>
/// <param name="optionsBuilder"></param>
protected override void OnConfiguring(DbContextOptionsBuilder optionsBuilder)
{
base.OnConfiguring(optionsBuilder);
} public virtual DbSet<MessatgeTemplate> MessatgeTemplate { get; set; } }
第二步、创建业务服务项目,添加对应的业务处理类
/// <summary>
/// 客服业务统一接口
/// </summary>
public interface ICustomerServicerSerice
{ }
/// <summary>
/// 模板业务类
/// </summary>
public class MessageTemplateService : ICustomerServicerSerice
{
private CustomerServiceContext _CustomerServiceContext;
public MessageTemplateService(CustomerServiceContext customerServiceContext)
{
this._CustomerServiceContext = customerServiceContext;
}
/// <summary>
/// 创建模板
/// </summary>
public void CreateMessageTemplate()
{
//todo create
}
/// <summary>
/// 修改模板
/// </summary>
public void ModifyMessageTemplate()
{
//TODO modified
}
/// <summary>
/// 获取模板
/// </summary>
/// <returns></returns>
public List<object> GetMessageTemplate()
{
//TODO根据传入参数查询模板
return null;
}
/// <summary>
/// 删除
/// </summary>
public void DeleteMessageTemplate(Guid id)
{
var template = _CustomerServiceContext.MessatgeTemplate.FirstOrDefault(p => p.Id == id);
if (template != null)
{
_CustomerServiceContext.MessatgeTemplate.Remove(template);
_CustomerServiceContext.SaveChanges();
} }
/// <summary>
/// 批量设置是否可用
/// </summary>
/// <param name="ids"></param>
/// <param name="enabled"></param>
public void BatchEnableTemplate(List<Guid> ids, bool enabled)
{
//TODO set enabled
}
}
第三步、创建webapi项目,并在其中建立对应的实体类,以及数据库访问类
须引入Microsoft.EntityFrameworkCore和Microsoft.EntityFrameworkCore.Design.
1、在appsettings.json中配置数据连接
"ConnectionStrings": {
    "CumstomerServiceConnection": "server=localhost;port=3306;database=CustomerServiceCenter;uid=root;pwd=root23456;CharSet=utf8"
  }
2、修改startup.cs类的ConfigureServices注入db访问类
  services.AddDbContext<CustomerServiceContext>(p => p.UseMySql(Configuration.GetConnectionString("CumstomerServiceConnection")));
3、设置该webapi项目为启动项目,在nuget程序包控制台选择第一步中创建的实体类项目依次运行如下脚本创建数据库
1)add-migration init
2) update-database
上面的两个命令中,add-migration表示添加数据迁移,其实就是将实体变更转换成sql(add-migraion后面的init只是个名称,可以自行定义),update-database是将生成的数据迁移信息更新到数据库
另外一些可能用到的命令
remove-migration ---将最近生成的迁移(没有更新到数据库的)移除掉
script-migration --生成数据库迁移相应的脚本
------------------------
命令执行成功后,就可以在数据库中找到创建好的数据库和表了

script-datatable可以生成数据库脚本语句

好了,以上就完成了codefirst的简单操作了。不过跟着第二步的业务类其实没啥关系!!!如果只是进行数据迁移确实没有service层什么事,但是业务逻辑要走通,实现crud,业务层还是必须的。
---------------------------------------------------------------------------------------------------------------------
以下就顺带写下controller中引入service,实现简单的删除业务逻辑(其它的业务逻辑---略)
在webapi创建MessageTemplateController
    [Route("api/[controller]")]
    [ApiController]
    public class MessageTemplateController : ControllerBase
    {
        private MessageTemplateService _MessageTemplateService;
        public MessageTemplateController(MessageTemplateService messageTemplateService)
        {
            this._MessageTemplateService = messageTemplateService;
        }
        /// <summary>
        /// 删除
        /// </summary>
        /// <param name="id"></param>
        [HttpPost("DeleteMessageTemplate")]
        public void DeleteMessageTemplate(Guid id)
        {
            _MessageTemplateService.DeleteMessageTemplate(id);
        }
        //TODO其他操作:查询,新增,修改等
    }
修改Startup.cs类,注入服务
public void ConfigureServices(IServiceCollection services)
{
services.AddControllers();
services.AddDbContext<CustomerServiceContext>(p => p.UseMySql(Configuration.GetConnectionString("CumstomerServiceConnection")));
#region 注入业务服务
Assembly assembly = Assembly.Load("Qingy.DotNetCoreStudy.CustomerServiceService");
List<Type> types = assembly.GetTypes().Where(u => u.IsClass && !u.IsAbstract && !u.IsGenericType
&& u.GetInterfaces().Any(p => p == typeof(ICustomerServicerSerice))
).ToList();
foreach (var item in types)
{
services.AddTransient(item);
}
#endregion
}
综合以上,就可以将api到db的完整实现了。
.netcore基于mysql的codefirst的更多相关文章
- 一个基于mysql构建的队列表
		通常大家都会使用redis作为应用的任务队列表,redis的List结构,在一段进行任务的插入,在另一端进行任务的提取. 任务的插入 $redis->lPush("key:task:l ... 
- 在Jena框架下基于MySQL数据库实现本体的存取操作
		在Jena框架下基于MySQL数据库实现本体的存取操作 转自:http://blog.csdn.net/jtz_mpp/article/details/6224311 最近在做一个基于本体的管理系统. ... 
- 基于MySQL协议的数据库中间层项目Atlas  -  360团队
		一.简介 Atlas是由 Qihoo 360公司Web平台部基础架构团队开发维护的一个基于MySQL协议的数据中间层项目.它在MySQL官方推出的MySQL-Proxy 0.8.2版本的基础上,修改了 ... 
- EF初始化mysql数据库codefirst
		EF使用Code First修改生成数据库表名的方法 1. 重写OnModelCreating,去掉表名复数 System.Data.Entity.ModelConfiguration.Convent ... 
- Mysql Explain 解读(基于MySQL 5.6.36)
		Mysql Explain 解读(基于MySQL 5.6.36) 1.语法 explain < table_name > #例子 explain select * from t3 wher ... 
- 搭建基于MySQL的读写分离工具Amoeba
		搭建基于MySQL的读写分离工具Amoeba: Amoeba工具是实现MySQL数据库读写分离的一个工具,前提是基于MySQL主从复制来实现的: 实验环境(虚拟机): 主机 角色 10.10.10.2 ... 
- 实操重写IK分词器源码,基于mysql热更新词库
		实操重写IK分词器源码,基于mysql热更新词库参考网址:https://blog.csdn.net/wuzhiwei549/article/details/80451302 问题一:按照这篇文章的介 ... 
- 基于MySQL提供的Yum repository安装MySQL5.6
		基于MySQL提供的Yum repository安装MySQL5.6 1:下载YUM包 1.1切换到root用户: 1)su - root 2)wget http://dev.mysql.com/ge ... 
- 新浪微博基于MySQL的分布式数据库实践
		提起微博,相信大家都是很了解的.但是有谁知道微博的数据库架构是怎样的呢?在今天举行的2011数据库技术大会上,新浪首席DBA杨海潮为我们详细解读了新浪微博的数据库架构——基于MySQL的分布式数据库实 ... 
随机推荐
- osgEarth使用笔记4——加载矢量数据
			目录 1. 概述 2. 详论 2.1. 基本绘制 2.2. 矢量符号化 2.2.1. 可见性 2.2.2. 高度设置 2.2.3. 符号化 2.2.4. 显示标注 2.3. 其他 3. 结果 4. 问 ... 
- 039 01 Android 零基础入门  01 Java基础语法 05 Java流程控制之循环结构 01 循环结构概述
			039 01 Android 零基础入门 01 Java基础语法 05 Java流程控制之循环结构 01 循环结构概述 本文知识点:循环结构概述 循环结构主要内容 while 循环 do-whiile ... 
- Jupyter 绘图怎么显示中文
			1. 简单加2行代码即可. import matplotlib.pyplot as plt plt.rcParams['font.sans-serif'] = [u'SimHei'] plt.rcPa ... 
- .NET Standard 版本支持
			系列目录 [已更新最新开发文章,点击查看详细] .NET标准已版本化.每个新版本都添加了更多的api.当库是针对某个.NET标准版本构建的时,它可以在实现该版本的.NET标准(或更高版本)的任 ... 
- minimist
			下载 minimistminimist 解析参数选项 这个模块是乐观主义者参数解析器的核心,没有所有的 奇特的装饰. 例子 var argv = require('minimist')(process ... 
- 多测师讲解selenium_运行报告相出错归纳_高级讲师肖sir
			<_io.TextIOWrapper name='<stderr>' mode='w' encoding='UTF-8'> EETraceback (most recent c ... 
- 多测师讲解selenium _携程选票定位练习_高级讲师肖sir
			打开携程网 from selenium import webdriverfrom time import sleepfrom selenium.webdriver.common.keys import ... 
- 4~20mA信号采集
			4-20mA信号采集 4-20mA信号采集可选卓岚ZLAN6802(485)/ZLAN6842(以太网)/ZLAN6844(无线wifi)他们不仅可以可采集4~20mA还可以采集 /0~5V/0~10 ... 
- 从Linux源码看Socket(TCP)的bind
			从Linux源码看Socket(TCP)的bind 前言 笔者一直觉得如果能知道从应用到框架再到操作系统的每一处代码,是一件Exciting的事情. 今天笔者就来从Linux源码的角度看下Server ... 
- centos8平台使用ethtool配置网卡
			一,ethtool命令所属的包 [root@centos8 liuhongdi]# whereis ethtool ethtool: /usr/sbin/ethtool /usr/share/man/ ... 
