当前位置:首页 » 《随便一记》 » 正文

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

24 人参与  2024年03月12日 13:51  分类 : 《随便一记》  评论

点击全文阅读


欢迎来到《小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_nameselect 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_namehaving 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://zhangshiyu.com/post/78273.html

<< 上一篇 下一篇 >>

  • 评论(0)
  • 赞助本站

◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。

最新文章

  • 进错房,嫁给八零最牛特种兵已完结(林晚夏江肆年)抖音热文_《进错房,嫁给八零最牛特种兵已完结》最新章节免费在线阅读 -
  • 重生后选魔族,天族哭着求我当王全章节(月沁雪任意)全文免费阅读无弹窗大结局_(重生后选魔族,天族哭着求我当王全章节)重生后选魔族,天族哭着求我当王全章节免费阅读全文最新章节列表_笔趣阁(重生后选魔族,天族哭着求我当王全章节) -
  • 捡回摄政王后,她在皇室作威作福完结版小说(景飞鸢赵灵杰)全文免费阅读无弹窗大结局_(捡回摄政王后,她在皇室作威作福完结版免费阅读全文大结局)最新章节列表_笔趣阁(捡回摄政王后,她在皇室作威作福完结版) -
  • 千金难泣(立轩苏子骞翠竹吴进)全本免费在线阅读_千金难泣最新章节在线阅读(立轩苏子骞翠竹吴进)
  • 《沈云阶傅宴辞》(沈云阶傅宴辞》已完结完整版全集大结局小说)全文阅读笔趣阁
  • 《沈凌峰沈国华》已完结小说全文阅读笔趣阁《沈凌峰沈国华》
  • 《傅嫤韩恬魏郯程茂》已完结(傅嫤韩恬魏郯程茂)热门小说全目录完整版)全文阅读笔趣阁
  • 八零俏军医错嫁糙汉军官:番外+全文+后续(贺昭朗孟翩然)完本小说免费_全本免费小说八零俏军医错嫁糙汉军官:番外+全文+后续最新小说全文阅读(贺昭朗孟翩然)
  • 失去千千万万遍在线阅读(阮相宜陆凛言)全文免费阅读无弹窗大结局_(失去千千万万遍在线阅读)失去千千万万遍在线阅读免费阅读全文最新章节列表_笔趣阁(失去千千万万遍在线阅读) -
  • 脱离世界后,妻子疯了火爆小说小说(沈夕颜林程言)全文免费阅读无弹窗大结局_(脱离世界后,妻子疯了火爆小说免费阅读全文大结局)最新章节列表_笔趣阁(脱离世界后,妻子疯了火爆小说) -
  • 跨年发生踩踏,男友为救白月光丢下我(温林初宝宝)免费阅读 -
  • 都重生了,还不离婚等啥呢宋招弟霍文铮小说在线章节免费阅读

    关于我们 | 我要投稿 | 免责申明

    Copyright © 2020-2022 ZhangShiYu.com Rights Reserved.豫ICP备2022013469号-1