重庆分公司,新征程启航

为企业提供网站建设、域名注册、服务器等服务

mysql怎么关系表 mysql表之间怎么关联

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

1.建立用户信息表

创新互联自2013年创立以来,是专业互联网技术服务公司,拥有项目成都网站设计、做网站网站策划,项目实施与项目整合能力。我们以让每一个梦想脱颖而出为使命,1280元城中做网站,已为上家服务,为城中各地企业和个人服务,联系电话:18982081108

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创建关联表可以理解为是两个表之间有个外键关系,但这两个表必须满足三个条件

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 数据库表间关系图怎么查看?

mysql数据库表间的关系图可以通过navicat查看:

第一步:下载navicat打开;

第二步:点击navicat界面最右下角标注的按钮即可查看关系图。

最新的MySQL Workbench已经完全包含了数据库建模与设计、数据库SQL开发和数据库管理与维护等功能。

Mysql数据库-----表

sh.qihoo.com 2018-04-07 08:20

1、定义: 表(table)是数据库最基本的组成单元,数据库是用来存储数据的,数据库中有很多表,每一个表都是一个独立的单元,表也是一个结构化的文件,由行和列组成,行称为数据或记录,列称为字段,字段又包含:字段名称、字段类型、长度、约束。

2、创建表

(1)、语法格式:create table 表名称(字段名 类型(长度) 约束);

(2)、MySQL常用数据类型

VARCHAR:可变长度字符串(VARCH AR(3)表示存储的数据长度丌能超过3个字符长度)

CHAR:定长字符串(CHAR(3) 表示存储的数据长度丌能超过3个字符长度)

INT:整数型(INT(3)表示最大可以存储999)

BIGINT:长整型(对应java程序中的long类型)

FLOAT:浮点型单精度(FLOAT(7,2)表示7个有效数字,2个有效小数位)

DOUBLE:浮点型双精度(DOUBLE(7,2)表示7个有效数字,2个有效小数位)

DATE:日期类型( 实际开发中,常用字符串代替日期类型)

BLOB:二进制大对象 Binary Large Object(专门存储图片、视频、声音等数据)

CLOB:字符型大对象 Character Large Object( 可存储超大文本,可存储4G+字符串)

VARCHAR与CHAR对比:

都是字符串

VARCHAR比较智能,可以根据实际的数据长度分配空间,比较节省空间;但在分配的时候需要相关判断,效率低。

CHAR不需要劢态分配空间,所以执行效率高,但是可能会导致空间浪费

若字段中的数据不具备伸缩性,建议采用CHAR类型存储

若字段中的数据具备很强的伸缩性,建议采用VARCHAR类型存储


当前文章:mysql怎么关系表 mysql表之间怎么关联
文章网址:http://cqcxhl.com/article/doshcdh.html

其他资讯

在线咨询
服务热线
服务热线:028-86922220
TOP