Database Administrators Asked on December 17, 2021
I will start by mentioning that I am very new to databases. I am working in MySQL.
Can anyone give me a layman’s view of when you would use which settings for the foreign key options so when you would use On Delete: Cascade, On Delete: Set Null, On Delete: No Action. Also, how would these work in the sense of foreign keys in a bridging table, does it depend on the context of the database as in what data it contains or is there a general rule of thumb as to which setting is best in this type of relationship?
If you can, please state it simply as I am not totally au fait with the jargon given I am a relative newbie. Thanks so much
Say you have a table of users and a table of photos and photos has a foreign key column referencing the user_id
that corresponds to the unique ids of each user in the users table.
With ON DELETE CASCADE - when you delete a user when a photo is still referencing it, it will also the delete the photo.
With ON DELETE SET NULL - the row of the foreign key column of the photos table for the deleted user will be set to NULL as the users' unique id no longer existed because you deleted them.
So where would we want to use this? Well, this might be very useful if a user were to create some kind of resource and if for some reason you delete the user, but you still want to show the underlying photo. Maybe you need to delete a problematic user, but the posts might be meaningful so that might be a scenario where you want to hold the records around even if you deleted some other record that these things depend upon.
Answered by Daniel on December 17, 2021
It is possible to use databases without knowing anything about FOREIGN KEYs
and not using them at all. I recommend you start that way.
A FOREIGN KEY
does three things:
Since you mentioned a bridging table, I'll ramble on in that direction. (It sounds like you may have already mastered it.) There are 3 types of "relations" between "entities":
1:1 -- Don't use that. Why bother having two tables that march in lock step when one would do. (There exceptions; but that comes in another lecture.)
1:many -- This is simply implemented with a link ("id") in one table to allow "JOINing" to another table. Many rows of the first table link to a single row in the second table.
many:many -- This has many names, "bridging" on one of them. In the college example: students:classes, classes:teachers, etc. Bridging requires an extra table. See this for the optimal indexes: http://mysql.rjweb.org/doc.php/index_cookbook_mysql#many_to_many_mapping_table
Any of those mappings can degenerate to 1 or to 0.
Rambling on...
SELECT ... FROM tableA JOIN tableB ON ...
delivers rows that show up in both tables (based on the ON
condition).
SELECT ... FROM tableA LEFT JOIN tableB ON ...
delivers all the rows of table A, whether are not there is a matching row in table B. If none exists, then the columns that should have come from tableB will be NULLs
.
The ON
says how the tables are 'related'.
The WHERE
clause, if present, filters out some of the rows.
Answered by Rick James on December 17, 2021
Get help from others!
Recent Questions
Recent Answers
© 2024 TransWikia.com. All rights reserved. Sites we Love: PCI Database, UKBizDB, Menu Kuliner, Sharing RPP