mysql怎么进行表设计 mysql表设计工具

MYSQL数据库中怎么建立一个表呢?1、打开Navicat for MySQL,找到要创建数据库中数据表
2、接着mysql怎么进行表设计我们在“表”上面单击鼠标右键,然后点击“新建表”
3、然后mysql怎么进行表设计,右边就会出现设计表的界面mysql怎么进行表设计,这里可以设置表的字段名,类型,长度以及是否为null等
4、设计完数据表之后,点击“保存”按钮就OK了 。
5、我们在其中输入表名就点击确定就可以了,表名可以根据自己的需求来设置
怎样在mysql中设计好友关系库表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.追加测试数据(满足uidfid条件)
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设计实现比较麻烦,需要在程序层面实现,也即增加限制条件uidfid即可
6.结果:
table设计达不到要求 , 或者较难达到要求时 , 可以在程序层面予以弥补 。
mysql 多对多 怎么设计表1.数据库中的多对多关联关系一般需采用中间表的方式处理,将多对多转化为两个一对多 。
2.通过表的关系,来帮助我们怎样建表,建几张表 。
一对一
一张表的一条记录一定只能与另外一张表的一条记录进行对应,反之亦然 。
学生表:姓名 , 性别,年龄,身高,体重,籍贯,家庭住址,紧急联系人
其中姓名、性别、年龄、身高 , 体重属于常用数据,但是籍贯、住址和联系人为不常用数据
如果每次查询都是查询所有数据 , 不常用的数据就会影响效率,实际又不用
常用信息表:ID(P),姓名,性别,年龄,身高 , 体重
不常用信息表:ID(P),籍贯,家庭住址,紧急联系人
解决方案:将常用的和不常用的信息分享存储,分成两张表
不常用信息表和常用信息表,保证不常用信息表与常用信息表能够对应上:找一个具有唯一性的
字段来共同连接两张表 。
一个常用表中的一条记录永远只能在一张不常用表中匹配一条记录,反之亦然 。
一对多
一张表中有一条记录可以对应另外一张表中的多条记录;但是反过来,另外一张表的一条记录
只能对应第一张表的一条记录,这种关系就是一对多或多对一
母亲与孩子的关系:母亲,孩子两个实体
母亲表:ID(P),名字,年龄,性别
孩子表:ID(P),名字,年龄,性别
以上关系:一个妈妈可以在孩子表中找到多条记录(也可能是一条),但是一个孩子只能找到一个妈妈
是一种典型的一对多的关系 。

推荐阅读