重庆分公司,新征程启航
为企业提供网站建设、域名注册、服务器等服务
首先能实现目的的语法是这么写:
创新互联建站作为成都网站建设公司,专注成都网站建设、网站设计,有关成都定制网站方案、改版、费用等问题,行业涉及成都效果图设计等多个领域,已为上千家企业服务,得到了客户的尊重与认可。
select id,name,a_rank
from table_a,(
select a_id,count(*) as a_rank
from table_b
group by a_id
)
where table_a.id = table_b.a_id
order by a_rank;
首先能实现目的的语法是这么写:
select id,name,a_rankfrom table_a,(select a_id,count(*) as a_rankfrom table_bgroup by a_id)where table_a.id = table_b.a_idorder by a_rank;
学生表:stu。选课表:sc。代码如下已测试通过。
select stu.sname,count(sc.cname) as '选修总数目' from stu,sc where stu.sid=sc.sid group by stu.sname order by count(sc.cname) desc limit 0,7
一般来说,我们为了得到更完整的结果,我们需要从两个或更多的表中获取结果,我一般都是用select
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如何查询某条记录在分页的第几页详析