I've got a
database where I want to store user information and user_meta information.
The reason behind setting it up in this way was because the user_meta side may change over time and I would like to do this without disrupting the master user table.
If possible, I would like some advice on how to best set up this meta data table.
I can either set it as below:
+----+---------+----------+--------------------+
| id | user_id | key | value |
+----+---------+----------+--------------------+
| 1 | 1 | email |
[email protected] |
| 2 | 1 | name | user name |
| 3 | 1 | address | test address |
...
Or, I can set it as below:
+----+---------+--------------------+--------------------+--------------+
| id | user_id | email | name | address |
+----+---------+--------------------+--------------------+--------------+
| 1 | 1 |
[email protected] | user name | test address |
Obviously, the top verison is more flexible, but the bottom version is space saving and perhaps more efficient, returning all the data as a single record.
Which is the best way to go about this?
Or, am I going about this completely wrong and there's another way I've not thought of?