Want to improve your database design skills? Get my Database Design project Guides here (diagrams, explanations, and SQL scripts): databasestar.mykajabi.com/lpkj-dbdesign/?
Lembrando que esse vídeo é uma simplificação para um exercício, instagram e outras redes tem muito mais tabelas bem mais complexas como metadados de posts, estatisticas pré calculadas para algoritmos, tabelas sobre sessões e locais de acesso, embeddings de posts e usuários, grafos pré calculados para otimizar tempo e processamento, preferências, configurações, entre outros. Se você é um iniciante não ache que isso é o suficiente para criar uma rede social de verdade, leve como um exercício, nada mais
Thanks and congrats for your style of teaching, in my opinion one of if not the best, specially on real-life examples. I would be very curious to see how you approach the real-life example of a simpler ERP (Enterprise Resource Planning) system.
Please, correct me if I am wrong. At 6:14, don't you think app_user (ID (PK)) references post_media_user_tag.user_id (FK)? I believe you may have misplaced the pointer when drawing it.
Thanks ever so much for this! I've been working on a database structure for some uni coursework and couldn't determine how the relationships between a user and the userFollower table would work. This definitely helps. One quick question though, what tool did you use to create this? I've been using vision but this tool looks far more intuitive =.
Need more designs like this. What are these called I had searched for - Database Design - Database modelling But still only a few were found please upload any one application database design on weekly or 2weeks.
Glad you like these kinds of videos! I think it would be called “database design” and yes I haven’t seen many others on RUclips. I can create more of them - I have a bunch planned
The Relationship to the app_user to the post_media_user_tag wouldnt the app_user ID be linked to the user_id on the post_media_user_tag table for that FK? Just wanted to verify. Thanks for all the info!
Can you make a follow up video on what indexes can be added to improve performance when loading new posts for people you follow and when listing posts by a user
Good question. For this example, I only captured Likes, so there's only one reaction to capture. If we want to capture Dislikes, we could add a new column to that reaction table. If there is only Like and Dislike, perhaps a boolean or tinyint column called is_like, which could be 1 or 0.
I am using MongoDB. So What approach should I use to Social Media 1. Make Different collections(similar to tables) for likes, comments etc containing the referenceField(similar to foreign key) of Posts collection & User Collection for the user who interacted. 2. Making a List in the collections with a user_id, post_id and any interaction he made with the post. 3. Making a Entire Collection for a user where all his interactions will be stored. Ex. {_id, post_id, liked(if he liked), (list of comments that this particular user made(if any)), time of comment(if any comment made)} As MongoDB is Dynamic Database what should be right criteria for designing database
Thanks so much for this. I would really appreciate if you can send a link to the exported version of the database design so that I can easily navigate and study it properly
No problem! Here's the link to an image of the design: dbshostedfiles.s3.us-west-2.amazonaws.com/dbs/erd_instagram.png I'll add it to the description too.
people can also like/react to comments , should this be added in the same likes table ?Perhaps we can add a field indicating whether its a post or a comment ...... or maybe a different table , or just add likes property to a comment ? What would you suggest ?
That's true. I'd probably want to think about it a bit more, but my initial thoughts would be to add another table like the "reaction" table but it would sit between the app_user and comment table, to capture likes for comments.
Hi, I love this video! I have one question, how this design could be implemented in OLAP? Should I enter fake news and then create tabular model? How does it work?
Good question. I'm not sure on the specifics, but you would somehow translate this into a Fact and Dimension design, depending on what you want to report on.
Hey! I'm a data science student and currently I'm working on a project where I need to design a database for an education company (I work there). Your videos are helping a lot, but I have a question - We work with B2B and B2C and sell basically the same things for both, but have different treatments and procedures for each type. But there is this specific case in which we can treat them equally and not have to split the selling procedure for B2B and B2C. I have a table of B2B clients and another one for B2C clients. If I give PKs of the same type for them (something like a9b9-9ab9-a99b-9b9a), can I create another table where I just put them all in there and relate the selling tables with it? Or is there a better solution?
I think I understand the question: you want to have a single table with all clients (both B2B and B2C clients)? If so, then yes, you can do that, and it's probably the easiest solution. I have created this video here which may help. It's about having similar records (in your case, B2B and B2C clients) and whether you should have the same or different tables: ruclips.net/video/Pg0ADtwt32k/видео.html
Great video - got a lot of value out of this! Could you please consider doing a video on access controls? Post visibility is quite the feature on social media platforms. If you consider doing one, it would be nice to learn how do you support FB visibility settings such as, "this post can be seen by friends of friends".
Is this schema design scalable? The followers table could easily get to a million records just with a few thousand users. In that case how well can indexing work?
It would be scalable up to a certain point, I think. Modern relational databases can handle millions of records without issues, especially with indexing on commonly filtered fields. At some point, once your application and user base is large enough, you can investigate alternatives to improve any performance issues you get. This could be implementing features in the database, or migrating to a different technology.
@@DatabaseStar I was looking for reddit data base design actually and found this one 😅,I read article that reddit uses only one table !! if that's true its insane😃it would be interesting if you make video on the same.
Hi, I wonder (for a mobile app), or in general, do I need to separate a user entity from profil entity? what's advisable to merge them or separate them? even if they are the same but there are a lot of information about the user/profil, and for my project the user can only create 1 profil. Thank you
Good question! If a user can only ever have one profile, then you probably don't need to separate them. You could have all of the information in one table or entity. The main reason for having a separate profile to a user entity is if a user can have multiple profiles, or if a profile can be managed by multiple users (e.g. a business that has two owners, and each owner can manage the business profile).
Want to improve your database design skills? Get my Database Design project Guides here (diagrams, explanations, and SQL scripts): databasestar.mykajabi.com/lpkj-dbdesign/?
There not much of this on RUclips. Thanks for this tutorial
You're welcome, glad you find it useful!
I just completed a database class in my university. I'm trying now to create my own web based projects and this definitely helps me. Thank you!!!
Awesome! Glad to hear it’s helpful
Thanks for making these! Would love to see videos on normalization, performance, and other advanced topics such as transactions, locking etc
Glad it was helpful! Sure, I can make videos on those topics.
Love these db design videos, keep it up!
Thanks! Do you have any suggested topics or areas you'd like to see a database desgn video for?
Amazing! I am following and learning from your videos nowdays :) Love from India
Thanks! Glad to hear it.
Lembrando que esse vídeo é uma simplificação para um exercício, instagram e outras redes tem muito mais tabelas bem mais complexas como metadados de posts, estatisticas pré calculadas para algoritmos, tabelas sobre sessões e locais de acesso, embeddings de posts e usuários, grafos pré calculados para otimizar tempo e processamento, preferências, configurações, entre outros. Se você é um iniciante não ache que isso é o suficiente para criar uma rede social de verdade, leve como um exercício, nada mais
That’s true and a very good point!
Very helpful for interviews, Thanks
Glad it was helpful!
Thanks and congrats for your style of teaching, in my opinion one of if not the best, specially on real-life examples. I would be very curious to see how you approach the real-life example of a simpler ERP (Enterprise Resource Planning) system.
Thanks, I’m glad you like it! Sure I don’t know a lot about ERP but I’ll look into it.
this is very good, learned a lot and it was easy to follow and understand the design
Thanks! I’m glad you found it useful.
Very good explanation
Thanks!
Please, correct me if I am wrong. At 6:14, don't you think app_user (ID (PK)) references post_media_user_tag.user_id (FK)? I believe you may have misplaced the pointer when drawing it.
Yes, you're right! The line should be pointing to post_media_user.user_id and not the field it points to in the diagram. Thanks for letting me know!
Wonderful video!
Thanks!
Thank You
You’re welcome
great video
Thanks!
Great video. Thank you so much for sharing.
What tool did you use for creating this sample, please?
Thanks! I use LucidChart for this diagram.
Great video 👍
Thanks!
Thanks ever so much for this! I've been working on a database structure for some uni coursework and couldn't determine how the relationships between a user and the userFollower table would work. This definitely helps.
One quick question though, what tool did you use to create this? I've been using vision but this tool looks far more intuitive =.
Glad it was helpful! I used a tool called LucidChart for creating this diagram.
Need more designs like this.
What are these called I had searched for
- Database Design
- Database modelling
But still only a few were found please upload any one application database design on weekly or 2weeks.
Glad you like these kinds of videos! I think it would be called “database design” and yes I haven’t seen many others on RUclips. I can create more of them - I have a bunch planned
The Relationship to the app_user to the post_media_user_tag wouldnt the app_user ID be linked to the user_id on the post_media_user_tag table for that FK? Just wanted to verify. Thanks for all the info!
Good point! Yes, it should be linked to the post_media_user_tag.user_id, and not the post_media_user_tag.post_media_id. Thanks for pointing it out!
Can you create one for Twitter app? Awesome videos btw, love it.
Thanks! Sure, I can do that.
Mann;
Thanks a Ton;
You're welcome!
Really great content. I am grateful for it. What's the tool you are using to draw the map ?
Thanks! It's called LucidChart.
Can you make a follow up video on what indexes can be added to improve performance when loading new posts for people you follow and when listing posts by a user
Yeah, good idea!
Just a query I have. where are you capturing the actual reaction of the users Like/Dislike? in the reaction table I can see only user_id and post_id
Good question. For this example, I only captured Likes, so there's only one reaction to capture. If we want to capture Dislikes, we could add a new column to that reaction table. If there is only Like and Dislike, perhaps a boolean or tinyint column called is_like, which could be 1 or 0.
Can you do a database design for an ecommerce website like shein?
Good idea, I’ve got a video planned soon on that topic.
what is the name of this software that you are designing tables?
It's called LucidChart. I can do a demo of it in a future video.
I am using MongoDB. So What approach should I use to Social Media
1. Make Different collections(similar to tables) for likes, comments etc containing the referenceField(similar to foreign key) of Posts collection & User Collection for the user who interacted.
2. Making a List in the collections with a user_id, post_id and any interaction he made with the post.
3. Making a Entire Collection for a user where all his interactions will be stored. Ex. {_id, post_id, liked(if he liked), (list of comments that this particular user made(if any)), time of comment(if any comment made)}
As MongoDB is Dynamic Database what should be right criteria for designing database
For Performance, Optimization and OLAP
Hi Akshat, good question. I don't know a lot about MongoDB and these concepts, so can't really advise on this
@@DatabaseStar okay, thanks 😁
Thanks so much for this.
I would really appreciate if you can send a link to the exported version of the database design so that I can easily navigate and study it properly
No problem! Here's the link to an image of the design: dbshostedfiles.s3.us-west-2.amazonaws.com/dbs/erd_instagram.png
I'll add it to the description too.
@@DatabaseStar thanks a lot
Great modeling!
Can you make it in practice?)
Yeah you can make it in practice! The next steps would be to create the database and then develop the application - both are not small steps though!
people can also like/react to comments , should this be added in the same likes table ?Perhaps we can add a field indicating whether its a post or a comment ...... or maybe a different table , or just add likes property to a comment ? What would you suggest ?
That's true. I'd probably want to think about it a bit more, but my initial thoughts would be to add another table like the "reaction" table but it would sit between the app_user and comment table, to capture likes for comments.
Hi, I love this video!
I have one question, how this design could be implemented in OLAP? Should I enter fake news and then create tabular model? How does it work?
Good question. I'm not sure on the specifics, but you would somehow translate this into a Fact and Dimension design, depending on what you want to report on.
Hey! I'm a data science student and currently I'm working on a project where I need to design a database for an education company (I work there). Your videos are helping a lot, but I have a question - We work with B2B and B2C and sell basically the same things for both, but have different treatments and procedures for each type. But there is this specific case in which we can treat them equally and not have to split the selling procedure for B2B and B2C. I have a table of B2B clients and another one for B2C clients. If I give PKs of the same type for them (something like a9b9-9ab9-a99b-9b9a), can I create another table where I just put them all in there and relate the selling tables with it? Or is there a better solution?
I think I understand the question: you want to have a single table with all clients (both B2B and B2C clients)? If so, then yes, you can do that, and it's probably the easiest solution.
I have created this video here which may help. It's about having similar records (in your case, B2B and B2C clients) and whether you should have the same or different tables: ruclips.net/video/Pg0ADtwt32k/видео.html
@@DatabaseStar Thanks a lot, I'll watch it
Great video - got a lot of value out of this!
Could you please consider doing a video on access controls? Post visibility is quite the feature on social media platforms.
If you consider doing one, it would be nice to learn how do you support FB visibility settings such as, "this post can be seen by friends of friends".
Thanks! Sure, I can do a video on that topic, that's a good idea.
What app/ide did you use here to design?
I used LucidChart.
which tool u are using for drawing ER diagram
I’m using LucidChart
Is crows foot still used, I'm only learnt uml
As far as I know it's still used, but there are a few different types depending on which software you use.
Is this schema design scalable?
The followers table could easily get to a million records just with a few thousand users.
In that case how well can indexing work?
It would be scalable up to a certain point, I think. Modern relational databases can handle millions of records without issues, especially with indexing on commonly filtered fields.
At some point, once your application and user base is large enough, you can investigate alternatives to improve any performance issues you get. This could be implementing features in the database, or migrating to a different technology.
What does FK and PK stand for?
They stand for Foreign Key and Private Key Respectively
That's right, thanks Kishor!
@@DatabaseStar I was looking for reddit data base design actually and found this one 😅,I read article that reddit uses only one table !! if that's true its insane😃it would be interesting if you make video on the same.
Hi,
I wonder (for a mobile app), or in general, do I need to separate a user entity from profil entity? what's advisable to merge them or separate them? even if they are the same but there are a lot of information about the user/profil, and for my project the user can only create 1 profil.
Thank you
Good question! If a user can only ever have one profile, then you probably don't need to separate them. You could have all of the information in one table or entity. The main reason for having a separate profile to a user entity is if a user can have multiple profiles, or if a profile can be managed by multiple users (e.g. a business that has two owners, and each owner can manage the business profile).
@@DatabaseStar doesn't matter if the user table is huge (profile has lots of parameters) ?
Can I get the scheme?
As in the SQL code to create the database? I didn’t create any code but you’re welcome to write some.
where can i download the diagram that you made on this video? it's possible? thanks
Sure, I've just added it here: dbshostedfiles.s3.us-west-2.amazonaws.com/dbs/erd_instagram.png
I'll add it to the description too.
@@DatabaseStar thaaaaaanks!!!
Hello sir,
Why you didn't use Neo4j.
It will be very used full in Social media apps right
Good point, but I have no experience with Neo4j