博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
SQL Server 查询语句(一)
阅读量:6260 次
发布时间:2019-06-22

本文共 1959 字,大约阅读时间需要 6 分钟。

一、查询语句格式

    SELECT [ALL|DISTINCT] [表名.]{*|列名|表达式[AS 新列名]}

    [INTO :主变量[,:主变量]…]

    FROM 表名[表别名],

    [WHERE 条件表达式|子查询]

    [GROUP BY 列名, …

     [HAVING 分组表达式]]

    [{UNION|INTERSECT |EXCEPT}SELECT…FROM…]

    [ORDER BY 列名|列序号[ASC|DESC], …]

二、单表查询

 

    Where 子句——运算符 

    比较:<<=>>==<>not + ~

    确定范围:

       Between A and BNot Between A and B

    确定集合INNOT IN

    字符匹配LIKENOT LIKE

    空值IS NULLIS NOT NULL

    多重条件:ANDORNOT

    1----

    SELECT Sname NAME, 'Year of Birth:' BIRTH,

           2003-sage BIRTHDAY,  LOWER(Sdept) DEPARTMENT

    FROM    Student;  

    2--- 选择表中的行

    消除重复行: DISTINCT    (缺省为ALL)

    SELECT    DISTINCT Sno FROM      student 

    3---  BETWEEN  AND

    求年龄在~ (, 22)之间的学生名及年龄(或不在~之间)

    SELECT Sname, Sage    FROM    Student

    WHERE   Sage BETWEEN 18 AND 22 (WHERE Sage>=18 AND Sage<=22)

    4--- IN or NOT IN

    SELECT    *    FROM     Student

    WHERE    Sdept IN (‘IE’, ‘CS’, ‘MA’)(WHERE Sdept=‘IE’OR Sdept=‘CS’OR Sdept=‘MA’)

 

    5--- Like

    格式:

       [NOT] LIKE ‘匹配串[ESCAPE ‘换码字符]

       %: 表示任意长度()的任意字符

       _: 表示单个的任意字符

       ESCAPE ‘换码字符: 匹配串中换码字符(转义符)之后的字(%,__),被定义为普通字符(不作通配符用)

    列出课程名称中带有_’的课号及课名:

        Select cno cnameFrom Course  Where cname LIKE%"_%escape ‘"’

    求以DATA_BASE’开头且倒数第五个字符为S’的课程名

        SELECT Cname  FROM Course  WHERE Cname LIKE ‘DATA"_BASE%S_ _ _ _’ESCAPE’"’

     6--- NULL

    SELECT   Sno, Cno  FROM  SC WHERE   Grade IS NULL;

 

 

    7--- 分组与组函数

    只有出现在Group By子句中的属性,才可出现在Select子句中

    组函数的使用:

       COUNT([DISTINCT|ALL] *|列名)

       SUM([DISTINCT|ALL] 列名)

       AVG([DISTINCT|ALL] 列名)

       MAX([DISTINCT|ALL] 列名)

       MIN([DISTINCT|ALL] 列名)

    组函数可用于SELECT子句中的目标列表中或在HAVING子句的分组表达式中用作条件。

    对分出的每一组用HAVING进行筛选,筛选条件要用到组函数。

    Having Where的区别:

        Where 决定哪些元组被选择参加运算作用于关系中的元组

        Having 决定哪些分组符合要求作用于分组

   

    例:统计各系学生的人数。

       Select sdeptcount(*) as stu_count

       From Student

       Group By sdept

    求选修了课程的学生人数

       SELECT COUNT(DISTINCT Sno) FROM SC

    例:求选修各门课的人数及平均成绩

       SELECT Cno, COUNT(Sno), AVG(GR) FROM    SC GROUP BY Cno

    例:求选修课程在2门以上且都及格的学生号及总平均分

       SELECT Sno, AVG(Grade) FROM SC GROUP BY Sno HAVING COUNT(Cno)>2 AND MIN(Grade)>=60

    8--- 排序

    用ORDER BY子句对查询结果按照一个或多个列的值进行升/降排列输出,升序为ASC;降序为DESC,空值将作为最大值排序

  

转载于:https://www.cnblogs.com/rainman/archive/2009/04/23/1442153.html

你可能感兴趣的文章
CentOS6.5加域
查看>>
互联网+时代,移动互联网安全怎么自我防范呢?
查看>>
图片上传预览功能
查看>>
org.apache.log4j.Logger 详解
查看>>
Tiny Linux -- tce-load
查看>>
Android 中自定义控件和属性(attr.xml,declare-styleable,TypedArray)的方法和使用
查看>>
vue中get和post请求
查看>>
2015-2016 ACM-ICPC, NEERC, Southern Subregional Contest A Email Aliases(模拟STL vector+map)
查看>>
Mr. Frog’s Game
查看>>
3.4可靠数据传输的原理
查看>>
多媒体通信-3-30-2018
查看>>
【Spring Boot&&Spring Cloud系列】Spring Boot中使用数据库之MySql
查看>>
【Spring Boot && Spring Cloud系列】那些Spring Boot中踩过的坑
查看>>
对XX系统的可用性和易用性改良
查看>>
大数据如何解决人工智能对文本挖掘的挑战
查看>>
updatepanel的属性
查看>>
.net 客户端调用java或.net webservice进行soapheader验证
查看>>
RadViz可视化方法--javascript实现
查看>>
软件工程综合实践的第二次实验报告
查看>>
Git储藏与恢复
查看>>