所以,我已经在 stackoverflow 上阅读了很多答案,但我仍然对其中的整个概念感到困惑。具体来说,我已经阅读了这篇文章(包括它引用的所有文章),但似乎无法真正理解这个概念(或者可能是我混淆了基数(n:m 等)和恒等式):
Still Confused About Identifying vs. Non-Identifying Relationships
我的问题是:我知道识别关系意味着子实体的主键必须包含其外键,而对于非识别关系则相反(这是正确的吗?)。现在,这对我来说似乎有点太“前瞻性”了?在其中一个链接的评论之一中也说了同样的话。我怎样才能“退后一步”并真正看到哪些关系属于哪个身份?
比如我有两个困境:
job_title( parent ,1)到 员工( child ,1..*)。我的想法是否正确,因为 job_title 是一个查找表,它一定是一个非识别关系?或者更准确地说“没有职位就不能存在员工,因此它必须是身份证明”?或者是定义该场景的关系?employee 到 employee_equipment(m:n 基数之间的桥接实体)到 equipment。现在,我读到这必须是 employee_equipment 双方的识别关系。但是,如果员工不需要设备怎么办?一个人可以有一个可选的识别关系吗? 我想我真的是在寻找一种方法来确定应该属于哪些身份表,而不考虑主键/外键,或者任何真正技术的东西。
如有任何帮助,我们将不胜感激!
最佳答案
您过度思考了可选性和身份之间的联系。在您更自然地理解整件事之前,最好将它们视为完全无关。
关于可选性,重要的是要记住可选性是有方向的。使用您的 employee_equipment 示例:当然,员工不需要设备。从 employee 到 employee_equipment 的一对多关系是可选的。同时,从相反的角度来看,这种关系是强制性的。您不能在 employee_equipment 中有记录,除非有 employee 与之关联。
身份与可选性无关,除了巧合从 child 到 parent 的身份关系是强制性的。就身份而言, parent 对 child 是否也是强制性的既不存在也不存在。
确定一段关系的原因是,您必须知道您在谈论的 parent 是谁(以及其他一些事情)才能知道您在谈论的 child 是什么人。也就是说,子项的主键必须包含父项的外键。
纯交集表(例如 employee_equipment)就是很好的例子。纯交集的主键是两个父表的外键的组合。请注意,有些人可能还会向这些类型的表添加代理键。如果有多个候选 key ,从身份的角度来看并不重要。确定同一性的重要因素是外键是否是候选键的一部分,以及该候选键是否恰好是主键。
另一个很好的例子类似于数据库的元数据目录,其中列由它所属的表标识,就像表由它所在的模式标识一样,等等。知道一个名为 NAME 的列并不能告诉您它是哪一列。知道它是 CUSTOMER 表中的 NAME 列会有所帮助。 (您还必须知道 CUSTOMER 所在的模式,等等)。
关于mysql - 识别与非识别关系(再次!!!),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15444083/
我的问题的一个例子是体育游戏。一场体育比赛有两支球队,一支主队和一支客队。我的事件记录模型如下:classTeam"Team"has_one:away_team,:class_name=>"Team"end我希望能够通过游戏访问一个团队,例如:Game.find(1).home_team但我收到一个单元化常量错误:Game::team。谁能告诉我我做错了什么?谢谢, 最佳答案 如果Gamehas_one:team那么Rails假设您的teams表有一个game_id列。不过,您想要的是games表有一个team_id列,在这种情况下
导读语言模型给我们的生产生活带来了极大便利,但同时不少人也利用他们从事作弊工作。如何规避这些难辨真伪的文字所产生的负面影响也成为一大难题。在3月9日智源Live第33期活动「DetectGPT:判断文本是否为机器生成的工具」中,主讲人Eric为我们讲解了DetectGPT工作背后的思路——一种基于概率曲率检测的用于检测模型生成文本的工具,它可以帮助我们更好地分辨文章的来源和可信度,对保护信息真实、防止欺诈等方面具有重要意义。本次报告主要围绕其功能,实现和效果等展开。(文末点击“阅读原文”,查看活动回放。)Ericmitchell斯坦福大学计算机系四年级博士生,由ChelseaFinn和Chri
文章目录一、概述简介原理模块二、配置Mysql使用版本环境要求1.操作系统2.mysql要求三、配置canal-server离线下载在线下载上传解压修改配置单机配置集群配置分库分表配置1.修改全局配置2.实例配置垂直分库水平分库3.修改group-instance.xml4.启动监听四、配置canal-adapter1修改启动配置2配置映射文件3启动ES数据同步查询所有订阅同步数据同步开关启动4.验证五、配置canal-admin一、概述简介canal是Alibaba旗下的一款开源项目,Java开发。基于数据库增量日志解析,提供增量数据订阅&消费。Git地址:https://github.co
之前说过10之后的版本没有3dScan了,所以还是9.8的版本或者之前更早的版本。 3d物体扫描需要先下载扫描的APK进行扫面。首先要在手机上装一个扫描程序,扫描现实中的三维物体,然后上传高通官网,在下载成UnityPackage类型让Unity能够使用这个扫描程序可以从高通官网上进行下载,是一个安卓程序。点到Tools往下滑,找到VuforiaObjectScanner下载后解压数据线连接手机,将apk文件拷入手机安装然后刚才解压文件中的Media文件夹打开,两个PDF图打印第一张A4-ObjectScanningTarget.pdf,主要是用来辅助扫描的。好了,接下来就是扫描三维物体。将瓶
Heroku支持人员告诉我,为了在我的Web应用程序中使用自定义字体(未安装在系统中,您可以在bash控制台中使用fc-list查看已安装的字体)我必须部署一个包含所有字体的.fonts文件夹里面的字体。问题是我不知道该怎么做。我的意思是,我不知道文件名是否必须遵循heroku的任何特殊模式,或者我必须在我的代码中做一些事情来考虑这种字体,或者如果我将它包含在文件夹中它是自动的......事实是,我尝试以不同的方式更改字体的文件名,但根本没有使用该字体。为了提供更多详细信息,我们使用字体的过程是将PDF转换为图像,更具体地说,使用rghostgem。并且最终图像根本不使用自定义字体。在
📢博客主页:https://blog.csdn.net/weixin_43197380📢欢迎点赞👍收藏⭐留言📝如有错误敬请指正!📢本文由Loewen丶原创,首发于CSDN,转载注明出处🙉📢现在的付出,都会是一种沉淀,只为让你成为更好的人✨文章预览:一.分辨率(Resolution)1、工业相机的分辨率是如何定义的?2、工业相机的分辨率是如何选择的?二.精度(Accuracy)1、像素精度(PixelAccuracy)2、定位精度和重复定位精度(RepeatPrecision)三.公差(Tolerance)四.课后作业(Post-ClassExercises)视觉行业的初学者,甚至是做了1~2年
在我让另一个人重做我的前端UI之前,我的Rails应用程序运行平稳。我已经尝试解决此错误3天了。这是错误:Nosuchfileordirectory-identifyExtractedsource(aroundline#59):575859606162@post=Post.find(params[:id])authorize@postif@post.update_attributes(post_params)flash[:notice]="Postwasupdated."redirect_to[@topic,@post]else{"utf8"=>"✓","_method"=>"patc
我看到其他人也遇到过类似的问题,但没有一个解决方案对我有用。0.3.14gem与其他gem文件一起存在。我已经完全按照此处指示完成了所有操作:https://github.com/brianmario/mysql2.我仍然得到以下信息。我不知道为什么安装程序指示它找不到include目录,因为我已经检查过它存在。thread.h文件存在,但不在ruby目录中。相反,它在这里:C:\RailsInstaller\DevKit\lib\perl5\5.8\msys\CORE\我正在运行Windows7并尝试在Aptana3中构建我的Rails项目。我的Ruby是1.9.3。$gemin
我已经开始使用mysql2gem。我试图弄清楚一些基本的事情——其中之一是如何明确地执行事务(对于批处理操作,比如多个INSERT/UPDATE查询)。在旧的ruby-mysql中,这是我的方法:client=Mysql.real_connect(...)inserts=["INSERTINTO...","UPDATE..WHEREid=..",#etc]client.autocommit(false)inserts.eachdo|ins|beginclient.query(ins)rescue#handleerrorsorabortentirelyendendclient.commi
我想合并多个事件记录关系例如,apple_companies=Company.where("namelike?","%apple%")banana_companies=Company.where("namelike?","%banana%")我想结合这两个关系。不是合并,合并是apple_companies.merge(banana_companies)=>Company.where("namelike?andnamelike?","%apple%","%banana%")我要Company.where("名字像?还是名字像?","%apple%","%banana%")之后,我会写代