.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的分布式数据库实 ...
随机推荐
- 089 01 Android 零基础入门 02 Java面向对象 02 Java封装 01 封装的实现 03 # 088 01 Android 零基础入门 02 Java面向对象 02 Java封装 01 封装的实现 03 使用包进行类管理(1)——创建包
089 01 Android 零基础入门 02 Java面向对象 02 Java封装 01 封装的实现 03 # 088 01 Android 零基础入门 02 Java面向对象 02 Java封装 ...
- NOI 2011 【阿狸的打字机】
之前讲了[AC自动姬],今天我终于把这题给刚下来了...嗯,来给大家讲一讲. 题目描述: 打字机上只有28个按键,分别印有26个小写英文字母和'B'.'P'两个字母.经阿狸研究发现,这个打字机是这样工 ...
- 第0天 | 12天搞定Pyhon,前言
依稀记得,在2014年的某一天,一位运营电商平台的多年好朋友,找我帮忙:一个月内,实现抓取竞争对手在某电商平台上的所有产品信息并统计每个产品的点击率. 说出来有些不好意思,那些年,参与过的产品挺多的, ...
- 远程触发Jenkins的Pipeline任务的并发问题处理
前文概述 本文是<远程触发Jenkins的pipeline任务>的续篇,上一篇文章实战了如何通过Http请求远程触发指定的Jenkins任务,并且将参数传递给Jenkins任务去使用,文末 ...
- Elasticsearch(3):别名
ES中可以为索引添加别名,一个别名可以指向到多个索引中,同时在添加别名时可以设置筛选条件,指向一个索引的部分数据,实现在关系数据库汇总的视图功能,这就是ES中别名的强大之处.别名是一个非常实用的功 ...
- id+is+深浅co'p'y
day06 一.id.is 关键字:id #唯一的,如果id相同,说明2个变量指向同一个地址,就是变量一==变量二 注意:id相同值一定相同,值相同但是id不一定相同(不同代码块的值相同,他们就像太阳 ...
- 多测师讲解自动化测试 _RF连接数据库_高级讲师肖sir
RF连接数据库:1.Connect To Database(连接数据库)2.Table Must Exist(表必须存在)3.Check If Exists In Database(查询某条件是否存在 ...
- XUEXI0.4
1.堆是一种内存管理方式,堆和栈是没有关联的.由于内存的容量很大,并且内存需求在时间和空间上没有规律,所以对操作系统来说,管理内存是非常复杂的. 2.堆这种内存管理方式特点是自由.堆内存是由操作系统划 ...
- elasticsearch-安装-centos7- es7.5 搭建
centos6 搭建 参考 https://www.cnblogs.com/php-linux/p/8758788.html 搭建linux虚拟机 https://www.cnblogs ...
- nginx集群:nginx配置负载均衡集群(nginx1.18.0)
一,nginx的负载均衡集群的特点: 1,nginx集群和lvs的不同? lvs集群:工作在第4层(传输层) nginx集群:工作在第7层(应用层) lvs集群:性能更强 nginx集群:功能更强:可 ...