一、数据库查询语句(单表查询篇)
创始人
2024-02-06 05:17:14
0

一、数据库查询语句(单表查询篇)

单表查询:SELECT 语句仅从一个表/视图中检索数据,称单表查询。即其中的<普通表> 使用的是[<模式名>.]<基表名|视图名>。


该查询的语句所依赖的表是创建数据库实例默认勾选的两个实例:BOOKSHOP和DMHR

有关数据库实例安装的信息:

http://t.csdn.cn/aODlJ

1、简单查询

1.1 *和DINSTINCT

简介:为了方便用户提高工作效率,SQL 语言允许用户将 SELECT 后的<值表达式>省略为* ; *表示为全部列.

DISTINCT 保证重复的行将从结果中去除。若允许有重复的元组,改用 ALL 来 替换 DISTINCT,或直接去掉 DISTINCT 即可。

  • 代码:

    #只要查询的表指定模式即可,其余列可以指定也可以不指定
    #1.查询production模式下的product表,名字列、作者列的信息
    select PRODUCT.NAME,PRODUCT.AUTHOR from PRODUCTION.PRODUCT;#2.查询production模式下的product表,名字列的信息
    select NAME from PRODUCTION.PRODUCT;/***/
    #3.查询production模式下的product表,所有列的信息
    select * FROM PRODUCTION.PRODUCT;-- 1.2查询结果去重(去除重复的数据)
    select DISTINCT NAME from PRODUCTION.PRODUCT;
    
  • 效果图:在这里插入图片描述


1.2 MINUS、EXCEPT

简介:取左边部分,不包含交集

  • 代码:

    -- 1.3使用minus、except查询tt表中有的,kk表中没有的数据
    create TABLE other.tt(num int);
    create TABLE other.kk(num int);
    insert into other.tt VALUES(1);
    insert into other.tt VALUES(2);
    insert into other.tt VALUES(3);
    insert into other.kk VALUES(2);
    insert into other.kk VALUES(3);
    insert into other.kk VALUES(4);select * FROM other.tt EXCEPT select * FROM other.kk;
    select * FROM other.tt MINUS select * FROM other.kk;
    
  • 效果图:在这里插入图片描述


1.3 INTERSECT

简介:取交集

  • 代码:

    -- 1.4使用intersect查看tt表和kk表中都有的数据
    select * FROM other.tt INTERSECT select * FROM other.kk;
    
  • 效果图:在这里插入图片描述


2、带条件查询

简介:带条件查询是指在指定表中查询出满足条件的元组,通过where子句和查询条件的为此和逻辑运算符组成 。

  • 逻辑运算符有:AND,OR,NOT。
  • 谓词包括比较谓词(=、>、<、>=、<=、<>),BETWEEN 谓词、IN 谓词、LIKE谓词、NULL 谓词、EXISTS 谓词

2.1 常用的逻辑运算符和谓词

简介:AND,OR,NOT,IN,NULL怎么使用

  • 代码:

    -- 2.1给出当前销售价格在 10~20 元之间的所有图书的名字、作者、出版社和当前价格
    select name,author,publisher,nowprice from PRODUCTION.PRODUCT where nowprice >= 10 AND nowprice <=20;
    select name,author,publisher,nowprice from PRODUCTION.PRODUCT where nowprice between 10 AND 20;-- 2.2查询出版社为中华书局或人民文学出版社出版的图书名称与作者信息
    SELECT PRODUCT.NAME,PRODUCT.AUTHOR FROM PRODUCTION.PRODUCT WHERE PRODUCT.PUBLISHER IN ('中华书局','人民文学出版社');-- 2.3查询出版社不是中华书局或人民文学出版社出版的图书名称与作者信息
    SELECT PRODUCT.NAME,PRODUCT.AUTHOR FROM PRODUCTION.PRODUCT WHERE PRODUCT.PUBLISHER NOT IN ('中华书局','人民文学出版社');-- 2.6查询哪些人员的 EMAIL 地址为 NULL
    -- 使用 NULL 谓词的查询,空是使用is null/is not null不是使用等于号(=)select * from PERSON.PERSON WHERE email is null;
    
  • 效果图:在这里插入图片描述


2.2 模糊查询和转义字符

简介:LIKE 谓词一般用来进行字符串的匹配,下划线(_)表示单个字符匹配,百分号(%)表示任意字符匹配, 模糊查询和转义符,如果我们的查询里面由%和但是不是表示模糊查询的呢?

  • 代码:

    -- 2.4查询第一通讯地址中第四个字开始为“关山”且以 202结尾的地址
    -- 模糊查询like,下划线(_)表示单个字符匹配,百分号(%)表示任意字符匹配-- 3个下划线,百分号202
    select * from PERSON.ADDRESS where ADDRESS.ADDRESS1 like '___关山%202';-- 模糊查询和转义符,如果我们的查询里面由%和_但是不是表示模糊查询的呢?
    -- 查询person表中以 iu_520 结尾的地址,则 LIKE 谓词应为:此时这里的下划线不是代表模糊查询的匹配字符
    create TABLE OTHER.person(id int,name varchar(32));
    insert into OTHER.person VALUES(1,'江西省新余市渝水区城北大道iu_520');
    insert into OTHER.person VALUES(2,'广东省佛山市城北大道iu_520');
    commit;select * from other.PERSON where name like '%iu*_520' escape '*';
    
  • 效果图:在这里插入图片描述


2.5 .ROW

简介:LIKE 谓词除支持使用列的计算外,还支持通过 ROW 保留字对表或视图进行 LIKE 计算。 该查询依次对表或视图中所有字符类型的列进行 LIKE 计算,只要有一列符合条件,则返回 TRUE

  • 代码:

    -- 2.5查询出版社与中华有关的书籍信息
    -- 使用.ROW 进行 LIKE 谓词的查询
    select * from PRODUCTION.PRODUCT WHERE product.ROW like '%中华%';
    
  • 效果图:在这里插入图片描述


2.7 组合逻辑

简介:可以用逻辑算符(AND,OR,NOT)与各种谓词相组合生成较复杂的条件查询

  • 代码:

     --2.7查询当前销售价格低于 15 元且折扣低于 7 或出版社为人民文学出版社的图书名称和作者--可以用逻辑算符(AND,OR,NOT)与各种谓词相组合生成较复杂的条件查询select name,author from PRODUCTION.PRODUCT where nowprice < 15 and discount < 7 or publisher = '人民文学出版社';
    
  • 效果图:在这里插入图片描述


3、集函数

简介:为了进一步方便用户的使用,增强查询能力,SQL 语言提供了多种内部集函数。集函数又称库函数,当根据某一限制条件从表中导出一组行集时,使用集函数可对该行集作统计操作,集函数可分为 10 类:

  1. COUNT(*);
  2. 相异集函数 AVG|MAX|MIN|SUM|COUNT(DISTINCT<列名>);
  3. 完全集函数 AVG|MAX|MIN| COUNT|SUM([ALL]<值表达式>);
  4. 方差集函数 VAR_POP、VAR_SAMP、VARIANCE、STDDEV_POP、STDDEV_SAMP、STDDEV;
  5. 协方差函数 COVAR_POP、COVAR_SAMP、CORR;
  6. 首行函数 FIRST_VALUE;
  7. 求区间范围内最大值集函数 AREA_MAX;
  8. FIRST/LAST 集函数 AVG|MAX|MIN| COUNT|SUM([ALL] <值表达式>) KEEP(DENSE_RANK FIRST|LAST ORDER BY 子句);ORDER BY 子句语法参考第 4.7 节;
  9. 字符串集函数 LISTAGG/LISTAGG2;
  10. 求中位数函数 MEDIAN。

集函数只能单独使用,只能返回一列,除非和group by使用

例子:

  • 代码:

     -- 3.1查询折扣小于 7 的图书中现价最低的价格SELECT MIN(nowprice) FROM PRODUCTION.PRODUCT;-- 3.1错误示例,只能单独使用或者和group by联合使用SELECT name,MIN(nowprice) FROM PRODUCTION.PRODUCT;-- 3.2求折扣小于 7 的图书的平均现价SELECT AVG(nowprice) FROM PRODUCTION.PRODUCT WHERE DISCOUNT < 7;-- 3.3求折扣大于 8 的图书的总价格SELECT SUM(nowprice) FROM PRODUCTION.PRODUCT WHERE DISCOUNT > 8;-- 3.4查询图书的个数SELECT COUNT(*) FROM PRODUCTION.PRODUCT;SELECT DISTINCT COUNT(*) FROM PRODUCTION.PRODUCT;-- 3.5求图书的现价方差SELECT VARIANCE(NOWPRICE) FROM PRODUCTION.PRODUCT;-- 3.6求图书的现价标准差SELECT STDDEV(NOWPRICE) FROM PRODUCTION.PRODUCT;-- 3.7求图书的现价样本标准差SELECT STDDEV_SAMP(NOWPRICE) FROM PRODUCTION.PRODUCT;-- 3.8求产品原始价格 ORIGINALPRICE 和当头销售价格 NOWPRICE 的总体协方差SELECT COVAR_POP(ORIGINALPRICE, NOWPRICE) FROM PRODUCTION.PRODUCT; -- 3.9求产品原始价格 ORIGINALPRICE 和当头销售价格 NOWPRICE 的样本协方差SELECT COVAR_SAMP(ORIGINALPRICE, NOWPRICE) FROM PRODUCTION.PRODUCT; -- 3.10求产品原始价格 ORIGINALPRICE 和当头销售价格 NOWPRICE 的相关系数SELECT CORR(ORIGINALPRICE, NOWPRICE) FROM PRODUCTION.PRODUCT; -- 3.11返回查询项的首行记录SELECT * FROM PRODUCTION.PRODUCT;SELECT FIRST_VALUE(NAME) FROM PRODUCTION.PRODUCT;-- 3.12求图书的现价在 20~30 之间的最大值SELECT area_max(NOWPRICE,20,30) FROM PRODUCTION.PRODUCT; -- 3.13求每个用户最早定的商品中花费最多和最少的金额select CUSTOMERID, max(TOTAL) keep (dense_rank first order by ORDERDATE) max_val, min(TOTAL) keep (dense_rank first order by ORDERDATE) min_val from SALES.SALESORDER_HEADER group by CUSTOMERID;-- 3.14求出版的所有图书SELECT LISTAGG(NAME, ', ') WITHIN GROUP (ORDER BY NAME) LISTAGG FROM PRODUCTION.PRODUCT;-- 3.15求按照 type 分组之后,各组内 nowprice 的中位数SELECT MEDIAN(nowprice)FROM PRODUCTION.PRODUCT group by(type);
    
  • 效果图:在这里插入图片描述


4、分析函数

简介:分析函数主要用于计算基于组的某种聚合值。如果不使用分析函数,则必须使用连接查询、子查询或者视图,甚至复杂的存储过程实现。DM分析函数为用户分析数据提供了一种更加简单高效的处理方式。引入分析函数后,只需要简单的 SQL 语句,并且执行效率方面也有大幅提高。 与集函数的主要区别是,分析函数对于每组返回多行,而集函数对于每个分组只返回一行。多行形成的组称为窗口,窗口决定了执行当前行的计算范围,窗口的大小可以由组中定义的行数或者范围值滑动.

分析函数可分为 11 类:

  1. COUNT(*);

  2. 完全分析函数 AVG|MAX|MIN| COUNT|SUM([ALL]<值表达式>),这 5个分析函数的参数和作为集函数时的参数一致;

  3. 方差函数 VAR_POP、VAR_SAMP、VARIANCE、STDDEV_POP、STDDEV_SAMP、STDDEV;

  4. 协方差函数 COVAR_POP、COVAR_SAMP、CORR;

  5. 首尾函数 FIRST_VALUE、LAST_VALUE;

  6. 相邻函数 LAG 和 LEAD;

  7. 分组函数 NTILE;

  8. 排序函数 RANK、DENSE_RANK、ROW_NUMBER;

  9. 百分比函数 PERCENT_RANK、CUME_DIST、RATIO_TO_REPORT、PERCENTILE_CONT、NTH_VALUE;

  10. 字符串函数 LISTAGG;

  11. 指定行函数 NTH_VALUE。

例子:

  • 代码:分析函数后跟over(partition by)分区和group by+集函数一致

     -- 4.1查询折扣大于 7的图书作者以及最大折扣/**如果使用的是集函数 MAX,那么得到的是所有图书中折扣的最大值,并不能查询出作者,使用了分析函数,就可以对作者进行分区,得到每个作者所写的图书中折扣最大的值。MIN 的含义和 MAX 类似*/SELECT NAME,AUTHOR,DISCOUNT FROM PRODUCTION.PRODUCT;SELECT AUTHOR, MAX(DISCOUNT) OVER (PARTITION BY AUTHOR) AS MAX FROM PRODUCTION.PRODUCT WHERE DISCOUNT > 7;SELECT MAX(DISCOUNT) FROM PRODUCTION.PRODUCT;
    
  • 图例:在这里插入图片描述

  • 效果图:在这里插入图片描述


5、情况表达式

简介:指明一个条件值。将搜索条件作为输入并返回一个标量值,类似于if和else

例子

  • 代码:

     -- 5.1查询图书信息,如果当前销售价格大于 20 元,返回“昂贵”,如果当前销售价格小于等于 20 元,大于等于 10 元,返回“普通”,如果当前销售价格小于 10 元,返回“便宜select name,CASEWHEN nowprice > 20 THEN '昂贵'WHEN nowprice > 10 and nowprice <= 20 THEN '普通'else '便宜'end AS 选择	from PRODUCTION.PRODUCT;
    
  • 图例:在这里插入图片描述

  • 效果图:在这里插入图片描述

相关内容

热门资讯

向英雄致敬的句子 向英雄致敬的句子  导语:当困难来临时是你们站在了一线,重重的困难阻扰都打不倒你那颗顽强的心。我们非...
唯美优美句子 唯美优美句子大全  1、生活是蜿蜒在山中的小径,坎坷不平,沟崖在侧。摔倒了,要哭就哭吧,怕什么,不心...
问候早上好的暖心简短句子 问候早上好的暖心简短句子(精选90句)  无论是在学校还是在社会中,大家都接触过很多优秀的句子吧,句...
描写人物外貌的好段 描写人物外貌的好段  外貌最常用于描述人的外表,容貌。也形容空间以及物体的外观结构,容貌。下面,小编...
爱自己的经典语句 关于爱自己的经典语句(精选145句)  在平平淡淡的学习、工作、生活中,大家一定都接触过一些名人语句...
描写月亮很圆的句子 描写月亮很圆的句子大全  无论是在学校还是在社会中,许多人都接触过一些比较经典的句子吧,句子由词或词...
英语句子在线翻译   你勇敢,世界就会让步。如果有时它战胜你,你要不断地勇敢再勇敢,它就会屈服。下面的是小编分享的与英...
人生大起大落的感悟句子 人生大起大落的感悟句子  所有的胜利,与征服自己的胜利比起来,都是微不足道。所有的失败,与失去自己的...
描写菊花的句子 描写菊花的句子(精选125句)  在现实生活或工作学习中,大家都知道一些经典的句子吧,句子可分为单句...
飞鸟集好词好句 飞鸟集精选好词好句  无论是在学校还是在社会中,大家或多或少都接触过一些经典的好词好句吧,好词好句的...
励志句子带图片 励志句子带图片  生活可能面目狰狞,但一定要以漂亮的姿态去迎战,励志句子带图片。下面是由应届毕业生小...
描写春分时节的句子 描写春分时节的句子  在我们平凡的日常里,大家总免不了要接触或使用句子吧,句子是能够表达一个相对完整...
搞笑绕口令笑破肚皮 搞笑绕口令笑破肚皮  绕口令是民间汉语语言游戏,将声母、韵母或声调极易混同的字,组成反复、重叠、绕口...
用满意造句 用满意造句  在平日的学习、工作和生活里,大家总少不了接触一些耳熟能详的句子吧,根据句子的语气用途不...
描写人生很累很辛苦的句子 描写人生很累很辛苦的句子集锦  在日常生活或是工作学习中,大家一定没少看到经典的句子吧,句子能表达一...
优秀作品傅雷家书摘抄_优秀句... 傅家雷书是我国文学艺术翻译家傅雷及夫人19541966年间写给孩子傅聪、傅敏等的家信摘编,该书是一本...
初中作文优美语段「摘抄」 初中作文优美语段「摘抄」  摘抄即从文刊、文件等里阅读 ,再把语言优美,值得品析,值得学习的词语,句...
早安最美句子 早安最美句子  在平平淡淡的日常中,大家都听说过或者使用过一些比较经典的句子吧,句子是能够表达一个相...
生日快乐经典句子 生日快乐经典句子(精选80句)  在日常的学习、工作、生活中,大家都接触过很多优秀的句子吧,借助句子...
天冷加衣的温馨句子 天冷加衣的温馨句子  天冷加衣的句子有哪些?天气变冷了加衣服,想要发表说说表达此时的感情,下面这些天...