一个简单的mysql数据问题
people表
id peoplename
orders表
id productname people(请问这里存people的id还是直接复制字段)
直接放id的话,如果people被删除的话,怎么办?
直接复制字段的话,如果修改people表中的数据,同时也要修改orders表的数据对吗?
这两种理解对吗?
大家平时实际操作的时候怎么处理的
谢谢
回复内容:
people表
id peoplename
orders表
id productname people(请问这里存people的id还是直接复制字段)
直接放id的话,如果people被删除的话,怎么办?
直接复制字段的话,如果修改people表中的数据,同时也要修改orders表的数据对吗?
这两种理解对吗?
大家平时实际操作的时候怎么处理的
谢谢
第一选择放id, 加外键约束. 关于你说的"直接放id的话,如果people被删除的话,怎么办", mysql在外键约束上有三个选项:
1. CASCADE: people表删除, 相应的order表的 记录也被删掉;
2. SET NULL: people表删除, 相应的order表的 记录 的列被置空;
3. RESTRICT(NO ACTION): 如果order表有相应的记录, 则对people表的删除 不被允许.
见: http://dev.mysql.com/doc/refman/5.6/en/create-table-foreign-keys.html
这大概可以解决你的问题了.
对存people直接复制字段, 除非这里的 people, order表操作 确实成为了性能瓶颈, 并且实测 直接复制字段 确实可以提高性能. 这样增加了冗余数据, 缺点: 1. 需要的存储空间增大; 2. 需要自己维护 order表和 people表的冗余字段.
应该是
<code>people: id peoplename orders: id productname pid comment "people id" </code>
如果people被删除,合理的话,相关的orders应该也被删除;保存的话,会产生冗余数据。
楼主,people有可能被删除了吗?用户一般不被删除。
同意楼上的,people一般不会被删除。如果真的要删除people的话,可以在程序中增加事务管理,级联删除people和order,如果删除失败就回滚。或者只是使用外键,并增加级联删除的约束。
orders表存people的id,建议修改people表时不要直接删除,加一个inuse字段表示是否有效。
建议设计表结构的初学者先学习下三范式

Heiße KI -Werkzeuge

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool
Ausziehbilder kostenlos

Clothoff.io
KI-Kleiderentferner

Video Face Swap
Tauschen Sie Gesichter in jedem Video mühelos mit unserem völlig kostenlosen KI-Gesichtstausch-Tool aus!

Heißer Artikel

Heiße Werkzeuge

Notepad++7.3.1
Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version
Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1
Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6
Visuelle Webentwicklungstools

SublimeText3 Mac-Version
Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Heiße Themen











MySQL und PhpMyAdmin können in den folgenden Schritten effektiv verwaltet werden: 1. Erstellen und Löschen von Datenbank: Klicken Sie einfach in phpMyadmin, um sie zu vervollständigen. 2. Verwalten Sie Tabellen: Sie können Tabellen erstellen, Strukturen ändern und Indizes hinzufügen. 3. Datenbetrieb: Unterstützt das Einsetzen, Aktualisieren, Löschen von Daten und Ausführung von SQL -Abfragen. 4. Daten importieren und exportieren: Unterstützt SQL, CSV, XML und andere Formate. 5. Optimierung und Überwachung: Verwenden Sie den Befehl optimizetable, um Tabellen zu optimieren und Abfrageanalysatoren und Überwachungstools zu verwenden, um Leistungsprobleme zu lösen.

Session_Start () iscrucialinphPFormAnagingUSSERSIONS.1) ItinitiatesanewSessionifnoneExists, 2) Wiederaufnahmen und 3) setaSessionCookieforContinuityAcrossRequests, aktivierende Anwendungen wie

Fügen Sie in MySQL Felder mit alterTabletable_nameaddcolumnNew_columnvarchar (255) nach oben nachzusteuern. Beim Hinzufügen von Feldern müssen Sie einen Speicherort angeben, um die Abfrageleistung und die Datenstruktur zu optimieren. Vor dem Löschen von Feldern müssen Sie bestätigen, dass der Betrieb irreversibel ist. Die Änderung der Tabellenstruktur mithilfe von Online-DDL, Sicherungsdaten, Testumgebungen und Zeiträumen mit niedriger Last ist die Leistungsoptimierung und Best Practice.

MySQL -Funktionen können zur Datenverarbeitung und -berechnung verwendet werden. 1. Grundlegende Nutzung umfasst String -Verarbeitung, Datumsberechnung und mathematische Operationen. 2. Erweiterte Verwendung umfasst die Kombination mehrerer Funktionen zur Implementierung komplexer Vorgänge. 3. Die Leistungsoptimierung erfordert die Vermeidung der Verwendung von Funktionen in der WHERE -Klausel und der Verwendung von Gruppenby- und temporären Tabellen.

Befolgen Sie die folgenden Schritte, um MySQL sicher und gründlich zu deinstallieren und alle Restdateien zu reinigen: 1. MySQL Service; 2. MySQL -Pakete deinstallieren; 3.. Konfigurationsdateien und Datenverzeichnisse; 4. Überprüfen Sie, ob die Deinstallation gründlich ist.

Die Installation von MySQL auf MacOS kann in den folgenden Schritten erreicht werden: 1. Installieren Sie Homebrew unter Verwendung des Befehls /bin/bash-c"$(curl-fSslhtps://raw.githubuSercontent.com/homebrew/install/head/install.sh) ". 2. Aktualisieren Sie Homebrew und verwenden Sie Brewupdate. 3. Installieren Sie MySQL und verwenden Sie BrewinstallMysql. V. Nach der Installation können Sie MySQL-U verwenden

Effiziente Methoden für das Batch -Einfügen von Daten in MySQL gehören: 1. Verwenden von InsertInto ... Wertesyntax, 2. Verwenden von LoadDatainFile -Befehl, 3. Verwendung der Transaktionsverarbeitung, 4. Stapelgröße anpassen, 5. Deaktivieren Sie die Indexierung, 6. Verwenden Sie die Einfügung oder einfügen.

Composer ist ein Abhängigkeitsmanagement -Tool für PHP und verwaltet Projektabhängigkeiten über Composer.json -Datei. 1) Composer.json analysieren, um Abhängigkeitsinformationen zu erhalten; 2) Abhängigkeiten analysieren, um einen Abhängigkeitsbaum zu bilden; 3) Download und installieren Sie Abhängigkeiten vom Packagisten in das Lieferantenverzeichnis. 4) Datei Composer.lock erzeugen, um die Abhängigkeitsversion zu sperren, um die Konsistenz und die Wartbarkeit von Projekten zu gewährleisten.
