data:image/s3,"s3://crabby-images/62b14/62b14370cf8f9901ee8f2134f9cf053a75ae2e69" alt=""
data:image/s3,"s3://crabby-images/18141/1814163ec5385cb676a61d1f37d53aa16c39097c" alt=""
It’s necessary to split it out into different tables if you have a one-to-many relationship. Let’s say you have a list of driver licenses the person has had over the years, for example. Then you’d need the second table. So something like this:
SSN_Table
ID | SSN | Other info
Driver_License_Table
ID | SSN_ID | Issue_Date | Expiry_Date | Other_Info
Then you could do something like pull up a person’s latest driver’s license, or list all the ones they had, or pull up the SSN associated with that license.
Yeah, I work daily with a database with a very important non-ID field that is denormalized throughout most of the database. It’s not a common design pattern, but it is done from time to time.