栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

MySQL好友表

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

MySQL好友表

假设所有朋友也都在用户表中,则需要一个朋友表,该表定义了简单的一对多关系-将用户表链接回自身。所以

User TableUserID int identity not null[other attribute fields]Friends TableUserIDlink1 intUserIDlink2 int [other attribute field]

其中UserIDlink1和UserIDlink2都是Users表上的外键。

例如,如果我有三个用户

1 Joe2 Bill3 Jane

并且Joe和Jane是朋友,那么Friends表将只包含一行

1 3

上面的内容隐含地假设,如果A是B的朋友,那么B是A的朋友-
如果不是这种情况,您可能希望将UserIDlink1和UserIDlink2重命名为UserID和FriendID或类似的名称-
在这种情况下,也有两倍的记录。

同样对于双向配置(如果B是A的朋友,则A是B的朋友),还应在Friends表上为(UserIDlink1,UserIDlink2)和(UserIDlink2,UserIDlink1)设置索引,以确保在以下情况下访问始终有效我们正在搜索joe的朋友或jane的朋友(如果您未设置第二个索引,则第一个查询将是有效的索引查找,但第二个查询将需要全表扫描)。

如果您的链接不是双向的,则不必找出A的朋友,但您仍然可能最需要它,因为您可能还需要找出B的朋友。



转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/421368.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号