设为首页 收藏本站
查看: 1114|回复: 0

[经验分享] SQL Server编程必知必会 -- (58-79 点总结)

[复制链接]

尚未签到

发表于 2018-10-22 10:31:15 | 显示全部楼层 |阅读模式
  ------------------------创建高级联结-----------------------
  -- 58.使用表/列别名
  -- 58.1. 对表使用别名
  SELECT cust_name,cust_contact
  FROM customers AS c,orders AS o,orderitems AS oi
  WHERE c.cust_id =o.cust_id
  AND oi.order_num = o.order_num
  AND prod_id ='TNT2'
  --结果:
  cust_name cust_contact
  Coyote Inc.                                        Y Lee
  Yosemite Place                                     Y Sam
  -- 58.2. 对列使用别名
  SELECT cust_name AS c_name,cust_contact AS c_contact
  FROM customers AS c,orders AS o,orderitems AS oi
  WHERE c.cust_id =o.cust_id
  AND oi.order_num = o.order_num
  AND prod_id ='TNT2'
  --结果:
  c_name c_contact
  Coyote Inc.                                        Y Lee
  Yosemite Place                                     Y Sam
  -- 58.3. 正常的表示:
  SELECT cust_name,cust_contact
  FROM customers,orders,orderitems
  WHERE  customers.cust_id = orders.cust_id
  AND orderitems.order_num= orders.order_num
  AND prod_id = 'TNT2'
  -- 59.使用不同类型的联结
  -- 59.1. 自联结: 找到生产ID为DTNTR物品的供应商,然后找出这个供应商生产的其他物品; 自联结有时候要比子查询要快;
  SELECT p1.prod_id,p1.prod_name,p1.vend_id
  FROM products AS p1, products AS p2
  WHERE p1.vend_id = p2.vend_id
  AND p2.prod_id = 'DTNTR'
  -- 59.2. 子查询: 找到生产ID为DTNTR物品的供应商,然后找出这个供应商生产的其他物品
  SELECT prod_id, prod_name,vend_id
  FROM products
  WHERE vend_id = (SELECT vend_id
  FROM products
  WHERE prod_id = 'DTNTR')
  -- 60. 自然联结:排除返回的数据有多次出现的情况,使得每个列只返回一次; 标准的自联结中相同的列可能多次出现;
  SELECT c.*, o.order_num,o.order_date,oi.prod_id,oi.quantity,oi.item_price
  FROM customers AS c, orders AS o, orderitems AS oi
  WHERE c.cust_id = o.cust_id
  AND oi.order_num = o.order_num
  AND prod_id='FB'
  -- 61. 外部联结: 将一个表中的行与另一个表中的行相关联,返回包含没有关联行的那些行;
  --对每个客户下了多少订单进行计数,包括那些至今尚未下订单的客户
  SELECT customers.cust_name,customers.cust_id,orders.order_num
  --RIGHT OUTER JOIN从FROM子句右边的表(orders表)中选择所有行
  --LEFT OUTER JOIN从FROM子句左边的表(customers表)中选择所有行
  FROM customers LEFT OUTER JOIN orders
  ON customers.cust_id = orders.cust_id
  --以前版本的简化使用:
  SELECT customers.cust_name,customers.cust_id,orders.order_num
  FROM customers ,orders
  WHERE customers.cust_id *= orders.cust_id
  --完全外联结,从每个表中检索不相关的行(这些行对另一个表的非选择列具有NULL值)
  SELECT customers.cust_name,customers.cust_id,orders.order_num
  FROM customers FULL OUTER JOIN orders
  ON customers.cust_id = orders.cust_id
  --检索所有客户及其订单
  SELECT customers.cust_name,customers.cust_id,orders.order_num
  FROM customers INNER JOIN orders
  ON customers.cust_id = orders.cust_id
  --列出所有产品以及订购数量,包括没有人订购的产品
  --计算平均销售规模,包括那些至今尚未下订单的客户
  -- 62. 使用带聚集函数的联结:
  -- 检索所有客户及每个客户所下的订单数
  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_name,
  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_name,
  customers.cust_id
  -- 63. 使用联结的注意事项
  -- 一般使用内部联结,但是有外部联结也是有效的。
  -- 保证使用正确的联结条件,否则将返回不正确的数据。
  -- 应该总是提供联结条件,否则会得出笛卡儿积。
  -- 在一个联结中可以包含多个表,甚至对于每个联结可以采用不同的联结类型。
  ------------------------组合查询-----------------------
  --64. 有两种基本情况,需要使用组合查询:
  --1. 在单个查询中从不同的表返回类似结构的数据
  --2. 对单个表执行多个查询,按单个查询返回数据
  --找出价格小于等于5的所有物品的一个列表
  SELECT vend_id,prod_id, prod_price
  FROM products
  WHERE prod_price

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-624862-1-1.html 上篇帖子: SQL读取树型所有下级或所有上级 下篇帖子: vsftpd server 搭建
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表