189 8069 5689

mysql怎么创建关系表 sql数据库怎么创建表

怎样在mysql中设计好友关系库表

1.建立用户信息表

创新互联公司是一家专业提供友谊企业网站建设,专注与网站建设、成都做网站、H5场景定制、小程序制作等业务。10年已为友谊众多企业、政府机构等服务。创新互联专业网络公司优惠进行中。

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中建立两个表之间的关系?

2张表,一张用户表,一张好友表。好友表里面放用户表的ID就行了。

如何在mysql 中建立有关联关系的表

主键:唯一标识一条记录,不能有重复。作用:用来保证数据的完整性。 外键:表的外键是另一表的主键。可以是重复的,可以是空值,用来和其他表建立联系,一个表可以有多个外键。

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

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

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

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

mysql workbench怎么数据表的关系图

打开MySQL Workbench,并连接数据库。图中显示连接数据库对话框

成功连接后,点击如图所示红色按钮,“create new Schema”,填写数据库名称如“new_schema”,点击“应用”,如图

在弹出的的确认对话框中点击“应用”,如图

OK,成功创建,如图

如图操作,我们开始创建表

需要填写表名(new_table),列名”id、date“和选择列的类型,以及列属性(主键),点击”应用“

如图所示,成功创建表,点击右键,选择“select rows”可以编辑表内容

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 ’书名‘,

`book_pic` varchar(200) NOT NULL COMMENT ’封面‘,

`book_author` char(20) NOT NULL COMMENT ’作者‘,

`book_pub` char(40) NOT NULL COMMENT ’出版社‘,

`book_sort` char(6) NOT NULL COMMENT ’分类‘,

`book_owner` char(6) default NULL COMMENT ’所有者‘,

`book_borrower` char(7) default NULL COMMENT ’借阅者‘,

`book_borrower_time` date default NULL COMMENT ’借阅时间‘,

PRIMARY KEY (`book_id`),

INDEX (book_borrower))

ENGINE=InnoDB CHARACTER SET utf8 COLLATE utf8_general_ci AUTO_INCREMENT=5 ;

Create TABLE IF NOT EXISTS `parts` (

`part_id` smallint(6) NOT NULL COMMENT ’成员编号‘,

`part_name` varchar(6) NOT NULL COMMENT ’成员名‘,

`part_mail` varchar(50) NOT NULL COMMENT ’邮箱‘,

`part_pass` varchar(20) NOT NULL COMMENT ’密码‘,

PRIMARY KEY (`part_id`),

FOREIGN KEY(part_name) REFERENCES books(book_borrower) on delete cascade on update cascade)

分析一下books表和parts表,创建他们的关联,我用了books表的book_borrower字段 创建表时索引并选择InnoDB为表引擎。而parts表即part_name字段为外键,关联到books表的book_borrower字段。注意两 个字段分别是char和varchar都是字符串类型。on delete cascade意思为当books表有相关记录删除时,那parts表也会跟着删除相关联的记录。


本文名称:mysql怎么创建关系表 sql数据库怎么创建表
文章出自:http://cdxtjz.cn/article/hppgoe.html

其他资讯