group by 如何合并字符串优化记?
sqlserver 2005及以上版本
表(tb)
id value
1 aa
2 cc
3 bb
3 dd
4 aa
4 cc
4 dd
5 aa
优化前:
select id, value = (select value+',' from tb as rtb where rtb.id = a.tb.id for xml path(''))
from tb as a
group by a.id
优化后:(思路:将count(0)数等于1或者等于2的记录,通过min,max处理,减少每个id都要查询表)
select id, value =case count(0) when 1 then min(value)
when 2 then min(value)+','+max(value)
else (select value+',' from tb as rtb where rtb.id = a.tb.id for xml path('')) end
from tb as a
group by a.id
group by 如何合并字符串优化记?的更多相关文章
- 【SQL】SqlServer中Group By后,字符串合并
		参考: 1.SQL查询语句 group by后, 字符串合并 2.sql for xml path用法 #需求: 合并列值 表结构,数据如下: id value ----- ------ aa bb ... 
- 在论坛中出现的比较难的sql问题:26(动态行专列+合并字符串、补足行数)
		原文:在论坛中出现的比较难的sql问题:26(动态行专列+合并字符串.补足行数) 最近,在论坛中,遇到了不少比较难的sql问题,虽然自己都能解决,但发现过几天后,就记不起来了,也忘记解决的方法了. 所 ... 
- 《Python CookBook2》 第一章 文本 - 去字符串两端的空格 && 合并字符串 && 将字符串逐字符或者逐词反转
		去字符串两端的空格 任务: 获得一个开头和末尾都没有多余空格的字符串. 解决方案: 字符串对象的lstrip.rstrip和strip 方法正是为这种任务而设计的.这几个方法都不需要参数,它们会直接返 ... 
- js 正则学习小记之匹配字符串优化篇
		原文:js 正则学习小记之匹配字符串优化篇 昨天在<js 正则学习小记之匹配字符串>谈到 个字符,除了第一个 个,只有 个转义( 个字符),所以 次,只有 次成功.这 次匹配失败,需要回溯 ... 
- python文本 拼接或合并字符串
		python文本 拼接.合并字符串 场景: 拼接.合并字符串 在这个场景中,我们首先想到的当然是使用+或者+=将两个字符串连接起来 >>> a='a' >>> ... 
- 一次 group by + order by 性能优化分析
		一次 group by + order by 性能优化分析 最近通过一个日志表做排行的时候发现特别卡,最后问题得到了解决,梳理一些索引和MySQL执行过程的经验,但是最后还是有5个谜题没解开,希望大家 ... 
- Java-Runoob-高级教程-实例-字符串:12. Java 实例 - 字符串优化
		ylbtech-Java-Runoob-高级教程-实例-字符串:12. Java 实例 - 字符串优化 1.返回顶部 1. Java 实例 - 字符串优化 Java 实例 以下实例演示了通过 Str ... 
- 【LeetCode】5685. 交替合并字符串 Merge Strings Alternately (Python)
		作者: 负雪明烛 id: fuxuemingzhu 公众号:每日算法题 本文关键词:LeetCode,力扣,算法,算法题,交替合并字符串,Merge Strings Alternately,刷题群 目 ... 
- SQL查询语句 group by后, 字符串合并
		合并列值 --******************************************************************************************* 表 ... 
随机推荐
- JSQL查询
			JSQL 其特征与原生soL语句类似,并且完全面向对象,通过类名和属性访问,而不是表名和表的属性. sql:查询的是表和表中的字段 jpql:查询的是实体类和类中的属性 查询全部 >> ... 
- 基于.net EF6 MVC5+WEB Api 的Web系统框架总结(3)-项目依赖注入
			简介 依赖注入主要是一种结构性的模式,注重的是类与类之间的结构,它要达到的目的就是设计原则中最少知道和合成复用的原则,减少内部依赖,履行单一职责,最终就是强解耦.依赖注入目前最好的实现就是依赖注入容器 ... 
- 洛谷 P1980【计数问题】 题解(2)
			还有一种办法,就是用stringstream函数将每一次的数全都转化成char一维数组样式的字符串,然后逐位扫一遍即可. (记得判断字符时将规定数字+48) //Stand up for the fa ... 
- 【LeetCode】103# 二叉树的锯齿形层次遍历
			题目描述 给定一个二叉树,返回其节点值的锯齿形层次遍历.(即先从左往右,再从右往左进行下一层遍历,以此类推,层与层之间交替进行). 例如: 给定二叉树 [3,9,20,null,null,15,7], ... 
- String对象为什么不可变
			转载:https://www.cnblogs.com/leskang/p/6110631.html 一.什么是不可变对象? As we all know, 在Java中, String类对象是不可变的 ... 
- Java,哈希码以及equals和==的区别
			从开始学习Java,哈希码以及equals和==的区别就一直困扰着我. 要想明白equals和==的区别首先应该了解什么是哈希码,因为在jdk的类库中不管是object实现的equals()方法还是S ... 
- Git的使用(三)远程仓库添加及克隆
			Git是分布式版本控制系统,同一个Git仓库,可以分布到不同的机器上.怎么分布呢?最早,肯定只有一台机器有一个原始版本库,此后,别的机器可以“克隆”这个原始版本库,而且每台机器的版本库其实都是一样的, ... 
- MySQL和mybatis查询相关
			0.mybatis的xml文件头 <?xml version="1.0" encoding="UTF-8" ?> <!DOCTYPE mapp ... 
- Android-隐藏app图标以及隐式启动
			隐藏APP桌面图标 <activity android:name=".LaunchActivity"> <intent-filter> <action ... 
- FreeSql (二十)多表查询 WhereCascade
			WhereCascade 多表查询时非常方便,有了它可以很轻松的完成类型软删除,租户条件的功能. IFreeSql fsql = new FreeSql.FreeSqlBuilder() .UseCo ... 
