SQL Server 查询设置 - LIKE/DISTINCT/HAVING/排序

目录

背景

一、LIKE - 模糊查询

1. 通配符 % 

2. 占位符 _

3. 指定集合 []

3.1 表示否定 ^

3.2 表示范围 -

4. 否定 NOT

二、DISTINCT - 去重查询

三、HAVING - 过滤查询

四、小的查询设置

1. ASC|DESC - 排序

2. TOP - 限制

3. 子查询

4. not in - 取补集(LIMIT效果)


背景

本专栏文章以 SAP 实施顾问在实施项目中需要掌握的 sql 语句为偏向进行选题,用例使用的是 SAP B1 的数据库,使用工具为 SQL Server。

本篇为复杂查询中功能强大、使用边界的条件语句 LIKEDISTINCTHAVING,与排序、子查询等查询设置。

不考虑表连接的基础上,在查询信息时,本文涉及到的各逻辑条件排列顺序如下:

--()表示结构可省略,[]表示该位置内容
SELECT (DISTINCT) (TOP 获取前几条) [*/字段名] 
FROM [表名/子查询]
(WHERE [字段名] LIKE [查询模糊条件])
(GROUP BY [分组条件])
(HAVING [过滤条件])
(ORDER BY [排序字段] (ASC|DESC))

一、LIKE - 模糊查询

模糊查询 LIKE 用于字符搜索,通过对所需查找的信息进行条件设定,如某字开头、某字结尾、包含某字、不含某字、第几位是某字等,将所需信息筛出。与之功能对应的还有 REGEXP(正则表达式) ,并且其功能更强大,表达更简略。但是 SQL Server 不支持使用。

其基本语法如下:

SELECT [需要查询的列名]
FROM [表名]
WHERE [条件列] LIKE '[条件内容]'

1. 通配符 % 

使用模糊查询 LIKE 时,对于所需核对的信息进行位置限定,需要根据条件使用 “%”,若需要以某字开头则形式为 'X%' ,某字结尾则为 '%X'

:查找【业务伙伴主数据】表单中含有 “京” 字的公司。

此时需要在条件词左右打上 “%”,对文本所在位置进行限制,即 “京” 字出现在的任何一个位置,都将被查找出来:

SELECT CardCode,CardName
FROM OCRD
WHERE CardName LIKE N'%京%' --查询内容为中文字符时需要增加前缀“N”才能被sql server识别

查询结果为:

2. 占位符 _

如果对于查询信息有严格的位数要求,如需要第几位是某字,即可通过占位符 “_” 占出前面位数,

例1:查找【业务伙伴主数据】表单中业务伙伴编码第二位为 “1” 的公司。

使用占位符占用第一位,意思是无论第一位是什么都无所谓只要有东西就行,第二位是要求 “1”,其后一共几位无所谓了所以用通配符 “%”。

SELECT CardCode,CardName
FROM OCRD
WHERE CardCode LIKE '_1%'

查询结果:

例2:查找【业务伙伴主数据】表单中业务伙伴编码为 6 位的公司。

SELECT CardCode,CardName
FROM OCRD
WHERE CardCode LIKE '______'--一共六条下划线

查询结果(结果行数较多,仅展示部分):

3. 指定集合 []

设定某一位,为在一定范围内任意一个值都可以,则使用 “[]” 框选集合,无论中括号内放多少字符,中括号都只算一位。

例:查找【业务伙伴主数据】表单中业务伙伴编码以 “C” 或 “V” 开头的公司。

SELECT CardCode,CardName
FROM OCRD
WHERE CardCode LIKE '[CV]%'

查询结果(结果行数较多,仅展示部分):

3.1 表示否定 ^

否定符 “^” 仅能在中括号内使用,哪怕只有一位,要使用否定符 “^”,也需要加上 “[]”。

例:查找【业务伙伴主数据】表单中业务伙伴编码不以 “C” 开头的公司。

SELECT CardCode,CardName
FROM OCRD
WHERE CardCode LIKE '[^C]%' --不加[]的话数据库会把^理解为判断字符

查询结果:

3.2 表示范围 -

在 “[]” 内设定内容存在既定顺序时,可以使用 “-”,主要包含:字母按照字母表顺序和数字按照大小顺序。

例:查找【业务伙伴主数据】表单中业务伙伴名称含有数字的公司。

SELECT CardCode,CardName
FROM OCRD
WHERE CardName LIKE '%[0-9]%'

查询结果:

4. 否定 NOT

对于 LIKE 级别的综合否定,均可用 NOT LIKE 来实现。

例:查找【业务伙伴主数据】表单中业务伙伴名称不含有数字的公司。

SELECT CardCode,CardName
FROM OCRD
WHERE CardName NOT LIKE '%[0-9]%'

则会查询出上一节 3.2 案例的查询结果的补集,即返回上一案例以外的内容行。

二、DISTINCT - 去重查询

SELECT 之后增加 DISTINCT,可以对查询数据去重。 

使用场景:比如在查询所有下过采购订单的客户时,可以使用得到去重后的客户名单

SELECT DISTINCT CardCode,CardName
FROM ORDR

三、HAVING - 过滤查询

对分组后的数据过滤,一般会先使用 GROUP BY;倘若没有出现 GROUP BY,则默认 HAVING 把整张表当作一组进行过滤

HAVING 和 WHERE 的区别:

  • WHERE 在分组前过滤,HAVING 在分组后过滤。
  • WHERE 语句里不能包含聚合函数,HAVING 语句可以,并且 HAVING 语句中的子句一般来说不是聚合函数就是分组列。

例:查找平均销售额大于 1000 的客户。

SELECT CardCode,CardName,AVG(DocTotal) AS '平均销售额'
FROM ORDR
GROUP BY CardCode,CardName
HAVING AVG(DocTotal)>1000

查询结果:

四、小的查询设置

1. ASC|DESC - 排序

放在 ORDER BY 后面,起到一个对分组进行升序(ASC)或降序(DESC)续排列的作用。

例:按【销售金额】对平均销售额大于 1000 的客户进行【倒序】排列

SELECT CardCode,CardName,AVG(DocTotal) AS '平均销售额'
FROM ORDR
GROUP BY CardCode,CardName 
HAVING AVG(DocTotal)>1000
ORDER BY AVG(DocTotal) DESC

查询结果:

2. TOP - 限制

放在 SELECT 之后,按照 TOP + [数量] 的格式,实现对前 [数量] 行信息的效果。

例:查询【销售金额】对平均销售额前十的客户名单

SELECT TOP 10 CardCode,CardName FROM ORDR
GROUP BY CardCode,CardName
ORDER BY AVG(DocTotal) DESC

查询结果:

3. 子查询

在 WHERE 后,除了可以接某张已经存在的具体表,还可以接一个【子查询】,即由一个新的查询构建的新表,将其嵌套进原有的查询命令时,形成一个【子查询】。

注意:子查询返回的值能且仅能为一个

例:查找销售额最高的客户在【业务伙伴主数据】中登记的业务伙伴代码、业务伙伴名称、业务伙伴类型、组代码、电话 1、联系人信息。

SELECT CardCode,CardName,CardType,GroupCode,Phone1,CntctPrsn
FROM OCRD
WHERE CardCode = (
SELECT TOP 1 CardCode FROM ORDR
GROUP BY CardCode
ORDER BY SUM(DocTotal) DESC
)

 查询结果

4. not in - 取补集(LIMIT效果)

在 MySQL 中,可以利用 LIMIT 对查询的信息条目进行限制,如查前 x 条数据、跳过前 y 条数据查找后面的 z 条数据。但是 SQL Server 中不支持 LIMIT,可以使用 TOP 联合 not 和 子查询完成以上功能的实现。

例:跳过销售金额平均值前十的客户,返回第 11-15 名的客户名单

SELECT TOP 5 CardCode,CardName FROM OPOR
WHERE CardCode NOT IN(
SELECT TOP 10 CardCode FROM ORDR
GROUP BY CardCode
ORDER BY AVG(DocTotal) DESC
)

查询结果:

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/473145.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

动态规划-完全背包问题——322.零钱兑换

1.题目解析 题目来源 322.零钱兑换——力扣 测试用例 2.算法原理 1.状态表示 这里需要寻找硬币使总面值等于一个值求出所需硬币的最小个数,所以不妨设置一个二维dp表,即dp[i][j]:在[1,i]个硬币中选择的硬币总面值完全等于j时所需要的最小硬…

从零到一:利用 AI 开发 iOS App 《震感》的编程之旅

在网上看到一篇关于使用AI开发的编程经历,分享给大家 作者是如何在没有 iOS 开发经验的情况下,借助 AI(如 Claude 3 模型)成功开发并发布《震感》iOS 应用。 正文开始 2022 年 11 月,ChatGPT 诞生并迅速引发全球关注。…

【Linux庖丁解牛】—Linux基本指令(下)!

目录 1、grep指令 2、zip/unzip指令 3、sz/rz指令 4、tar指令 ​编辑 5、scp指令 6、bc指令 7、uname –r指令 8、重要的几个热键 9、关机 10、完结撒花 1、grep指令 grep是文本过滤器,其作用是在指定的文件中过滤出包含你指定字符串的内容,…

小程序19-微信小程序的样式和组件介绍

在小程序中不能使用 HTML 标签,也就没有 DOM 和 BOM,CSS 也仅支持部分选择器 小程序提供了 WXML 进行页面结构的编写,WXSS 进行页面的样式编写 WXML 提供了 view、text、image、navigator等标签构建页面结构,小程序中标签称为组件…

VMD + CEEMDAN 二次分解,CNN-LSTM预测模型

往期精彩内容: 时序预测:LSTM、ARIMA、Holt-Winters、SARIMA模型的分析与比较 全是干货 | 数据集、学习资料、建模资源分享! EMD变体分解效果最好算法——CEEMDAN(五)-CSDN博客 拒绝信息泄露!VMD滚动分…

《生成式 AI》课程 第3講 CODE TASK 任务3:自定义任务的机器人

课程 《生成式 AI》课程 第3講:訓練不了人工智慧嗎?你可以訓練你自己-CSDN博客 我们希望你创建一个定制的服务机器人。 您可以想出任何您希望机器人执行的任务,例如,一个可以解决简单的数学问题的机器人0 一个机器人&#xff0c…

SOLIDWORKS Toolbox:一键自动化,让紧固件与零部件管理更高效

紧固件广泛应用于从手机到火箭的各种产品中。在SOLIDWORKS设计时,通过使用实际的CAD模型来包含和跟踪紧固件是最简便和全面的方法,这有助于理解设计的整体,并自动管理零件数据和设计文档,如工程图和物料清单(BOM)。 在SOLIDWORKS…

串口DMA接收不定长数据

STM32F767—>串口通信接收不定长数据的处理方法_stm32串口超时中断-CSDN博客 STM32-HAL库串口DMA空闲中断的正确使用方式解析SBUS信号_stm32 hal usart2 dma-CSDN博客 #define USART1_RxBuffSize 100 extern DMA_HandleTypeDef hdma_usart1_rx; //此处声明的变量在…

git简介和本地仓库创建,并提交修改。git config init status add commit

一、Git简介和本地仓库组成 1.1 git简介 视频教程在这 git简介,版本控制系统,工作区,暂存区,本地仓库_哔哩哔哩_bilibili 如下图,比如我们写毕业论文,要经常修改和完善,得靠自己保存&#x…

鸿蒙学习生态应用开发能力全景图-赋能套件(1)

文章目录 赋能套件鸿蒙生态应用开发能力全景图 赋能套件 鸿蒙生态白皮书: 全面阐释了鸿蒙生态下应用开发核心理念、关键能力以及创新体验,旨在帮助开发者快速、准确、全面的了解鸿蒙开发套件给开发者提供的能力全景和未来的愿景。 视频课程: 基于真实的开发场景,提供向导式…

vue+svg圆形进度条组件

vuesvg圆形进度条组件 一、实现思路二、ProgressCircle.vue三、父组件使用四、实现效果 一、实现思路 使用svg的circle元素画两个圆形&#xff0c;一个圆形控制进度&#xff0c;一个绘制底色 二、ProgressCircle.vue 代码示例&#xff1a; <template><!-- 圆形进度…

软件测试 —— 自动化基础

目录 前言 一、Web 自动化测试 1.什么是 Web 自动化测试 2.驱动 3.安装驱动管理 二、Selenium 1.简单 web 自动化测试示例 2.工作原理 三、元素定位 1.cssSelector 2.XPath 四、操作测试对象 1.点击/提交对象 2.模拟按键输入 3.清除文本内容 4.获取文本信息 5.…

基于SpringBoot的旅游网站(程序+数据库+报告)

基于SpringBoot的旅游网站&#xff0c;系统包含两种角色&#xff1a;管理员、用户,系统分为前台和后台两大模块&#xff0c;主要功能如下。 【前台】&#xff1a; - 首页&#xff1a;展示旅游网站的核心内容&#xff0c;包括推荐的旅游线路、最新的旅游资讯等。 - 旅游线路&am…

RabbitMQ教程:路由(Routing)(四)

文章目录 RabbitMQ教程&#xff1a;路由&#xff08;Routing&#xff09;&#xff08;四&#xff09;一、引言二、基本概念2.1 路由与绑定2.2 Direct交换机2.3 多绑定2.4 发送日志2.5 订阅 三、整合代码3.1 EmitLogDirectApp.cs3.2 ReceiveLogsDirectApp.cs3.3 推送所有和接收e…

AntFlow:一款高效灵活的开源工作流引擎

AntFlow 是一款功能强大、设计优雅的开源工作流引擎&#xff0c;其灵感来源于钉钉的工作流设计理念&#xff0c;旨在为企业和开发者提供灵活、高效的工作流解决方案。AntFlow 支持复杂的业务流程管理&#xff0c;具有高度可定制性&#xff0c;且拥有现代化的前端设计&#xff0…

游戏引擎学习第13天

视频参考:https://www.bilibili.com/video/BV1QQUaYMEEz/ 改代码的地方尽量一张图说清楚吧,懒得浪费时间 game.h #pragma once #include <cmath> #include <cstdint> #include <malloc.h>#define internal static // 用于定义内翻译单元内部函数 #…

中仕公考怎么样?事业编面试不去有影响吗?

事业编考试笔试已经通过&#xff0c;但是面试不去参加会有影响吗&#xff1f; 1. 自动放弃面试资格&#xff1a;未能按时出席事业单位的面试将被视为主动放弃该岗位的竞争机会。 2. 个人信誉问题&#xff1a;面试作为招聘流程的关键步骤&#xff0c;无故缺席可能被解释为诚信…

ElasticSearch学习笔记二:使用Java客户端

一、前言 在上一篇文章中&#xff0c;我们对ES有了最基本的认识&#xff0c;本着实用为主的原则&#xff0c;我们先不学很深的东西&#xff0c;今天打算先学习一下ES的Java客户端如何使用。 二、创建项目 1、普通Maven项目 1、创建一个Maven项目 2、Pom文件 <dependenc…

使用 Grafana api 查询 Datasource 数据

一、使用grafana 的api 接口 官方API 二、生成Api key 点击 Administration -》Users and accss -》Service accounts 进入页面 点击Add service account 创建 service account 点击Add service account token 点击 Generate token , 就可以生成 api key 了 三、进入grafana…

机器学习-36-对ML的思考之机器学习研究的初衷及科学研究的期望

文章目录 1 机器学习最初的样子1.1 知识工程诞生(专家系统)1.2 知识工程高潮期1.3 专家系统的瓶颈(知识获取)1.4 机器学习研究的初衷2 科学研究对机器学习的期望2.1 面向科学研究的机器学习轮廓2.2 机器学习及其应用研讨会2.3 智能信息处理系列研讨会2.4 机器学习对科学研究的重…