tangdesign 发表于 2009-2-19 08:26:59

全面接触SQL语法(3)

  指定一特定的分组记录,并满足HAVING 所指定的条件或状态,但条件是针对分组的条件设置。
  
  SELECT fieldlist
  FROM table
  WHERE selectcriteria
  GROUP BY groupfieldlist
  HAVING groupcriteria
  fieldlist
  显示被查询的字段名称。(可与ALL,DISTINCT,DISTINCTROW,或TOP相结合)
  table
  欲查询数据的表格名称。
  selectcriteria
  选取标准。
  groupfieldlist
  分组记录的字段名称,到多10个字段。而这些字段的顺序决定最高到最低的分组阶层。
  groupcriteria
  决定什么样的分组记录要被显示。
  HAVING跟WHERE 的用法相当类似,不同之处在于HAVING必须用于GROUP之后的分组数据上。
  例如:
  SELECT 分类编,Sum(库存数量)
  FROM 产品表格
  GROUP BY 分类编号
  HAVING Sum(库存数量)>100 AND 产品名称 LIKE "*纸";
  
  GROUP BY 条件子句
  
    依据指定的字段,将具有相同数值的记录合并成一条。
  
  SELECT fieldlist
  FROM table
  WHERE criteria
  GROUP BY groupfieldlist
  fieldlist
  欲读取的字段名称。(可与ALL,DISTINCT,DISTINCTROW,或TOP合并使用)
  table
  被查询的表格名称。
  groupfieldlist
  分组记录的字段名称,到多10个字段,而这些字段的顺序决定最高到最低的分组层次。
  例如:
  SELECT 姓名,Count(姓名)AS 职员姓名
  FROM 职员表格
  WHERE 部门名称="业务部"
  GROUP BY 姓名
  
  FROM 条件子句
  
    指定表格名称或是查询,其中包含列在SELECT语句的字段数据。
  
  SELECT fieldlist
  FROM tableexpression
  fieldlist
  表格中的字段名称。(可与ALL,DISTINCT,DISTINCTROW,或TOP相结合)
  tableexpression
  表格名称,或多个表格的算式。
  externaldatabase
  若该表格参考到外部的数据库时,将其完整的路径名称记下。
  例如:
  从职员表格下,查询出所有姓名字段的数据(只有姓名字段被查询,其他则不显示)。
  SELECT 姓名 FROM 职员表格;
  
    WHERE 条件子句
  165;
  
    2、COUNT:计算记录条数
    COUNT(expr)
  expr
  字段名称或表达式。
    例如:
    若是要统计出业务部门的职员人数,并查询出职员的姓名,可以利用下面的程序。
    SELECT Count(姓名) AS 职员姓名
    FROM 职员表格
    WHERE 部门名称="业务部";
  
    3、FIRST与LAST:返回某字段的第一条数据与最后一条数据。
    FIRST(expr)
    LAST(expr)
    expr
    字段名称或表达式。
    例如:
    若是要找出货品数量字段的第一条数据与货品价格字段的最后一条数据时,可以利用下面的查询方式
    SELECT FIRST(货品数量),LAST(货品价格)
    FROM 订单表格
  
    4、MAX,与MIN:返回某字段的最大值与最小值。
  
    用法同FIRST与LAST。
    5、SUM:返回某特定字段或是运算的总和数值。
  
    SUM(expr)
    expr
    字段名称或表达式。
    例如:
    要计算出货品总价,可使用下面的程序。
    SELECT
    Sum(单位价格*货品数量)
    AS 货品总价 FROM 订单表格
    多层SQL查询
    顾名思义,多层的SQL查询的便在于:“在一个SQL语句中可以包含另一个SQL查询语句,形成内部嵌套的查询类型。”
  comparison(sqlstatement)
  expressionIN (sqlstatement)
  EXISTS(sqlstatement)
  comparison
  将表达式与内层查询的结果比较的操作。
  expression
  对内层查询的结果作搜索的表达式。
  sqlstatement
  为SELECT语句构成的SQL查询,必须用()将该语句括起来。
    例如:
    我们先从订单表格当中,查询出所有的单位,再将产品表格中的单位与的一一对比,查询出所有高于订单表格的单位价格的记录。
  ELECT * FROM 产品表格
  
    WHERE 单位价格>ANY (SELECT 单位价格 FROM 订单表格 WHERE 折扣>=.25);
  
  
  
  
   <
页: [1]
查看完整版本: 全面接触SQL语法(3)