mysql关系怎么建立 mysql如何建立表的关系

怎样在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创建关联表可以理解为是两个表之间有个外键关系mysql关系怎么建立,但这两个表必须满足三个条件
1.两个表必须是InnoDB数据引擎
2.使用在外键关系mysql关系怎么建立的域必须为索引型(Index)
3.使用在外键关系mysql关系怎么建立的域必须与数据类型相似
下面分别建两个表来说明一下mysql关系怎么建立:
Create TABLE IF NOT EXISTS `books` (
`book_id` smallint(6) NOT NULL auto_increment COMMENT ‘书籍编号',
`book_name` char(20) NOT NULL COMMENT ’书名‘,
如何设计mysql 的主从关系MySQL主从关系设置
一,概要
1.这个文档主要实现的是MYSQL主从备份(主机数据库任何修改,备份机器都会有实现)
2.但是有个问题,就是如果对备份机器数据库进行操作,可能会导致连接失败 。
二,准备工作
1.可以是多台主机和从机 , 在这里我只用一台主机和从机为例讲解主从关系配置 。2.主机IP:192.168.0.100(例子)从机IP:192.168.0.101(例子)3.主机和从机的IP地址必须是一个网段的 。
4.MySQL版本:mysql-5.5.15-win32.msi安装路径:D:\MySQL\(例子)5.其他相关软件:
①.MySQL管理客户端:Navicat8forMySQL(Windows) 。
②.编辑工具:Notepad(建议用此编辑工具修改MySQL配置文件,点击此链接进入下载
页面)
三,配置主机【master】(IP:192.168.0.100)
1.在命令行窗口中执行:netstopmysql关闭mysql服务 。
2.在mysql安装路径下找到配置文件my.ini文件(Linux下是文件my.cnf),一般都在MySQL安装目录下 , 本实验中在D:\MySQL\下 。记得先备份以下原来的配置文件 。并用Notepad打开 。然后在文件末尾加入下面的代码:
server-id=1#配一个唯一的ID编号
log-bin=NEW_NAME#指定日志类型
binlog-do-db=bojinv2#设置要进行主从复制的数据库名 , 同时也要在从机
【Slave】上设定(同步多个另起一行输入这行代码)
Binlog-ignore-db=mysql#设置不要进行主从复制的数据库名 , 同时也要在
【Slave】上设定(不同步多个另起一行输入这行代码
即可 。)
3.在系统管理命令窗口输入:netstartmysql按回车启动mysql服务
4.在MySQL5.5CommandLineClient命令窗口(路径:开始菜单》程序》MySQL下),
输入数据库密码:******回车,如下图所示:
然后输入:grantreplicationslaveon*.*toslaveuser@从机IP(例:192.168.1.101)identifiedby'从机数据库密码(例:123456)'回车后如下图所示:
var cpro_psid ="u2572954"; var cpro_pswidth =966; var cpro_psheight =120;
出现这样的提示后,继续输入:flushprivileges;按回车,如下图所示:
出现这样的提示后,继续输入:showmasterstatus;按回车 , 如下图所示:
记住出现的表格中的File列和Position的值 。
5.在系统管理命令窗口输入:netstopmysql按回车关闭mysql服务
6.进入MySQL管理客户端:Navicat8forMySQL(Windows) 。点击菜单栏用户,右侧显示你
刚才创建slaveuser@192.168.1.101的用户 , 选中该用户 。点击编辑用户链接 。弹出窗口 , 再
选择权限,将所有权限都选上保存 , 这样主机就配置好了 。重启一下MySQL服务 。
四,配置从机【slave】(Ip:192.168.1.101)
1.在命令行窗口中执行:netstopmysql关闭mysql服务 。
2.在mysql安装路径下找到配置文件my.ini文件(Linux下是文件my.cnf),一般都
在MySQL安装目录下 , 本实验中在D:\MySQL\下 。记得先备份以下
原来的配置文件 。并用Notepad打开 。然后在文件末尾加入下面的代
码:
server-id=2#配一个唯一的ID编号,不能与主机和其他的从机相同
replicate-do-db=bojinv2#设置要进行主从复制的数据库名,数据库名与主机
相同
replicate-ignore-db=mysql#设置不要进行主从复制的数据库名,数据库名与
主机相同
别忘了保存修改后的文件 。
3.在系统管理命令窗口输入:netstartmysql按回车启动mysql服务
4.在MySQL5.5CommandLineClient命令窗口(路径:开始菜单》程序》MySQL下),
输入数据库密码,按回车成功登录数据库 。5.登录成功后,在该命令窗口输入:
Changemastertomaster_host='主机IP(192.168.1.100)',master_user='
mysql数据表之间如何建立关系你分别给“评论表”(表A)和“文章表”(表B)建立了一个主键,数据表是存储多条记录,而主键是区分记录的唯一性的,你将 表A 的主键id放到 表B 中作为外键(aid) , 你就已经将两表通过 B表(aid) 建立了一种关系,就好像母子两人 , 因为有血缘关系,就可以知道一人是另一个人的母亲,两个表有关系了就可以互相知道了;
B表里有了aid必须是A表中存在的,就像儿子肯定有母亲的,所有一文章记录有评论(aid),那aid就能在A表中找到,找到的这条评论就是这篇文章的评论;
因为文章和评论是一对多的关系 , 像LZ那样文章表冗余就会比较多;个人觉得将文章的主键作为评论表的外键比较好;
【mysql关系怎么建立 mysql如何建立表的关系】mysql关系怎么建立的介绍就聊到这里吧,感谢你花时间阅读本站内容,更多关于mysql如何建立表的关系、mysql关系怎么建立的信息别忘了在本站进行查找喔 。

    推荐阅读