mysql数据表的一对多 多对多
我想请问下数据表的简单设计
一个一对多 为何要在多表添加字段 而不在1表添加 请举例
多对多 为什么要把形成第三个表 形成一对多 而不在他们的表各添加一个字段呢?
我要详细的解释
回复内容:
我想请问下数据表的简单设计
一个一对多 为何要在多表添加字段 而不在1表添加 请举例
多对多 为什么要把形成第三个表 形成一对多 而不在他们的表各添加一个字段呢?
我要详细的解释
我终于看到了一个傻逼问题,你和几个人喝一杯饮料,一杯饮料对多个人,也就是一对多,难道不是每个人拿个管子插到那杯饮料里面去?也就是每个人有一个字段存储上面关联的饮料。
好了,多对多,假设两个表都有一个字段来存储关系,那么每新增一个对应关系你就需要在当前数据列新增一个关联数据到那个字段对吧?你以逗号分隔还是以什么分隔这个Id我不管,但是结构够清晰么?怎么想都不太符合常规逻辑啊。这个我懒得解释了。
编辑了半天,最后总结一下算了。
百度一下:第三范式
为了减少数据冗余
问题一:一对多在多表加字段仅仅是因为 ‘这个时候一是主表多是辅表,所以外键放在多上’,这个是业务需求定的,你完全可以放在一上,那样的话多是主表,一是辅表,外键在一上。
问题二:你说的那样是可行的,但是,成本过高(开发成本和维护成本),开发难度相对增大,维护成本增大。多对多普遍惯例就是新增一个第三方表。
官方着回答就是(这种反范式化设计)

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제









이번 장에서는 CakePHP의 환경 변수, 일반 구성, 데이터베이스 구성, 이메일 구성에 대해 알아봅니다.

PHP 8.4는 상당한 양의 기능 중단 및 제거를 통해 몇 가지 새로운 기능, 보안 개선 및 성능 개선을 제공합니다. 이 가이드에서는 Ubuntu, Debian 또는 해당 파생 제품에서 PHP 8.4를 설치하거나 PHP 8.4로 업그레이드하는 방법을 설명합니다.

CakePHP에서 데이터베이스 작업은 매우 쉽습니다. 이번 장에서는 CRUD(생성, 읽기, 업데이트, 삭제) 작업을 이해하겠습니다.

CakePHP는 PHP용 오픈 소스 프레임워크입니다. 이는 애플리케이션을 훨씬 쉽게 개발, 배포 및 유지 관리할 수 있도록 하기 위한 것입니다. CakePHP는 강력하고 이해하기 쉬운 MVC와 유사한 아키텍처를 기반으로 합니다. 모델, 뷰 및 컨트롤러 gu
