1.【列选取】从fruits表中获取f_name和f_price两列,T-SQL语句如下。

SELECT f_name,f_price FROM fruits;

2.【去重】查询fruits表中s_id字段的值,并返回s_id字段值不得重复。

SELECT DISTINCT s_id FROM fruits;

3.【列改名】查询fruits表,为f_name取别名‘名称’,f_price取别名‘价格’,T-SQL语句如下:

SELECT f_name AS ‘名称’,f_price AS ‘价格’

FROM fruits;

4.【查询显示的注释添加】

(1)查询fruits表,对表中的s_id和f_id添加说明信息。

SELECT ‘供应商编号:’,s_id,‘水果编号’,f_id FROM fruits;

(2)查询fruits表中所有水果的名称和价格,并对价格打八折

SELECT f_name,f_price 原价,f_price * 0.8 折扣价 FROM fruits;   --相当于省略了AS

5.EXISTS

查询suppliers表中是否存在s_id=107的供应商,如果存在则查询fruits表中的记录,T-SQL语句如下。

SELECT * FROM fruits

WHERE EXISTS

(SELECT s_name FROM suppliers WHERE s——id =107);

6.多列排序

查询fruits表中的f_name和f_price字段,先按f_name排序,再按f_price排序,T-SQL语句如下。

SELECT f_name,f_price FROM fruits ORDER BY f_name,f_price;

7.***GROUP BY分组

(1)根据s_id对fruits表中的数据进行分组,T-SQL语句如下。

SELECT s_id,COUNT(*) AS Total FROM fruits GROUP BY s_id;

(2)根据s_id和f_name字段对fruits表中的数据进行分组,T-SQL语句如下。

SELECT s_id,f_name FROM fruits group by s_id,f_name;

8.HAVING对分组结果过滤【和GROUP BY联合使用】

根据s_id对fruits表中的数据进行分组,并显示水果种类大于1的分组信息,语句如下:

SELECT s_id,COUNT(*) AS Total FROM fruits

GROUP BY s_id HAVING COUNT(*)>1;

9.使用COMPUTE子句对查询结果小计

GROUP BY子句返回的结果集中只有合计数据,而没有原始的详细记录,但是COMPUTE可以显示详细的记录、

使用COMPUTE子句产生fruits表中f_price字段的总和,要求将查询结果按s_id字段进行排序之后,再返回f_price字段的总和。

USE test

SELECT s_id,f_price,f_name

FROM fruits

ORDER BY s_id

COMPUTE SUM(f_price);

10.使用COMPUTE BY子句分组小计

11.使用UNION合并查询结果集

查询所有价格小于9的水果的信息,查询s_id等于101的所有水果的信息,使用UNION ALL连接查询结果,语句如下。

SELECT s_id,f_name,f_price

FROM fruits

WHERE f_price <9.0

UNION ALL

SELECT s_id,f_name,f_price

FROM fruits

WHERE s_id = 101;

12.****使用COUNT()统计

(1)COUNT(*):计算表中总的行数,不管某列有数值或者为空值;

(2)COUNT(字段名):计算指定列下总的行数,计算时将忽略字段值为空值的行。

SQL从零到迅速精通【查询利器】的更多相关文章

  1. SQL从零到迅速精通【表连接查询】

    看了这些表连接,个人感觉'左外连接'.'右外连接'和'全外连接'应用好就可以了. 1.外连接 (1)LEFT JOIN(左连接):返回包括左表中的所有记录和右表中连接字段相等的记录. 在student ...

  2. SQL从零到迅速精通【触发器】

    essay from:http://www.cnblogs.com/hoojo/archive/2011/07/20/2111316.html 触发器就类似一个小账本,记录了你在数据库做了哪些操作,可 ...

  3. SQL从零到迅速精通【实用函数(3)】

    1.LOWER()函数 使用LOWER函数将字符串中所有字幕字符转换为小写,输入语句如下. SELECT LOWER('BEAUTIFUL'),LOWER('Well'); 2.UPPER()函数 S ...

  4. SQL从零到迅速精通【实用函数(1)】

    语法是一个编程语言的基础,真的想玩的6得飞起还是要靠自己定义的函数和变量. 1.使用DECLARE语句创建int数据类型的名为@mycounter的局部变量,输入语句如下: DECLARE @myco ...

  5. SQL从零到迅速精通【数据更新】

    1.[导入表]在两个表的格式一样的情况下,将一个表的数据导入另外一个表. person_old表中现在有两条记录.接下来将person_old表中所有的记录插入到person表中,语句如下: INSE ...

  6. SQL从零到迅速精通【实用函数(2)】

    1.对查询结果进行排序 查询stu_info表中所有学生信息,并按照成绩由高到底进行排序,输入语句如下. SELECT * FROM stu_info ORDER BY s_score DESC;   ...

  7. SQL从零到迅速精通【数据库应用】

    数据库理论的研究主要集中于关系规范化理论和关系数据理论等.数据库技术与计算机技术的结合使得数据库中新的技术层出不穷.最初的数据库系统主要应用于银行管理.飞机订票等事务处理环境.后来渐渐应用于工程设计与 ...

  8. SQL从零到迅速精通【规则和约束】

    1.[创建规则] 为stu_info表定义一个规则,指定其成绩列的值必须大于0,小于100,输入语句如下. USE test_db; GO CREATE RULE rule_score AS @sco ...

  9. SQL从零到迅速精通【基本语句】

    1.使用T-SQL语句创建数据表authors,输入语句如下. CREATE TABLE authors { auth_id int PRIMARY KEY,--数据表主键 auth_name VAR ...

随机推荐

  1. HTML Flex 布局

    感谢原文作者:在路上de 小白 原文链接:https://www.cnblogs.com/likun123/p/9518466.html#commentform 目录 一.Flex 布局是什么? 二. ...

  2. VC中如何将资源打包并释放到指定文件夹

    转载请注明来源:https://www.cnblogs.com/hookjc/ 很多时候,我们可能要将某些文件打包到资源中,然后当程序执行的时候,发现缺少某些文件时,进行自我修复,以维持程序的正常执行 ...

  3. 类扩展(Class Extension)

    类扩展(Class Extension) 也有人称为匿名分类 - 作用     - 能为某个类增加额外的属性.成员变量.方法声明     - 一般将类扩展写到.m文件中     - 一般将一些私有的属 ...

  4. 区段统计 mysql 语句 case when then end as

    EXPLAIN SELECT COUNT(*),CASEWHEN device_width > 729 THEN '>729'WHEN device_width BETWEEN '720' ...

  5. play的action链(一个action跳转到另一个action,类似于重定向)

    在play中没有Servlet API forward 的等价物.每一个HTTP request只能调用一个action.如果我们需要调用另一个,必须通过重定向,让浏览器访问另一个URL来访问它.这样 ...

  6. 申请免费的ssl通配符证书

    吐曹: 为了给我网站配置免费的htpps证书费死劲了, 折腾了一天, 找阿里阿里给我反馈的和我自己看的一样, 没什么用 我用Certbot生成证书以后怎么访问都是阿里的免费的hppts证书, 我都把阿 ...

  7. 7、架构--location、LNMP架构、uwsgi部署、BBS项目部署

    笔记 1.晨考 1.Nginx中常用的模块 autoindex stub_status allow 和 deny basic limit_conn limit_req 2.配置步骤 1.创建连接池 2 ...

  8. weblogic12c安装笔记

    weblogic12c安装笔记 1.创建wls用户 useradd wls 2.切换到wls用户 su - wls 3.在/home/wls/创建files.jdk1.8.patch.bao目录 mk ...

  9. 使用 Spring Cloud Jaeger 进行分布式跟踪

    在本文中,学习如何实现 Jaeger(基于 OpenTracing 和 Spring Boot 应用程序)以及如何使用 Jaeger UI 可视化跟踪. 介绍 在本文中,我们将探讨如何使用 Jaege ...

  10. 如何深入学习Java并发编程?

    在讲解深入学习Java并发编程的方法之前,先分析如下若干错误的观点和学习方法. 错误观点1:学习Java编程主要是学习多线程. 这话其实是说明了表面现象,多线程其实还真是并发编程的实现方式,但在实际高 ...