【Sql server】假设有三个字段a,b,c 以a和b分组,如何查询a和b唯一,但是c不同的记录

欢迎来到《小5讲堂》,大家好,我是全栈小5。
这是《Sql Server》系列文章,每篇文章将以博主理解的角度展开讲解,
特别是针对知识点的概念进行叙说,大部分文章将会对这些概念进行实际例子验证,以此达到加深对知识点的理解和掌握。
温馨提示:博主能力有限,理解水平有限,若有不对之处望指正!

在这里插入图片描述

目录

  • 前言
  • 创建表
  • 模拟数据
  • 分组查询
    • 城市分组
    • 城市区县分组
    • 代理商维度
    • 不同代理
  • 小知识点
    • identity
    • 删除数据
    • 分组查询原则
  • 文章推荐

前言

最近在做数据修改,有时候太久没写sql语句,突然想通过子查询的方式去批量更新数据的时候,
还是有点不知所措,那就一步一步来吧,也写篇文章梳理和总结下,毕竟也是基本的操作加深印象。
在做数据批量修改时,有个关键点,就是分组查询后找出另外一个字段不同值得记录,因此本篇文章就针对这个查询梳理一遍。

创建表

假设有一张表,有三个主要字段,城市名称、区县名称、代理商名称。
创建表时,习惯性给表加一个id编号,并且是自增字段,有个序号感觉看起来舒服,hhh~~~

create table test_name
(id int identity(1,1),        -- 自增编号city_name nvarchar(50),        -- 城市名称area_name nvarchar(50),        -- 区县名称agent_name nvarchar(50)        -- 代理商名称
)

模拟数据

insert into test_name(city_name,area_name,agent_name) values
('广州市','白云区','张三'),
('广州市','白云区','张三'),
('广州市','白云区','李四'),
('广州市','白云区','王五'),
('深圳市','龙岗区','张三')

上面是一次性添加多条,所以只需要写一个values即可,也可以分开写。
分开写后,就能看出来重复啰嗦,所以才会有一些简写的方式。

insert into test_name(city_name,area_name,agent_name) 
values
('广州市','白云区','张三')insert into test_name(city_name,area_name,agent_name) 
values('广州市','白云区','张三')insert into test_name(city_name,area_name,agent_name) 
values('广州市','白云区','李四')insert into test_name(city_name,area_name,agent_name) 
values('广州市','白云区','王五')insert into test_name(city_name,area_name,agent_name) 
values('深圳市','龙岗区','张三')

分组查询

城市分组

select city_name from test_name group by city_name

在这里插入图片描述

城市区县分组

select city_name,area_name from test_name group by city_name,area_name

在这里插入图片描述

代理商维度

城市、区县、代理商,三者组合唯一查询

select * from test_name
select city_name,area_name,agent_name from test_name group by city_name,area_name,agent_name

在这里插入图片描述

不同代理

同城市区县,但不同代理商的记录。

select city_name 城市,area_name 区县,count(agent_name) 过滤前代理商数量,count(distinct agent_name) 过滤后代理商数据
from test_name 
group by city_name,area_name
having count(distinct agent_name)>1

在这里插入图片描述

小知识点

identity

在 SQL Server 中,Identity 是一种特殊的属性,用于指定某一列是自动生成的数字列。
通过设置 Identity 属性,可以让 SQL Server 自动生成唯一的数字值,并自动填充到指定的列中。
这样可以很方便地为表中的每一行生成一个唯一的标识符。
在创建表时,可以通过以下语法向列添加 Identity 属性:

CREATE TABLE your_table
(column_name INT IDENTITY(1,1) PRIMARY KEY,-- other columns
);

在这个例子中,column_name 是指定了 Identity 属性的列名,INT 是数据类型,IDENTITY(1,1) 表示以1为起始值,1为递增值自动为每个新行生成一个唯一值,PRIMARY KEY 用来指定此列为主键。
当插入数据时,不需要为 Identity 列指定具体的值,数据库会自动生成并填充对应的值。如果需要获取自动生成的 Identity 值,可以使用 SCOPE_IDENTITY() 函数或者 @@IDENTITY 系统变量。

删除数据

基于上面自增编号知识点,来了解下delete和truncate删除数据的最大区别
delete 表名 可按条件删除或者批量删除记录,并且自增id编号会继续从当前记录值开始算,比如最新编号为10,即使删除编号10的记录,那么新插入一条记录,编号为11
truncate table 表名,全表删除,id自增编号重新开始从1或者指定规则计算

分组查询原则

选择列表中的列 ‘test_name.area_name’ 无效,因为该列没有包含在聚合函数或 GROUP BY 子句中。
基本原则就是,查询的字段值必须要在分组里,否则无效。
在这里插入图片描述

文章推荐

【Sql Server】新手一分钟看懂在已有表基础上修改字段默认值和数据类型

【数据库】Sql Server数据迁移,处理自增字段赋值

【数据类型】C#和Sql Server、Mysql、Oracle等常见数据库的数据类型对应关系

总结:温故而知新,不同阶段重温知识点,会有不一样的认识和理解,博主将巩固一遍知识点,并以实践方式和大家分享,若能有所帮助和收获,这将是博主最大的创作动力和荣幸。也期待认识更多优秀新老博主。

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

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

相关文章

2_SQL

文章目录 SQL数据完整性实体完整性域完整性参照完整性default(默认值)comment(注释) 多表设计一对一一对多多对多数据库三大范式第一范式:原子性第二范式:唯一性第三范式:数据的冗余 多表查询连…

JQMobile Loader Widget 遮罩层改造

最近在用jqmobile 做一个混合APP项目时候用到 jqmobile1.4.3提供的Loader Widget控件,但是这个控件本身是一个loading弹出层,这个弹出层弹出之后,用户还是可以去点击按钮,重复发送请求,为了防止重复提交,我想了两种办法, 1,在loading弹出层弹出之后,让按钮不可用.但是form表单…

记录SSM项目集成Spring Security 4.X版本 之 加密验证和记住我功能

目录 前言 一、用户登录密码加密认证 二、记住我功能 前言 本次笔记的记录是接SSM项目集成Spring Security 4.X版本 之 加入DWZ,J-UI框架实现登录和主页菜单显示-CSDN博客https://blog.csdn.net/u011529483/article/details/136255768?spm1001.2014.3001.5502 文章之后补…

Python列表的合并、重复、判断与切片操作你学会了吗

1.合并列表 通过 实现 list1 ["佛跳墙", "肠粉", "刀削面", "烤鸭"]list2 [32, 4, 5, 7.43, True]list3 list1 list2print(list3) # [佛跳墙, 肠粉, 刀削面, 烤鸭, 32, 4, 5, 7.43, True] 2.重复输出列表中的元素 通过 * 实…

vue3 中 主题定制

vue3 中 主题定制 背景 做多主题定制,黑/白 ,里面还要再分各种颜色,每次进来都要记住上次的主题设置 效果图 一、目录结构 ├── generated │ ├── theme │ │ └── dark-yellow.ts │ │ └── dark-orange.ts │ │…

「算法」常见位运算总结

位运算符 异或 按位异或可以实现无进位相加,所谓无进位相加,就是在不考虑进位的情况下将两个数相加(后面有道题需要用到这种操作) 异或的运算律 ①a ^ 0 a ②a ^ a 0 ③a ^ b ^ c a ^ ( b ^ c ) 有符号右移>> 将一个…

IDEA切换 Springboot初始化 URL

🌹作者主页:青花锁 🌹简介:Java领域优质创作者🏆、Java微服务架构公号作者😄 🌹简历模板、学习资料、面试题库、技术互助 🌹文末获取联系方式 📝 往期热门专栏回顾 专栏…

云计算 2月20号 (认识操作系统)

1、认识操作系统 计算机系统的组成 知识点1:没有软件系统的计算机称之为"裸机" 知识点2:裸机提供基本的可计算性资源 知识点3:操作系统是最靠近硬件的软件层,负责管理和控制计算机硬件。 计算机硬件组成五大部件 运算器…

代码随想录算法刷题训练营day29:LeetCode(491)递增子序列、LeetCode(46)全排列、LeetCode(47)全排列 II

代码随想录算法刷题训练营day29:LeetCode(491)递增子序列、LeetCode(46)全排列、LeetCode(47)全排列 II LeetCode(491)递增子序列 题目 代码 import java.util.ArrayList; import java.util.Arrays; import java.util.Collections; import java.util.HashSet; im…

2024年AI全景预测

欢迎来到 2024 年人工智能和技术的可能性之旅。 在这里,每一个预测都是一个潜在的窗口,通向充满创新、变革、更重要的是类似于 1950 年代工业革命的未来。 20 世纪 50 年代见证了数字计算的兴起,重塑了行业和社会规范。 如今,人工…

力扣1143. 最长公共子序列(动态规划)

Problem: 1143. 最长公共子序列 文章目录 题目描述思路复杂度Code 题目描述 思路 我们统一标记:str1[i]代表text1表示的字符数组,str2[j]代表text2表示的字符数组;LCS代表最长的公共子序列;(我们易得只有str1[i]和str…

Flutter中Widget的生命周期

Widget生命周期: createState-initState-didChangeDependency-build-deactive-dispose 可通过WidgetsBinding类对widget生命周期的回调进行监控。 createState:StatefulWidget 中用于创建 State; initState:State 的初始化操作&am…

CLion远程调试C++

文件映射到 可以右键文件夹选择重新Cmake 编译

xsslabs第七关

源码 <!DOCTYPE html><!--STATUS OK--><html> <head> <meta http-equiv"content-type" content"text/html;charsetutf-8"> <script> window.alert function() { confirm("完成的不错&#xff01;"…

【刷题】Leetcode 1609.奇偶树

Leetcode 1609.奇偶树 题目描述广度优先搜索&#xff08;BFS&#xff09;深度优先算法&#xff08;DFS&#xff09; 思路一&#xff08;BFS&#xff09;思路二&#xff08;DFS&#xff09;Thanks♪(&#xff65;ω&#xff65;)&#xff89;谢谢阅读&#xff01;&#xff01;&a…

数字后端——DEF文件格式

文章目录 MACRO的不同orientationDEF中在macro orientation定义前需要留空格 MACRO的不同orientation DEF中在macro orientation定义前需要留空格 像下图中这种方向和分号之间没有空格的情况&#xff0c;就是有问题的格式。

数学学习与研究杂志社《数学学习与研究》杂志社编辑部2023年第29期目录

考试研究 提高高三数学二轮复习质量的思考与实践 佘淮青; 2-4 提升高三数学复习质量的策略探究 王飞; 5-7 核心素养背景下的高中数学命题策略研究 陈明发; 8-10 提升中考数学复习课的有效性研讨 韩兴宏; 11-13 中学教学方法《数学学习与研究》投稿&#xff1a;…

pyuic生成py文件到指定文件夹

pyuic生成py文件到指定文件夹 关于如何在pycharm配置外部工具的方法这里不做赘述&#xff0c;本文主要说明&#xff0c;如何利用pyuic将ui文件生成到指定的项目目录中。 前提条件&#xff1a;已配置的pyuic工具可以正常使用生成文件到目录中。 一、打开外部工具配置页面 打开…

如何用Python检查时间序列数据是否平稳?

时间序列数据通常以其时间性质为特征。这种时间性质为数据增加了趋势或季节性&#xff0c;使其与时间序列分析和预测兼容。如果时间序列数据不随时间变化或没有时间结构&#xff0c;则称其为静态数据。因此&#xff0c;检查数据是否平稳是非常必要的。在时间序列预测中&#xf…

用HTML5的<canvas>元素实现刮刮乐游戏

用HTML5的<canvas>元素实现刮刮乐 用HTML5的<canvas>元素实现刮刮乐&#xff0c;要求&#xff1a;将上面的“图层”的图像可用鼠标刮去&#xff0c;露出下面的“图层”的图像。 示例从简单到复杂。 简单示例 准备两张图像&#xff0c;我这里上面的图像top_imag…