mysql怎么做连表查询_mysql怎么修改表数据
mysql两表联合查询
两个表需要有共同的字段用来做对应关系,假定表a 的ab字段和表b 的bc字段意义是一样的:
新建两张表:
表a:ab ac ad
表b: bc bd be
(此时这样建表只是为了演示连接SQL语句,当然实际开发中我们不会这样建表,实际开发中这两个表会有自己不同的主键.)
第一段:外连接
外连接可分为:左连接、右连接、完全外连接.
①.、左连接 left join 或 left outer join
SQL语句:select 表a.ab,表a.ac,表a.ad,表b.bc,表b.bd,表b.be from 表a left join 表b on 表a.ab=表b.bd执行结果以ab行为准:
表:ab ac ad bc bd be
其中b表bc第二行的值在ab中没有对应的所以左连无法找出来,同理右连会变成这样:
SQL语句:select 表a.ab,表a.ac,表a.ad,表b.bc,表b.bd,表b.be from 表a left join 表b on 表a.ab=表b.bd执行结果以bd行为准:
左外连接包含left join左表所有行,如果左表中某行在右表没有匹配,则结果中对应行右表的部分全部为0.
注:此时我们不能说结果的行数等于左表数据的行数.当然此处查询结果的行数等于左表数据的行数,因为左右两表此时为一对一关系.
右外连接包含right join右表所有行,如果左表中某行在右表没有匹配,则结果中对应左表的部分全部为0.
注:同样此时我们不能说结果的行数等于右表的行数.当然此处查询结果的行数等于左表数据的行数,因为左右两表此时为一对一关系.
SQL语句:select 表a.ab,表a.ac,表a.ad,表b.bc,表b.bd,表b.be from 表a full join 表b on 表a.ab=表b.bd执行结果:
完全外连接包含full join左右两表中所有的行,如果右表中某行在左表中没有匹配,则结果中对应行右表的部分全部为0,如果左表中某行在右表中没有匹配,则结果中对应行左表的部分全部为0.
第二段:内连接 join 或 inner join
SQL语句:select 表a.ab,表a.ac,表a.ad,表b.bc,表b.bd,表b.be from 表a inner join 表b on 表a.ab=表b.bdinner join 是比较运算符,只返回符合条件的行.
第三段:交叉连接 cross join
①概念:没有 WHERE 子句的交叉联接将产生连接所涉及的表的笛卡尔积.第一个表的行数乘以第二个表的行数等于笛卡尔积结果集的大小.表a: ab
星期一
星期二
星期三
表b: cd
张三
李四
王五
SELECT a.ab,b.cd FROM 表a CROSS JOIN 表b
ab cd
星期一 张三
星期一 李四
星期一 王五
星期二 张三
星期二 李四
星期二 王五
星期三 张三
星期三 李四
星期三 王五
MySQL联表查询的索引使用
执行的语句:
执行时间约 10分钟 ,查看执行计划如下:
给Where条件建立索引,并不一定会使用.
比如:在表 knowledge 的字段 update 上建立索引 idx_time :
结果执行上来看,并没有使用索引 idx_time .
则会使用索引 idx_time
在建立索引的时候,会遇到 Table Metadata Lock 的问题,可以先 show processlist ,找到占用表锁的连接,然后 kill .
如何使MYSQL多表联合查询?
MYSQL查询
查询所有同学的学号、姓名、选课数、总成绩
SELECT id,NAME
FROM student
WHERE id NOT IN (SELECT student_id
FROM studentcourse
WHERE course_id IN (SELECT course.id
FROM teacher,course
WHERE teacher.id=course.teacher_id
AND teacher.name='关羽'));
查询学生信息和平均成绩
SELECT s.id,s.name,s.city,s.age, c.name,sc.score,t.name
FROM student s,studentcourse sc,course c,teacher t
WHERE s.id=sc.student_id AND c.id=sc.course_id AND c.teacher_id=t.id GROUP BY s.id;?
以上就是天笑百科网小编为大家整理的mysql怎么做连表查询相关主题介绍,如果您觉得小编更新的文章只要能对粉丝们有用,就是我们最大的鼓励和动力,不要忘记讲本站分享给您身边的朋友哦!!