sql必知必会学习记录(十二)- 联结表

sql必知必会学习记录(十二)- 联结表

  1. 联结
  • 等值联结(内部联结)
SELECT
	vend_name,
	prod_name,
	prod_price
FROM
	vendors,
	products
WHERE
	vendors.vend_id = products.vend_id
ORDER BY
	vend_name,
	prod_name

笛卡儿积(cartesian product):由没有联结条件的表关系返回的结果为笛卡儿积。检索出的行的数目将是第一个表中的行数乘以第二个表中的行数。又称为叉联结。

  • 内部联结
SELECT
	vend_name,
	prod_name,
	prod_price
FROM
	vendors
INNER JOIN products ON vendors.vend_id = products.vend_id

SQL规范首选INNER JOIN语法。

  • 联结多个表
SELECT
	prod_name,
	vend_name,
	prod_price,
	quantity
FROM
	orderitems,
	products,
	vendors
WHERE
	products.vend_id = vendors.vend_id
AND orderitems.prod_id = products.prod_id
AND order_num = 20005

性能考虑 MySQL在运行时关联指定的每个表以处理联结。这种处理可能是非常耗费资源的,因此应该仔细,不要联结不必要的表。联结的表越多,性能下降越厉害。

  1. 创建高级联结
  • 自联结
//使用子查询来完成查询
SELECT prod_id,prod_name FROM products WHERE vend_id=(SELECT vend_id FROM products WHERE prod_id='DTNTR');
//使用自联结查询
SELECT p1. prod_id, pl. prod_name FROM products AS p1, products AS p2 WHERE p1. vend_id=p2. vend_id AND p2. prod_id=' DTNTR';

用自联结而不用子查询.自联结通常作为外部语句用来替代从相同表中检索数据时使用的子查询语句.虽然最终的结果是相同的,但有时候处理联结远比处理子查询快得多.应该试一下两种方法,以确定哪一种的性能更好.

  • 使用表别名
SELECT
	CONCAT(
		RTRIM(vend_name),
		' (',
		RTRIM(vend_country),
		')'
	) AS vend_title
FROM
	vendors
ORDER BY
	vend_name;
  • 使用不同类型的联结

    内联结

SELECT
	customers.cust_id,
	orders.order_num
FROM
	customers
INNER JOIN orders ON customers.cust_id = orders.cust_id

外联结

SELECT
	customers.cust_id,
	orders.order_num
FROM
	customers
LEFT OUTER JOIN orders ON customers.cust_id = orders.cust_id

上面这条条SELECT语句使用了关键字OUTER JOIN来指定联结的类型(而不是在WHERE子句中指定)。但是,与内部联结关联两个表中的行不同的是,外部联结还包括没有关联行的行。在使用OUTER JOIN语法时,必须使用RIGHT或LEFT关键字指定包括其所有行的表(RIGHT指出的是OUTER JOIN右边的表,而LEFT指出的是OUTER JOIN左边的表)。上面的例子使用LEFT OUTER JOIN从FROM子句的左边表(customers表)中选择所有行。为了从右边的表中选择所有行,应该使用RIGHT OUTER JOIN。

外部联结的类型存在两种基本的外部联结形式:左外部联结和右外部联结。它们之间的唯一差别是所关联的表的顺序不同。换句话说,左外部联结可通过颠倒FROM或WHERE子句中表的顺序转换为右外部联结。因此,两种类型的外部联结可互换使用,而究竟使用哪一种纯粹是根据方便而定。

带聚集函数的联结


SELECT
	customers.cust_name,
	customers.cust_id,
	COUNT(orders.order_num) AS num_ord
FROM
	customers
INNER JOIN orders ON customers.cust_id = orders.cust_id
GROUP BY
	customers.cust_id;
	
	
SELECT
	customers.cust_name,
	customers.cust_id,
	COUNT(orders.order_num) AS num_ord
FROM
	customers
LEFT OUTER JOIN orders ON customers.cust_id = orders.cust_id
GROUP BY
	customers.cust_id
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值