码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • EF Core学习笔记:额外的外键属性 / 单项导航属性


    虽然一直在做定制化开发,但是不能总是食嗟来之食。很多东西还是自己必须要掌握的。

    额外的外键属性 

    为什么需要外键属性

    1、EF Core会在数据表中建外键列。

    2、如果需要获取外键列的值,就需要做关联查询,效率低。(各种join)

    3、需要一种不需要Join直接获取外键列的值的方式。

    设置外键属性

    1、在实体类中显式声明一个外键属性。

    2、关系配置中通过HasForeignKey(c=>c.ArticleId)指定这个属性为外键。

    3、除非必要,否则不用声明,因为会引入重复。

    然后记得去配置!不然EFcore不知道这个外键是哪里来的。

    复习一下 hasOne( )

     

     单项导航属性

     双向导航属性的麻烦:很多的表都会引用同一张表,如此,user表会建立很多反向的导航属性。

    没必要

     所以我们需要单项导航属性。

    要求者 和 批准者 都指向user表

     配置方法

    不设置反向的属性,然后配置的时候WithMany()不设置参数即可。

    单向属性如何反向获取数据

    1. //再查询一下即可:
    2. ctx.Leaves.Where(l => l.Requester == u)

    对于主从结构的“一对多”表关系,一般是声明双向导航属性。

    而对于其他的“一对多”表关系:如果表属于被很多表引用的基础表,则用单项导航属性,否则可以自由决定是否用双向导航属性。

     考虑到有单项导航属性的可能,我们一般用HasOne().WithMany()

     

  • 相关阅读:
    Java项目:基于Springboot+vue实现的付费自习室系统设计与实现(源码+数据库+毕业论文)附含微信小程序端代码
    【数据结构】栈和队列
    【双向链表的插入和删除】
    mysql 间隙锁原理深度详解
    css 固定图片尺寸16:9
    黄仁勋最新建议:找到一门技艺,用一生去完善、磨炼!
    电影下载工具推荐
    沉睡者IT - 如何识别NFT“洗盘交易”?
    STM32中断编程入门
    力扣(LeetCode)566. 重塑矩阵(C语言)
  • 原文地址:https://blog.csdn.net/dongnihao/article/details/125882757
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号