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,且都来自于use

本文介绍了如何在MySQL中创建用户信息表和好友关系表,并通过示例数据展示了查询好友关系的方法。讨论了表设计中的一些约束,如唯一性、外键关联以及潜在的冗余问题,提出在程序层面添加uid<fid条件来避免冗余。
最低0.47元/天 解锁文章
901

被折叠的 条评论
为什么被折叠?



