netcore2.0 ORM框架中如何配置自定义的主外键加载

本文涉及的产品
云数据库 RDS MySQL Serverless,0.5-2RCU 50GB
简介: 环境:netcore2.0 DB :mysql ORM:Ant https://github.com/yuzd/AntData.ORM/tree/netcore2 [给我一个star吧] NUGET:Install-Package AntData.
环境:netcore2.0
DB :mysql
ORM:Ant https://github.com/yuzd/AntData.ORM/tree/netcore2 [给我一个star吧]
NUGET: Install-Package AntData.Core.Mysql
 
测试的表结构:
 
 
新建一个netcore app项目
 
然后添加一个 名称为 Model 的 .Net Standard2.0 项目
 
https://github.com/yuzd/AntData.ORM/tree/netcore2/AntData/AntData.DbModels 里面copy出3个文件夹放入到 刚刚新建的 Model
的项目中
 
 
打开上图中的 EntityRobotForMysql.tt 脚本文件 然后把里面的 db的信息替换成自己的
 
person 和 school表 虽然没有在db层建立 主外键关系
然后依然可以在orm层映射主外键关系【这个也是ant orm的一个特色】
在 EntityRobotForMysql.tt 加入下面的代表 就能映射2个表的主外键关系了
然后按 Ctrl+S 触发生成 model 文件
分为三部分
1:Entitys类 相当于db ,每个 IQueryable类型的Property 相当于 一个Table
2:具体的每个table的定义
3:table的扩展类
 
 
var person = DB.Tables.People.FirstOrDefault(r => r.Name.Equals("nainaigu"));
这个的意思是 查询 person表里面第一个 name = nainaigu 的row
那如何加载外键 scholl的意思呢
使用LoadWith 方法 的意思是 查询的时候加载外键,外键我们刚刚在tt文件里面配置了
var person = DB.Tables.People.LoadWith(r=>r.School).FirstOrDefault(r => r.Name.Equals("nainaigu"));
 
 
 
 
总结:
一般dba都不会建议你直接在db里面建主外键。都建议在代码层控制。
使用antorm框架在配置一下主外键映射关系,代码中用loadWith加载外键model 提供了便捷。
针对orm框架如果您有好的建议请畅所欲言
 
附demo下载

如果您觉得阅读本文对您有帮助,请点一下“推荐”按钮,您的“推荐”将是我最大的写作动力!欢迎各位转载,转载文章之后须在文章页面明显位置给出作者和原文连接,谢谢。
相关实践学习
基于CentOS快速搭建LAMP环境
本教程介绍如何搭建LAMP环境,其中LAMP分别代表Linux、Apache、MySQL和PHP。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
|
域名解析 Kubernetes Java
图文详述Nacos配置中心使用:应用间配置共享、扩展配置文件加载优先级、新老版本差异
图文详述Nacos配置中心使用:应用间配置共享、扩展配置文件加载优先级、新老版本差异
2565 1
图文详述Nacos配置中心使用:应用间配置共享、扩展配置文件加载优先级、新老版本差异
|
30天前
|
资源调度 前端开发 JavaScript
推荐一款可以自动创建视频的前端Ract框架
推荐一款可以自动创建视频的前端Ract框架
|
30天前
|
XML JSON Java
springboot如何创建并配置环境3 - 配置扩展属性(上)
springboot如何创建并配置环境3 - 配置扩展属性(上)
springboot如何创建并配置环境3 - 配置扩展属性(上)
|
存储 数据库 文件存储
Ocelot简易教程(七)之配置文件数据库存储插件源码解析
作者:依乐祝原文地址:https://www.cnblogs.com/yilezhu/p/9852711.html 上篇文章给大家分享了如何集成我写的一个Ocelot扩展插件把Ocelot的配置存储到数据库中。
1268 0
|
4月前
|
小程序 关系型数据库 数据库连接
laravel5.8(十一)配置使用多数据库
有的时候,我们在开发的过程中需要连接多个数据库。 Laravel框架中早已为我们想到了这样的需求。 配置很简单。 在根目录下的/config/database.php文件中配置: Laravel中为我们提前预设了多种类型的数据库连接
25 0
|
5月前
|
SQL Java 关系型数据库
模仿Activiti工作流自动建表机制,实现Springboot项目启动后自动创建多表关联的数据库与表的方案
在一些本地化项目开发当中,存在这样一种需求,即开发完成的项目,在第一次部署启动时,需能自行构建系统需要的数据库及其对应的数据库表。
36 1
|
9月前
|
SQL 开发框架 .NET
10分钟系列:NetCore3.1+EFCore三步快速完成数据库交互
10分钟系列:NetCore3.1+EFCore三步快速完成数据库交互
|
9月前
|
SQL Java 数据库连接
MyBatis动态数据源配置(动态配置字段,库 适合简单逻辑)
MyBatis动态数据源配置(动态配置字段,库 适合简单逻辑)
87 0
|
SQL druid Java
Springboot 从数据库读取数据库配置信息,动态切换多数据源 最详细实战教程
Springboot 从数据库读取数据库配置信息,动态切换多数据源 最详细实战教程
3279 1
Springboot 从数据库读取数据库配置信息,动态切换多数据源 最详细实战教程
|
SQL 消息中间件 NoSQL