sqlserver模仿mysql函数FIND_IN_SET,group_concat的功能

一、判断某个逗号隔开的字段中有某个值

FIND_IN_SET(‘a‘,‘a,b,c,d‘) 用 CHARINDEX(‘,‘+‘b‘+‘,‘ , ‘,‘+‘a,b,c‘+‘,‘) > 0 替代

二、模仿mysql的group_concat的示例

SELECT id,     
       val=( SELECT [value] +‘,‘     
               FROM tb AS b     
               WHERE b.id = a.id
               FOR XML PATH(‘‘)  )     
FROM tb AS a      
GROUP BY id
SELECT id,     
       [val]=STUFF( (SELECT ‘,‘+[value]     
                     FROM tb AS b     
                     WHERE b.id = a.id     
                     FOR XML PATH(‘‘)) , 1 , 1 , ‘‘ )    
FROM tb AS a      
GROUP BY id
--删除、创建临时表
drop table #table1;
select * into #table1
from (
SELECT myId,‘auto‘ as type
)allData
--把数据按myId分类链接,然后按链接后数据的长度倒序排序
select * from (
  select myId,
  val=STUFF( (SELECT ‘、‘+type     
                     FROM #table1 AS b     
                     WHERE b.myId = ta.myId     
                     FOR XML PATH(‘‘)) , 1 , 1 , ‘‘ )
  from #table1 ta
  group by myId
) dd order by LEN(val) desc
时间: 2024-12-19 21:42:33

sqlserver模仿mysql函数FIND_IN_SET,group_concat的功能的相关文章

Mysql函数FIND_IN_SET()的使用方法

有了FIND_IN_SET这个函数.我们可以设计一个如:一只手机即是智能机,又是Andriod系统的. 比如:有个产品表里有一个type字段,他存储的是产品(手机)类型,有 1.智能机,2.Andriod系统,3.小米系统,4.1000元以下 现在有条手机的记录即是1000元以下的,又是智能机,还是Andriod的系统. type中以 4,1,2的格式存储. 那们我们如何用sql查找所有type中有4的1000元以下的手机呢, 这就要我们的find_in_set出马的时候到了. 先看MySQL手

MySQL函数之group_concat()

group_concat() 该函数返回带有来自一个组的连接的非NULL值的字符串结果. 示例: SELECT id,GROUP_CONCAT(item) AS items FROM tab GROUP BY id id  items --  ----------- 1  a,b 2  c 3  d,e,f

coding++ :MySQL函数——FIND_IN_SET()

语法:FIND_IN_SET(str,strlist) 定义: 1). 假如字符串 str 在由N子链组成的字符串列表 strlist 中,则返回值的范围在1到N之间. 2). 一个字符串列表就是一个由一些被‘,’符号分开的自链组成的字符串. 3). 如果第一个参数是一个常数字符串,而第二个是typeSET列,则FIND_IN_SET()函数被优化,使用比特计算. 4). 如果 str 不在 strlist 或 strlist 为空字符串,则返回值为 0. 5). 如任意一个参数为 NULL,则

mysql中find_in_set()函数的使用

首先举个例子来说: 有个文章表里面有个type字段,它存储的是文章类型,有 1头条.2推荐.3热点.4图文等等 .现在有篇文章他既是头条,又是热点,还是图文,type中以 1,3,4 的格式存储.那我们如何用sql查找所有type中有4的图文类型的文章呢?? 这就要我们的 find_in_set 出马的时候到了.以下为引用的内容: select * from article where FIND_IN_SET('4',type) ---------------------------------

SQLServer 中实现类似MySQL中的group_concat函数的功能

SQLServer中没有MySQL中的group_concat函数,可以把分组的数据连接在一起. 后在网上查找,找到了可以实现此功能的方法,特此记录下. SELECT a, stuff((SELECT ',' + b FROM #tb WHERE a = t.a FOR xml path('')), 1, 1, '' )AS b from  # tb AS t GROUP BY a; 先对a列进行分组,对分组中的b以Xml形式输出,再使用stuff将开关多出的,删掉. 具体实现参考:http:/

Mysql中关于 group_concat函数详解

group_concat()主要功能:能将相同的行组合起来 完整的语法如下: group_concat([DISTINCT] 要连接的字段 [Order BY ASC/DESC 排序字段] [Separator '分隔符']) 基本查询 Sql代码   select * from aa; +------+------+| id| name |+------+------+|1 | 10||1 | 20||1 | 20||2 | 20||3 | 200 ||3 | 500 |+------+---

Mysql字符串函数FIND_IN_SET()的两点用法

概要:该可以查询用逗号分割的字段,以及对结果进行强制排序 首先看一张表: colid vyear area cast ,31,32,21,12 2014 1 15 ,32,33,34,35,21, 2014 2 16 ,33,34,36,39,40 2011 3 17 表中的colid字段的值是以逗号分割, 当我们需要查询这张表中,colid含有32的行, 那么可以用FIND_IN_SET() SQL如下: SELECT * FROM table WHERE FIND_IN_SET('32',

mysql 的 find_in_set函数使用方法

举个例子来说:有个文章表里面有个type字段,他存储的是文章类型,有 1头条,2推荐,3热点,4图文 .....11,12,13等等 现在有篇文章他既是 头条,又是热点,还是图文, type中以 1,3,4的格式存储. 们我们如何用sql查找所有type中有4图文标准的文章呢?? 这就要我们的find_in_set出马的时候到了. 以下为引用的内容: select * from article where FIND_IN_SET('4',type) -----------------------

关于mysql函数GROUP_CONCAT

GROUP_CONCAT()是MySQL数据库提供的一个函数,通常跟GROUP BY一起用,具体可参考MySQL官方文挡:http://dev.mysql.com/doc/refman/5.0/en/group-by-functions.html#function_group-concat. 语法: GROUP_CONCAT([DISTINCT] expr [,expr ...] [ORDER BY {unsigned_integer | col_name | expr} [ASC |DESC]