IT忍者神龟之中的一个句sql语句——连接同一字段的全部值
Oracle能够用SYS_CONNECT_BY_PATH字符串聚合函数:
SELECT LTRIM(MAX(SYS_CONNECT_BY_PATH(productname, ', ')), ', ') AS productname
FROM(
SELECT '1' as id, productname,
ROW_NUMBER() OVER (PARTITION BY '1' ORDER BY productname) AS curr,
ROW_NUMBER() OVER (PARTITION BY '1' ORDER BY productname) -1 AS prev
FROM products
-- where 条件
order by productname
)
START WITH curr = 1
CONNECT BY prev = PRIOR curr AND id = PRIOR id
GROUP BY id 但MS SQL 2000没有这样的函数,但能够通过自己定义函数或过程来实现.
-- drop function ConnectString
Create FUNCTION ConnectString( @name varchar(20) )
RETURNS varchar(1024)
AS
BEGIN
declare @Str varchar(1024)
set @Str = ''
select @Str = @Str + (case when @Str = '' then '' else ',' end) + [productname] from products
--where [productname] = @name
return @Str
END
GO -- 调用
select DISTINCT dbo.ConnectString(productname) from products SQL Server 2005 可用OUTER APPLY:
下面是从网上摘录的:
-- 演示样例数据
DECLARE @t TABLE(id int, value varchar(10))
INSERT @t SELECT 1, 'aa'
UNION ALL SELECT 1, 'bb'
UNION ALL SELECT 2, 'aaa'
UNION ALL SELECT 2, 'bbb'
UNION ALL SELECT 2, 'ccc' -- 查询处理
SELECT *
FROM(
SELECT DISTINCT
id
FROM @t
)A
OUTER APPLY(
SELECT
[values]= STUFF(REPLACE(REPLACE(
(
SELECT value FROM @t N
WHERE id = A.id
FOR XML AUTO
), '<N value="', ','), '"/>', ''), 1, 1, '')
)N /*--结果
id values
----------- ----------------
1 aa,bb
2 aaa,bbb,ccc
(2 行受影响)
--*/
2 Admin/ adminY/ 刘超楠/ 张伟如/ 单慧慧/
3 王亦平/ 靳麟/ 杨婧/ 运营管理部资产管理员/ 刘婷/ 钟媛/ 杜佳凝/
4 分行营业部电脑管理员A角/ 分行营业部电脑管理员B角/ 张婷婷/ 反洗钱301/ 信贷综合301/ 陈光/ 蒋喆/ 安静/ 个贷接单301/ 单立伟/ 孙晴/ 分行营业部资产管理员/ 方正/ 李晨/ 营业部企划联系人/ 李燚/
5 李娟/ 神华支行电脑管理员A角/ 神华支行电脑管理员B角/ 王国萍/ 反洗钱302/ 信贷综合302/ 张喆/ 周小舟/ 个贷接单302/ 王兆圆/ 神华支行资产管理员/ 杨厚玮/ 神华企划联系人/
6 安华支行电脑管理员A角/ 安华支行电脑管理员B角/ 魏红/ 反洗钱303/ 信贷综合303/ 陈盈/ 许越昆/ 陈醒/ 宛霞/ 个贷接单303/ 花园路支行资产管理员/ 乔曦/ 程瑶/ 花园路企划联系人/
7 西三环支行电脑管理员B角/ 西三环支行电脑管理员A角/ 张永风/ 反洗钱304/ 信贷综合304/ 邓立/ 个贷接单304/ 张纪洪/ 龚鑫/ 李冬冬(304)/ 崔佳/ 西三环支行资产管理员/ 周琪/ 李菲/ 西三环企划联系人/ 张鑫/
8 董钧玉/ 中关村支行电脑管理员B角/ 中关村支行电脑管理员A角/ 李鑫/ 反洗钱305/ 信贷综合305/ 个贷接单305/ 徐文文/ 旦蕊/ 中关村支行资产管理员/ 贾晋平/ 张莹01/ 车帅/ 中关村企划联系人/
IT忍者神龟之中的一个句sql语句——连接同一字段的全部值的更多相关文章
- 使用ODP.NET一次执行多句SQL语句
在实际开发的时候有的时候希望一次执行多句SQL语句,又不想使用Transcation的话,可以直接将多句SQL语句拼接起来.例如: var sql = "Begin " + &qu ...
- 用一句sql语句更新两个表并可更新对应的字段的值
ACCESS 例子: insert into products (ProNumber,CASNumber,Cnname,Price,Enname,Baozhuang,Pinpai) select Pr ...
- 我和小美的撸码日记(3)之中的一个句话搞定MVC表单页数据绑定与提交
另外献上在<线体验Demo地址>希望大家也能从中得到一些启示. 地址:http://121.40.148.178:8080/ . username:guest,password:12345 ...
- tp5中很牛皮的一句sql语句,三个条件(两个不确定条件,一个硬性条件)
$result = Db::table('xxxxxx') // 表名 ->alias('g') ->join('xxxxx_2 u','g.user_id = u.id') -> ...
- select count(1) from table where ..这句sql语句的作用
作用是计算一共有多少符合条件的行.1并不是表示第一个字段,而是表示一个固定值,count(1)和count(2)效果是一样的 count(*),执行时会把星号翻译成字段的具体名字,效果也是一样的,不过 ...
- Mysql Sql语句令某字段值等于原值加上一个字符串
MySQL连贯字符串不能利用加号(+),而利用concat. 比方在aa表的name字段前加字符'x',利用: update aa set name=concat('x',name); 替换: UPD ...
- 写sql语句连接的时候注意的一个小细节
我在写权限的查询的时候,用到了sql语句的链接写一下出错的时候的代码 $sqlpid="select auth_name from sw_auth where auth_level=0&qu ...
- 同样的一句SQL语句在pl/sql 代码块中count 没有数据,但是直接用SQl 执行却可以count 得到结果
pl/sql 代码块: SELECT count(distinct t2.so_nbr) INTO v_count2 FROM KFGL_YW_STEP_qd t2 WHERE t2.partitio ...
- 一个表的两个列连接另外一个表的一个列SQL语句怎么写
f619424517 | 浏览 2207 次 推荐于2016-09-09 11:38:18 最佳答案 select a.flightid,a.flightname,b.cityname,c.c ...
随机推荐
- 安装基于XenServer的DevStack
Openstack默认的hypervisior是基于KVM的,可以修改nova-compute.conf的libvirt_type改成使用其他,网上可以搜到个别文章 但是Openstack官方文档却说 ...
- SQLyog 注册码
用户名: 随意填写 秘钥: ccbfc13e-c31d-42ce-8939-3c7e63ed5417a56ea5da-f30b-4fb1-8a05-95f346a9b20ba0fe8645-3916- ...
- BZOJ 2743: [HEOI2012]采花( 离线 + BIT )
处理出每个数下一个出现的位置, 然后按左端点排序回答询问.处理当前数去除的影响 ------------------------------------------------------------ ...
- BZOJ 1475: 方格取数( 网络流 )
本来想写道水题....结果调了这么久!就是一个 define 里面少加了个括号 ! 二分图最大点权独立集...黑白染色一下 , 然后建图 : S -> black_node , white_no ...
- saltstack:使用教程之一安装及客户端返回写入MySQL
saltstack使用教程: 1.安装: 需要epel的yum源,没有的话把下面的复制并新建个文件 /etc/yum.repos.d/epel.repo 粘贴即可: [epel] name=Extra ...
- 04-Foundation-NSSet、NSDictionary、block
目录: 一.NSSet集合 二.NSDictionary字典 三.block代码块 回到顶部 一.NSSet集合 1 NSSet是一个无序的,管理对个对象的集合类,最大特点是集合中不允许出现重复对象, ...
- WCF技术剖析之二十七: 如何将一个服务发布成WSDL[编程篇]
原文:WCF技术剖析之二十七: 如何将一个服务发布成WSDL[编程篇] 对于WCF服务端元数据架构体系来说,通过MetadataExporter将服务的终结点导出成MetadataSet(参考< ...
- EF+jQueryUI前后端分离设计
开源项目练习EF+jQueryUI前后端分离设计 最近大家流行把项目开源,我也来玩玩.只是开源公司项目不好,小弟只好从公司项目经验上另外弄出一套练习开源给大家. 这个项目可以做简单的团队任务系统( ...
- asp.net 通过 Handler 导出数据至excel (让用户下载)
效果图: 代码: Export2Excel.ashx <%@ WebHandler Language="C#" CodeBehind="Export2Excel.a ...
- JIRA初步
JIRA 是澳大利亚 Atlassian 公司开发的一款优秀的问题跟踪管理软件工具.可以对各种类型的问题进行跟踪管理.包含缺陷.任务.需求.改进等.JIRA採用J2EE技术.可以跨平台部署.它正被广泛 ...