.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的分布式数据库实 ...
随机推荐
- 第一次面试linux后台岗位
今天给大家分享前段时间面试linux后台的面试题目,我从里面挑了几道大家比较陌生的题目,而且要那种手写代码的题目,这方面肯定很多人在实际面试时最怕的题目! 1.请说出如何用tcp服务实现文件的断点续传 ...
- Espruino似乎和Arduino一样
参考:https://baike.baidu.com/item/Espruino Espruino 编辑 锁定 讨论 Espruino 是一个微处理器的 JavaScript 解释器,我们用它来创 ...
- 【题解】[USACO12MAR]Cows in a Skyscraper G
题目链接 题目大意:给定一个集合\(S\),给一个限制条件\(P\),要求划分集合,使得每一个子集\(A\in S\),\(A\)满足限制条件\(P\),且划分总数最小. 注意到数据范围\(n< ...
- IDEA2020.2的破解
第一种方式:http://code.39sd.cn/ 直接获取二维码: 第二种:下载破解工具(本方法只是提供个人学习使用) 1.下载2020.2的idea 链接:https://pan.baidu.c ...
- php数据显示在html截取字符
<?php echo mb_subsrt($s['content'],0,20,'gbkj')?> gbk也可以是utf8根据实际情况来
- 安装memcache,步骤
1.先下载emcache.rar安装包<ps:随便安装在哪里文件夹,或者新建文件夹都是可以的> 2.解压安装包<ps:运行里面的程序> 3.然后根据自己的phpstudy的版本 ...
- org.apache.ibatis.ognl.OgnlException: source is null for getProperty(null, "enterpCd")-Mybatis报错
一.问题由来 下午快要下班时,登录测试服务器查看日志信息,看看有没有新的异常信息,如果有的话好及时修改.结果一看果然有新的异常信息. 主要的异常信息如下: 2020-10-13 14:51:03,03 ...
- 关于 Promise 的一些简单理解
一.ES6 中的 Promise 1.JS 如何解决 异步问题? (1)什么是 同步.异步? 同步指的是 需要等待 前一个处理 完成,才会进行 下一个处理. 异步指的是 不需要等待 前一个处理 完成, ...
- 2020年java全套教程,此套java涵盖了pdf,java源码,项目案例,完整视频约3000G的资源
疫情期间,百无聊赖,是不是需要充电一下,让自己更有竞争力呢?学习java一定要快呦! 废话不多说了,网盘已经爆炸了,把2006年-2020年的全部资料都发给爱学习的你吧, 希望可以改变你的命运,或者是 ...
- JSON,数组根据字段分组
function GroupbyName(data, Name) { //data数据源,Name 根据什么字段分组 var map = {}, dest = []; for (var i = 0; ...