mysql 关系_MySQL之关系

关系

多对多的关系,如何通过mysql来表示

站在老师的角度

一个老师可以教多个学生,

一个老师也可以教一个学生。

站在学生的角度

一个学生可以被一个老师教

一个学生也可以被多个老师教

结论:如果站在两边看都是一对多的情况,那么这个关系就是多对多的。

问题:

如果表示a老师教过x学生和y学生,x学生和y学生同时也被b老师教

解决方法

多对多关系,无论是把外键放在哪一张表都不合适,因为可能有多个值

解决方案:建立一个中间的关系表

create table student(

id int primary key auto_increment,

name char(10)

) charset utf8;

create table teacher(

id int primary key auto_increment,

name char(10)

) charset utf8;

create table t_s_r(

id int primary key auto_increment,

t_id int,

s_id int,

foreign key(t_id) references teacher(id),

foreign key(s_id) references student(id)

) charset utf8 ;

insert into teacher values(null,"bgon"),(null,"nike");

insert into student values(null,"老王"),(null,"老李");

# 老王被bgon教过

insert into t_s_r values(null,1,1);

# nike教过老李

insert into t_s_r values(null,2,2);

# nike教过老王

insert into t_s_r values(null,2,1);

# 现在已知老师名称为bgon,请找出他教过的那些学生

mysql> select id from teacher where name="bgon";

+----+

| id |

+----+

| 1 |

+----+

1 row in set (0.00 sec)

mysql> select s_id from t_s_r where t_id=1;

+------+

| s_id |

+------+

| 1 |

+------+

1 row in set (0.00 sec)

mysql> select name from student where id=1;

+--------+

| name |

+--------+

| 老王 |

+--------+

# 子查询

mysql> select name from student where id=(select s_id from t_s_r where t_id=(select id from teacher where name="bgon"));

+--------+

| name |

+--------+

| 老王 |

+--------+

1 row in set (0.00 sec)

# 已知学生名为老李,请查询出哪些老师教过他.

mysql> select id from student where name = "老李";

+----+

| id |

+----+

| 2 |

+----+

1 row in set (0.00 sec)

mysql> select t_id from t_s_r where s_id=2;

+------+

| t_id |

+------+

| 2 |

+------+

1 row in set (0.00 sec)

mysql> select name from teacher where id=2;

+------+

| name |

+------+

| nike |

+------+

1 row in set (0.00 sec)

# 子查询

mysql> select name from teacher where id=(select t_id from t_s_r where s_id=(select id from student where name = "老李"));

+------+

| name |

+------+

| nike |

+------+

1 row in set (0.00 sec)

总结:

如何确认多对多的关系?

站在两个表的角度去想

处理方式,通过在两个表中间建立一个外键表,该外键表分别都关联两表的字段。

联合唯一约束

对于上面的t_s_r表进行改进

# 原表

create table t_s_r(

id int primary key auto_increment,

t_id int,

s_id int,

foreign key(t_id) references teacher(id),

foreign key(s_id) references student(id),

) charset utf8 ;

# 改进方法一(表已创建的情况下):unique key

alter table t_s_r add unique key(t_id,s_id);

# 改进方法二(表没创建的情况下):unique key

create table t_s_r(

id int primary key auto_increment,

t_id int,

s_id int,

foreign key(t_id) references teacher(id),

foreign key(s_id) references student(id),

unique key(t_id,s_id)

) charset utf8 ;

# 联合主键

create table t_s_r(

id int primary key auto_increment,

t_id int,

s_id int,

foreign key(t_id) references teacher(id),

foreign key(s_id) references student(id),

primary key(t_id,s_id)

) charset utf8 ;

对于上面的t_s_r表进行改进------最终版

# 创建学生表

create table student(

id int primary key auto_increment,

name char(10)

) charset utf8;

# 创建教师表

create table teacher(

id int primary key auto_increment,

name char(10)

) charset utf8;

# 创建学生和老师关系表

create table t_s_r(

t_id int,

s_id int,

foreign key(t_id) references teacher(id),

foreign key(s_id) references student(id),

primary key(t_id,s_id)

) charset utf8 ;

insert into teacher values(null,"bgon"),(null,"nike");

insert into student values(null,"老王"),(null,"老李");

# 老王被bgon教过

insert into t_s_r values(null,1,1);

# nike教过老李

insert into t_s_r values(null,2,2);

# nike教过老王

insert into t_s_r values(null,2,1);

# 问题:现在已知老师名称为bgon,请找出他教过的那些学生

mysql> select id from teacher where name="bgon";

+----+

| id |

+----+

| 1 |

+----+

1 row in set (0.00 sec)

mysql> select s_id from t_s_r where t_id=1;

+------+

| s_id |

+------+

| 1 |

+------+

1 row in set (0.00 sec)

mysql> select name from student where id=1;

+--------+

| name |

+--------+

| 老王 |

+--------+

# 整合查询语句:子查询

mysql> select name from student where id=(select s_id from t_s_r where t_id=(select id from teacher where name="bgon"));

+--------+

| name |

+--------+

| 老王 |

+--------+

1 row in set (0.00 sec)

# 问题:已知学生名为老李,请查询出哪些老师教过他.

mysql> select id from student where name = "老李";

+----+

| id |

+----+

| 2 |

+----+

1 row in set (0.00 sec)

mysql> select t_id from t_s_r where s_id=2;

+------+

| t_id |

+------+

| 2 |

+------+

1 row in set (0.00 sec)

mysql> select name from teacher where id=2;

+------+

| name |

+------+

| nike |

+------+

1 row in set (0.00 sec)

# 整合查询语句:子查询

mysql> select name from teacher where id=(select t_id from t_s_r where s_id=(select id from student where name = "老李"));

+------+

| name |

+------+

| nike |

+------+

1 row in set (0.00 sec)

一对一关系

例如:每一个人都有一个身份证。一个身份证只对应一个人

分表:

垂直分表,例如:人物的详细信息,就可以垂直分表

# 全表

create table person(

id int primary key auto_increment,

name char(10),

age int,

height float,

weigth float

)

# 垂直分表:person

create table person(

id int primary key auto_increment,

name char(10),

age int

) charset utf8;

# 垂直分表:person_info

create table person_info(

id int primary key,

height float,

weigth float,

foreign key(id) references person(id)

) charset utf8;

水平分表

数据量很大,使用一个表,查询效率低,使用两个表来存取这些数据

处理一对一关系处理方式:

先确定先后顺序

将先存在的数据作为主表

后存在的作为从表

使两个表的id保持一一对应

方法1:从表的id即是主键又是外键

方法2:从表的id设置为外键,并保证唯一

人物关系表,从客户演变为学生:

# 创建客户表

create table kehu_t(

id int primary key auto_increment,

name char(10),

phone char(11)

)

# 创建学生表

create table student_t(

id int primary key auto_increment,

card_id char(18)

)

为什么要分表:

数据分担在多个表,提高了查询的效率

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/443620.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

mysql账号密码忘_mysql用户名密码忘记了解决方法

今天想用一下实验室服务器的mysql,发现不记得用户名密码了。解决方法如下:1. 保证服务器处于安全的状态,如果可以请拔掉网线...(不过我跳过了这一步,额)2. 修改/etc/my.cnf文件在[mysqld]的段中加入:skip-grant-tables…

copying mysql status_mysql慢查询copying to tmp table

windows server,无论修改my.ini的tmp_table_size,max_heap_table_size到多少,情况都一样。同样的表和查询语句,在本地运行,没出现慢查询。SELECTg.goods_id,g.goods_name,g.shop_price,g.goods_thumb,SUM(og.goods_num…

JDK 7,jdk1.7 安装及配置

1.打开网页:http://www.oracle.com 下载对应平台的合适JDK。 2. 双击下载的exe,如jdk-7u7-windows-i586.exe。 3.进入安装向导: 4.下一步,更改安装路径,选择安装所有组件。 更改为D:\jdk1.7.0_07\ 点击确定 5.下一步,…

c mysql 编译_MySQL编译安装之cmake

mysql版本5.5以上编译安装时需要用到软件cmake,cmake特性是独立于源码编译,编译工作可以在另外一个目录中而非源码目录中进行,mysql版本5.5以上编译安装时需要用到软件cmake,cmake特性是独立于源码编译,编译工作可以在…

vb连接mysql未发现_vb连接MySQL遇到的问题解决方法

1.安装mysql,2.安装MyODBC-standard-3.51.07-win.msi3:vb连接语句是:Public strcnn As StringPublic sql As StringPublic conn A1.安装mysql,2.安装MyODBC-standard-3.51.07-win.msi3:vb连接语句是:Public strcnn As StringPublic sql As StringPublic conn As New ADODB.Conn…

mysql常用内置函数_mysql常见内置函数

在mysql中有许多内置的函数,虽然功能都能在PHP代码中实现,但巧妙的应用mysql内置函数可以大大的简化开发过程,提高效率。在这里我总结一下一些常用的,方便以后查看:mysql字符串函数:concat(String2 [,...])…

mysql里面有没有map类型_MySQL学习(二) 数据类型

MySQL支持多种列类型:数值类型、日期/时间类型和字符串(字符)类型。数值类型数值类型又分为整数型与小数型整数型下面的表显示了需要的每个整数类型的存储和范围创建一张表mysql> CREATE TABLE t_int (int_1 TINYINT,int_2 SMALLINT,int_3 MEDIUMINT,int_4 INT,i…

mysql alter table if_MySQL中的alter table命令的基本使用方法及提速优化

一、基本用法1. 增加列?1alter table tbl_nameadd col_name type例如, 给pet的表增加一列 weight,?1mysql>alter table petadd weightint;2. 删除列?1alter table tbl_namedrop col_name例如, 删除pet表中的weight这一列?1mysql>alter table petdrop weight;3. 改变…

mysql_real_escape_string 报错_addslashes与mysql_real_escape_string的区别

addslashes和mysql_real_escape_string.都是为了使数据安全的插入到数据库中而进行过滤.那么这两个函数到底是有什么区别呢??我们今天来简单的看下..首先.我们还是从PHP手册入手..手册上addslashes转义的字符是单引号()、双引号(")、反斜线(\)与NUL(NULL 字符)。mysql_r…

shell执行perl_【编程技巧(一)】在Perl、Shell和Python中传参与输出帮助文档

社会你明哥,人狠话又多!【小明的碎碎念】与你不见不散!作为一名搞数据的生物狗,咱们是生物狗中代码写得最六的,程序员中生物学得最好的——大家没意见吧,有意见请憋着跟随小明的步伐,让我们开开…

项目开发中的编码规范

1.规范存在的意义: 好的编码规范可以尽可能的减少一个软件的维护成本 , 并且几乎没有任何一个软件,在其整个生命周期中,均由最初的开发人员来维护; 好的编码规范可以改善软件的可读性,可以让开发人员尽快而彻底地理解…

mysql 5.6.36安装图解_2017年12月聚合文章--实战-Mysql5.6.36脚本编译安装及初始化 | 码友网...

概述本文为centos7.3自动化编译安装mysql5.3.6的脚本及后续初始化操作,话不多少,直接上脚本。安装脚本install.py如下:#codingutf-8#!/usr/bin/pythonimport os,commands#定义变量install_dir /data/mysqldata_dir /data/mysql/datapackage…

python之路2.0_Python之路【第二十一篇】:JS基础

1.2 ECMAScript尽管 ECMAScript 是一个重要的标准,但它并不是 JavaScript 唯一的部分,当然,也不是唯一被标准化的部分。实际上,一个完整的 JavaScript 实现是由以下 3 个不同部分组成的:● 核心(ECMAScript)● 文档对象…

solr4 mysql自动更新_(solr系列:五) solr定时实时重建索引和增量更新

将mysql中的数据导入到了solr中之后,如果数据库中的数据有变动,solr中还是第一次导入的旧的数据,那该如何是好呢?该如何实现mysql数据库中的数据定时同步到solr中呢?下面将做详细的介绍。准备工作要做好:1、…

mysql pydev_pydev-python 链接mysql数据库(mac系统)

在mac os上安装MySQLdb,遇到了非常多问题,总结一下:首先。假设用sudo easy_install mysql-python命令安装,基本上不会成功的,原因有两个:一是找不到mysql_config位置,二是如今基本上安装的是64位…

MySQL多个线程同时写数据_多个线程可以同时将数据写入文件吗?

同步声明可以做到这一点。尝试下面的代码,我在类似的情况下使用。package hrblib;import java.io.*;public class FileOp {static int nStatsCount 0;static public String getContents(String sFileName) {try {BufferedReader oReader new BufferedReader(new F…

Java在Linux下创建文件,文件夹,删除,拷贝文件的命令

1.创建,删除文件夹,复制文件夹 mkdir,rmdir如:mkdir -p dir1/dir2 //-p表示递归创建文件夹 cp -r /tmp/a /root/a //拷贝不强制覆盖cp -rf /tmp/a /root/a //拷贝强制覆盖 2.创建,删除文件 vi,touch都可以创建文件。如:vi fileNametouch f…

python 拼多多_拼多多现重大BUG被“薅羊毛”,教你如何用Python简单褥羊毛

import timefrom urllib.parse import parse_qsimport requestsfrom bs4 import BeautifulSoupfrom selenium import webdriverfrom selenium.common.exceptions import *from selenium.webdriver.support.wait import WebDriverWait# 额外抽取的授权模块from utils import aut…

上海交通大学python期末考试样题加解析_上海交通大学python期末考试样题加解析...

一、选择题: 将唯一正确的选项写在题前括号中.每题2分.【】(1) 本课程的目标定位是什么?[A] 学习Python语言[B] 学习计算机的工作原理[C] 学习各种算法[D] 学习用计算机解决问题【】(2) 下列哪个标识符是合法的?[A] var-name [B] !#$% [C] _100 [D] elif【】(3) 执行下列语句…

mysql 安装测试ok_tpcc-mysql安装测试与使用的实例教程

1:下载tpcc-mysql的压缩包,从下面的网站进行下载也可直接从叶总博客直接下载:我这边使用的就是后者。2:安装tpcc-mysql[rootmxqmongodb2 tpccmysql]# gunzip tpcc-mysql-src.tgz[rootmxqmongodb2 tpccmysql]# tar xf tpcc-mysql-s…