zoukankan      html  css  js  c++  java
  • 数据库SQL Server2012笔记(四)——多表查询、子查询、分页查询、用查询结果创建新表和外连接

    1、多表查询
    1)笛卡尔集:
    • select  *  from  表名1,表名2
    • select  *  from  表名1。表名2  where   表名1.字段名=表名2.字段名
    注:
    • 若有两张表有同样名字的字段,则使用时需带表名(别名)。
    • order  by  置于where 条件之后
    2)自连接:同一张表的连接查询。将一张表视为两张表或多张表。

    eg:显示公司每一个员工名字和他的上级的名字。将emp表看做两张表worker和boss
    • select  worker.ename  雇员,boss.ename  老板   from   emp  worker,emp  boss  where   worker.mgr=boss.empno

    2、子查询(嵌套查询):嵌入在其他sql语句中的select语句。

    1)单行子查询:仅仅返回一行数据的子查询语句。
    2)多行子查询:返回多行数据的子查询。
    3)在from子句中使用子查询。
    说明:
         当在from子句中使用子查询时,该子查询会被作为一个视图(暂时表)来对待,因此也叫做内嵌视图。

    当在from子句中使用查询时。必须给子查询指定别名。


    3、分页查询
    1)top  n:前n条记录。

    • select  top  5  *  from  emp  order  by  hiredate
    • 显示第5个到第9个人的信息(按sal高低)
      • select  top  5   from  emp  where  empno  not  in  (select  top  4  empno  from  emp order  by  sal  desc)  order  by  sal  desc
    • identity(1,1):表示字段自增长,从“1”開始增长。每次加“1”。
      • create  table  test  (testId  int  primary  key  identity(1,1))

    4、用查询结果创建新表
    • select  *  into  还有一个表名  from  表名
    • 删除表中的反复记录
      • select  distinct  *  into  #temo(新表)  from  表名1
      • delete  from  表名1
      • insert  into  表名1  select  *  from  #temp
      • drop  table  #temp

    5、外连接:
    • 左外连接:左边的表的记录所有显示,假设没有匹配的记录,用Null填补。
    • 右外连接:右边的表的记录所有显示。假设没有匹配的记录,用Null填补。


  • 相关阅读:
    微信小程序开发常用方法
    HTML5 video常用属性
    移动端键盘定制
    移动端弹性滑动以及滑动出界解决方案
    vue移动端Ui组件 mint-ui 使用指南
    vue.js的ajax和jsonp请求
    获取用户地理位置
    如何将一个已有的项目托管到github或是码云上?git的配置
    mvvm模式和mvc模式 概述总结对比
    使用Java的BlockingQueue实现生产者-消费者
  • 原文地址:https://www.cnblogs.com/yfceshi/p/7025902.html
Copyright © 2011-2022 走看看