一个查询

简介:
一个查询 3/4/2007 6:14:16 PM
今天坐在那里没太多事可做,然后就想到了上次说的那个输出格式,过去多半年了我也没找到一个思路。今天正好和三一块讨论一下。
具体要求是这样的:
有一张表。表里的某一个字段有重复值。现在要求的输出结果是如果某一个值已经出现了一次那么下面再出现时不再显示。
比如一张表:boyi55中的数据为
name    total
-----------------
boyi55      1
boyi55      2
boyi55      5
h11h99     2
h11h99     6
则要求的输出结果为:
name    total
-----------------
boyi55      1
                 2
                 5 
h11h99      2
                  6
这个在ASP里应该不难实现的。可是用T-SQL还真没写出来过。
下面看下我的实现过程:
原理:由于不能对原表直接update所以把原表里的数据排序后放到临时表里,然后对临时表进行update操作
用到两张临时表#boy 和#boyi
先把原表按name分组
select name,total into #boy from boyi55 group by name,total
再提出中间name按原值输出的列。即name相同行显示的第一列
select name,min(total) into #boyi from boyi55
下面对临时表#boy进行操作
update #boy
set name='' from #boy
inner join #boyi on #boyi.name=#boy.name
where #boy.total != #boyi.total
这样就可以得到要求的格式,但由于存在于临时表里,所以只能从临时表#boy中查询。
全部代码和结果如下:
--===========================
--按所要求格式输出内容
--按用户名显示信息,如果用户名称相同则从
--下一行开始用户名为空
--当用户名不同时继续输出用户名
--author:boyi55,date:2006-12-5
--===========================
set nocount on
if object_id('#boy') is not null
 drop table #boy
go
if object_id('#boyi') is not null
 drop table #boyi
go
if object_id('boyi55') is not null
 drop table boyi55
go
create table boyi55(name varchar(15),total int)
go
insert into boyi55 values('boyi55',8)
insert into boyi55 values('harry',10)
insert into boyi55 values('h11h99',15)
insert into boyi55 values('boyi55',50)
insert into boyi55 values('boyi55',30)
insert into boyi55 values('h11h99',11)
insert into boyi55 values('boyi55',15)
insert into boyi55 values('h11h99',16)
insert into boyi55 values('boyi55',16)
insert into boyi55 values('harry',1)
insert into boyi55 values('harry',15)
insert into boyi55 values('harry',50)
select name,total into #boy from boyi55 group by name,total
select name,min(total)as total into #boyi from boyi55 group by name
/*update #boy
set name='' from #boy,#boyi
where #boy.total not in(select total from #boyi where name=#boy.name)
*/
update #boy
set name='' from #boy
inner join #boyi on #boyi.name=#boy.name
where #boy.total != #boyi.total
select * from #boy
drop table #boy
drop table #boyi
drop table boyi55
set nocount off
 
输出结果:
name            total       
--------------- ----------- 
boyi55                    8 
                         15 
                         16 
                         30 
                         50 
h11h99                   11 
                         15 
                         16 
harry                     1 
                         10 
                         15 
                         50









本文转自 boyi55 51CTO博客,原文链接:http://blog.51cto.com/boyi55/27299,如需转载请自行联系原作者
目录
相关文章
|
3天前
|
搜索推荐 编译器 Linux
一个可用于企业开发及通用跨平台的Makefile文件
一款适用于企业级开发的通用跨平台Makefile,支持C/C++混合编译、多目标输出(可执行文件、静态/动态库)、Release/Debug版本管理。配置简洁,仅需修改带`MF_CONFIGURE_`前缀的变量,支持脚本化配置与子Makefile管理,具备完善日志、错误提示和跨平台兼容性,附详细文档与示例,便于学习与集成。
271 116
|
18天前
|
域名解析 人工智能
【实操攻略】手把手教学,免费领取.CN域名
即日起至2025年12月31日,购买万小智AI建站或云·企业官网,每单可免费领1个.CN域名首年!跟我了解领取攻略吧~
|
12天前
|
安全 Java Android开发
深度解析 Android 崩溃捕获原理及从崩溃到归因的闭环实践
崩溃堆栈全是 a.b.c?Native 错误查不到行号?本文详解 Android 崩溃采集全链路原理,教你如何把“天书”变“说明书”。RUM SDK 已支持一键接入。
663 219
|
5天前
|
数据采集 人工智能 自然语言处理
Meta SAM3开源:让图像分割,听懂你的话
Meta发布并开源SAM 3,首个支持文本或视觉提示的统一图像视频分割模型,可精准分割“红色条纹伞”等开放词汇概念,覆盖400万独特概念,性能达人类水平75%–80%,推动视觉分割新突破。
349 34
Meta SAM3开源:让图像分割,听懂你的话
|
10天前
|
人工智能 移动开发 自然语言处理
2025最新HTML静态网页制作工具推荐:10款免费在线生成器小白也能5分钟上手
晓猛团队精选2025年10款真正免费、无需编程的在线HTML建站工具,涵盖AI生成、拖拽编辑、设计稿转代码等多种类型,均支持浏览器直接使用、快速出图与文件导出,特别适合零基础用户快速搭建个人网站、落地页或企业官网。
1575 157
|
存储 人工智能 监控
从代码生成到自主决策:打造一个Coding驱动的“自我编程”Agent
本文介绍了一种基于LLM的“自我编程”Agent系统,通过代码驱动实现复杂逻辑。该Agent以Python为执行引擎,结合Py4j实现Java与Python交互,支持多工具调用、记忆分层与上下文工程,具备感知、认知、表达、自我评估等能力模块,目标是打造可进化的“1.5线”智能助手。
897 61
|
7天前
|
编解码 Linux 数据安全/隐私保护
教程分享免费视频压缩软件,免费视频压缩,视频压缩免费,附压缩方法及学习教程
教程分享免费视频压缩软件,免费视频压缩,视频压缩免费,附压缩方法及学习教程
295 140