资讯

精准传达 • 有效沟通

从品牌网站建设到网络营销策划,从策略到执行的一站式服务

mysql中关系怎么弄 mysql关系表

如何建立mysql表之间的关系

MySQL创建关联表可以理解为是两个表之间有个外键关系,但这两个表必须满足三个条件

成都创新互联是一家集网站建设,蓬莱企业网站建设,蓬莱品牌网站建设,网站定制,蓬莱网站建设报价,网络营销,网络优化,蓬莱网站推广为一体的创新建站企业,帮助传统企业提升企业形象加强企业竞争力。可充分满足这一群体相比中小企业更为丰富、高端、多元的互联网需求。同时我们时刻保持专业、时尚、前沿,时刻以成就客户成长自我,坚持不断学习、思考、沉淀、净化自己,让我们为更多的企业打造出实用型网站。

1.两个表必须是InnoDB数据引擎

2.使用在外键关系的域必须为索引型(Index)

3.使用在外键关系的域必须与数据类型相似

下面分别建两个表来说明一下:

Create

TABLE

IF

NOT

EXISTS

`books`

`book_id`

smallint(6)

NOT

NULL

auto_increment

COMMENT

‘书籍编号',

`book_name`

char(20)

NOT

NULL

COMMENT

’书名‘,

mysql数据表之间如何建立关系

你分别给“评论表”(表A)和“文章表”(表B)建立了一个主键,数据表是存储多条记录,而主键是区分记录的唯一性的,你将 表A 的主键id放到 表B 中作为外键(aid),你就已经将两表通过 B表(aid) 建立了一种关系,就好像母子两人,因为有血缘关系,就可以知道一人是另一个人的母亲,两个表有关系了就可以互相知道了;

B表里有了aid必须是A表中存在的,就像儿子肯定有母亲的,所有一文章记录有评论(aid),那aid就能在A表中找到,找到的这条评论就是这篇文章的评论;

因为文章和评论是一对多的关系,像LZ那样文章表冗余就会比较多;个人觉得将文章的主键作为评论表的外键比较好;

怎样在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中关系怎么弄 mysql关系表
网页网址:http://cdkjz.cn/article/ddsgohi.html
多年建站经验

多一份参考,总有益处

联系快上网,免费获得专属《策划方案》及报价

咨询相关问题或预约面谈,可以通过以下方式与我们联系

大客户专线   成都:13518219792   座机:028-86922220