怎样在mysql中设计好友关系库表

怎样在mysql中设计好友关系库表,第1张

1.建立用户信息表

create table userinfo(id int(4) not null primary key, name varchar(20) not null unique key)engine=innodb default charset=utf8

2.建立好友关系

create table friend(uid int(4) not null, foreign key(uid) references

userinfo(id),fid int(4) not null, foreign key(fid) references

userinfo(id),unique key(uid,fid))engine=innodb default charset=utf8

3.追加测试数据(满足uid<fid条件)

insert userinfo values(1111---9999,'namea---namei’)

insert friend values(1111,4444---6666)

insert friend values(5555,6666---9999)

4.查询好友(5555的好友)

select * from friend where uid=5555 or fid=5555

+-------+------+

| uid | fid|

+-------+------+

| 1111 | 5555 |

| 5555 | 6666 |

| 5555 | 7777 |

| 5555 | 8888 |

| 5555 | 9999 |

+-------+--------+

5.问题:

5.1.userinfo中的id和name不为null,且不可重复:table设计可以做到

5.2.friend中的uid和fid均不为null,且都来自于userinfo的id:table设计可以实现

5.3.(uid,fid)组合不可重复:table设计可以完成

5.4.好友关系的表达时,(1111,5555)和(5555,1111)有冗余,也会出现(1111,1111)这样的数据:这个在table设计实现比较麻烦,需要在程序层面实现,也即增加限制条件uid<fid即可

6.结果:

table设计达不到要求,或者较难达到要求时,可以在程序层面予以弥补。

create table 商品表 (PID int,name varchar(20) primary key(PID))

create table 用户表 (UID int,name varchar(20) primary key(UID))

create table 商品和用户关系表 (PUID int,UID int,PID int primary key(PUID),foreign key(UID) references 用户表(UID),foreign key(PID) references 商品表(PID))

以上,希望对你有所帮助!

你的设想是一个逻辑,但那种关系一般不是表能实习的,尤其是非事务支持的表,如果非要用表来表示:

SELECT fid FROM TABLE WHERE uid=selfId (我关注的用户)

SELECT COUNT(*) FROM TABLE WHERE fid=selfId (我的粉丝数)

SELECT b.uid FROM TABLE a, TABLE b WHERE b.fid = a.uid AND a.fid = b.uid(互粉的ID)


欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/zaji/7293972.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2023-04-03
下一篇2023-04-03

发表评论

登录后才能评论

评论列表(0条)

    保存