create table userinfo(id int(4) not null primary key, name varchar(20) not null unique key)engine=innodb default charset=utf8
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设计达不到要求,或者较难达到要求时,可以在程序层面予以弥补。
在多的一方增加 一 的一方的id,例如 A 有 n 个好友,则在好友表(friends)中,增加一个字段用于存放A的id,则可以通过下列语句查询到A的所有好友:select * from friends where Aid = ?
一个用户表,所有用户都记录在内如你的id 1111
一个好友表 (下面表示1111有两个好友)
id 玩家id , 好友id
1 1111 1
2 1111 2
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)