如何用mysql设计表

如何用mysql设计表,第1张

选中某个表,然后右键点击,选择“设计表”即可。

也可以左键点击某个表(即选中某表),在上面辅助菜单栏里有“打开表”、“设计表”、“新建表”等按钮可点击,点击“设计表”按钮即可。

进入后,会d出新的 *** 作窗口,新窗口的菜单栏里有常用的修改表结构的按钮,右键点击某列字段也可以d出相应的修改表的 *** 作按钮。

其它摸索着看提示 *** 作即可,还是很简单的。

修改好表后点击菜单栏上的“保存”按钮即可。

注:若要查看修改表的sql语句,必须在“保存”之前点击“SQL预览”按钮。

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设计达不到要求,或者较难达到要求时,可以在程序层面予以弥补。


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

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

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

发表评论

登录后才能评论

评论列表(0条)

    保存