mysql数据库表之间是怎么关联的请详解

mysql数据库表之间是怎么关联的请详解,第1张

left join

join

主外键是两种对表的约束。

例如:

学生表student(学号(id),姓名(name),性别(sex))

表内有:1,aa,女

课程表subject(课程编号(id),课程名(name))

表内有:1,语文

成绩表grade(成绩编号(id),学号(stu_id),课程号(sub_id),成绩(grade))

表内有:1,1,1,90

成绩表的学号就是学生表的学号相对应,并且为学生表的主键,这样就称成绩表中的学号是学生表的外键,同理,成绩表中的课程号是课程表的外键。

select from  student as s inner join subject as su on sustu_id=sid inner join grade as g on gsub_id=suid where 1

扩展资料:

注意事项

SQL 连接(JOIN) 子句用于把来自两个或多个表的行结合起来,基于这些表之间的共同字段。连接的结果可以在逻辑上看作是由SELECT语句指定的列组成的新表。

左连接与右连接的左右指的是以两张表中的哪一张为基准,它们都是外连接。外连接就好像是为非基准表添加了一行全为空值的万能行,用来与基准表中找不到匹配的行进行匹配。

假设两个没有空值的表进行左连接,左表是基准表,左表的所有行都出现在结果中,右表则可能因为无法与基准表匹配而出现是空值的字段。

不同的 SQL JOIN可以使用的不同的 SQL JOIN 类型:

INNER JOIN:如果表中有至少一个匹配,则返回行

LEFT JOIN:即使右表中没有匹配,也从左表返回所有的行

RIGHT JOIN:即使左表中没有匹配,也从右表返回所有的行

FULL JOIN:只要其中一个表中存在匹配,则返回行(MySQL不支持FULL JOIN)

例如:

mysql> select from access_log;

+-----+---------+-------+------------+

| aid | site_id | count | date       |

+-----+---------+-------+------------+

|   1 |       1 |    45 | 2016-05-10 |

|   2 |       3 |   100 | 2016-05-13 |

|   3 |       1 |   230 | 2016-05-14 |

|   4 |       2 |    10 | 2016-05-14 |

|   5 |       5 |   205 | 2016-05-14 |

|   6 |       4 |    13 | 2016-05-15 |

|   7 |       3 |   220 | 2016-05-15 |

|   8 |       5 |   545 | 2016-05-16 |

|   9 |       3 |   201 | 2016-05-17 |

+-----+---------+-------+------------+

9 rows in set

inner

join是内连接,显示符合连接条件的记录natural

join是自然连接,自动对两个表按照同名的列进行内连接使用自然连接要注意,两个表同名的列不能超过1个。

当代码开发人员只写join的时候,SQL解析器自动将其默认为内关联,既不是左关联也不是右关联。

左关联必须用Left join,右关联必须用right join。

1、打开终端窗口,登录mysql。mysql -uroot -p。

2、SHOW DATABASES;USE testdb;这个时候切换到相应的数据库。

3、SHOW TABLES;INSERT INTO branch VALUES(6, 'BB', NULL, NULL);SELECT FROM branch;比如我们为branch这个表插入数据。

4、SELECT employeeemp_id, employeefirst_name, branchbranch_nameFROM employee JOIN branch ON employeeemp_id = branchmgr_id;这个时候进行一下数据的联合,用JOIN。

看来你还没学到这里,join在sql语句中的用法是做连接,而连接就是基于这些表之间的共同字段,把来自两个或多个表的行结合起来。常见的一般是inner join、left join、right join。直接写join的代表的是inner join(内连接)。具体的就不在这里说了,你在百度上搜sql连接就有很多的博客论坛之类的会详细讲解,望采纳。

以上就是关于mysql数据库表之间是怎么关联的请详解全部的内容,包括:mysql数据库表之间是怎么关联的请详解、数据库中natural join和join有什么区别、oracle数据库sql语句里只有join是左连接还是右连接等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/9449769.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-28
下一篇 2023-04-28

发表评论

登录后才能评论

评论列表(0条)

保存