xxx,xxx
from
表1,表2
where
表1.xxx=表2.xxx,我们一般都是进行的是这般的 *** 作,其实mysql中还有一种 *** 作,那就是join的 *** 作,例如底下有两个表:
请看
"Persons"
表:
接下来请看
"Orders"
表:
以上的这两个表,然后我们把它们进行连接查询
SELECT
Persons.LastName,
Persons.FirstName,
Orders.OrderNo
FROM
Persons,
Orders
WHERE
Persons.Id_P
=
Orders.Id_P
结果集:
如果使用关键词JOIN来从两个表中获取数据
SELECT
Persons.LastName,
Persons.FirstName,
Orders.OrderNo
FROM
Persons
INNER
JOIN
Orders
ON
Persons.Id_P
=
Orders.Id_P
ORDER
BY
Persons.LastName
结果集:
则inner
join
与上面的普通查询没有区别
不同的
SQL
JOIN
JOIN:
如果表中有至少一个匹配,则返回行
LEFT
JOIN:
即使右表中没有匹配,也从左表返回所有的行
RIGHT
JOIN:
即使左表中没有匹配,也从右表返回所有的行
FULL
JOIN:
只要其中一个表中存在匹配,就返回行
LEFT
JOIN
关键字语法
"Persons"
表:
"Orders"
表:
SELECT
Persons.LastName,
Persons.FirstName,
Orders.OrderNo
FROM
Persons
LEFT
JOIN
Orders
ON
Persons.Id_P=Orders.Id_P
ORDER
BY
Persons.LastName
结果集:
SQL
RIGHT
JOIN
关键字
"Persons"
表:
"Orders"
表:
SELECT
Persons.LastName,
Persons.FirstName,
Orders.OrderNo
FROM
Persons
RIGHT
JOIN
Orders
ON
Persons.Id_P=Orders.Id_P
ORDER
BY
Persons.LastName
结果集:
SQL
FULL
JOIN
关键字
"Persons"
表:
"Orders"
表:
全连接(FULL
JOIN)实例
SELECT
Persons.LastName,
Persons.FirstName,
Orders.OrderNo
FROM
Persons
FULL
JOIN
Orders
ON
Persons.Id_P=Orders.Id_P
ORDER
BY
Persons.LastName
结果集:
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对脚本之家的支持。如果你想了解更多相关内容请查看下面相关链接
您可能感兴趣的文章:浅谈mysql的子查询联合与in的效率详解Mysql多表联合查询效率分析及优化对MySQL几种联合查询的通俗解释Mysql联合查询UNION和UNION
ALL的使用介绍Mysql联合查询UNION和Order
by同时使用报错问题的解决办法mysql多表联合查询返回一张表的内容实现代码mysql使用from与join两表查询的区别总结Mysql查询正在执行的事务以及等待锁的 *** 作方式MySQL查询中LIMIT的大offset导致性能低下浅析Mysql如何查询某条记录在分页的第几页详析
select * from 表1 inner join 表2 on 关联条件
select * from 表1 left outer join 表2 on 关联条件
select * from 表1 right outer join 表2 on 关联条件
select * from 表1 cross join 表2 on 关联条件
MYSQL查询
查询平均成绩大于70分的同学的学号和平均成绩
SELECT s.id,AVG(sc.score) FROM student s,studentcourse sc WHERE s.id=sc.student_id GROUP BY s.id HAVING AVG(sc.score)>70
查询所有同学的学号、姓名、选课数、总成绩
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
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)