【SQL分享】根据字符分割字符串的最好的写法【经典】

本文介绍了如何通过SQL操作将数据库中以逗号分隔的数据以表格形式展示,并通过示例代码进行说明。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

 

因数据库中保存的是以,号分隔的数据,需要在界面上以表格的方式显示出来。

特想出以下方法。

知识点:

1、拼接SQL

2、UNION ALL

3、EXEC

 

其代码如下:

--测试示例
declare @sql varchar(2000),@tsql nvarchar(max),@split varchar(100)
set @sql='A,B,C,D,E' --保存的字符

set @split=','--分隔符
select @tsql='select '''+replace(@sql,@split,''' union all select ''')+''''
exec(@tsql)
 

显示结果:

----
A
B
C
D
E

(5 行受影响)

 

### SQL 中检查字段值是否包含指定子串 在不同的数据库管理系统中,可以采用多种方式来实现这一功能。 #### MySQL 使用 `FIND_IN_SET` 函数 对于逗号分隔的列表形式的数据,MySQL 提供了专门用于此类情况下的函数——`FIND_IN_SET()`。此函数用来检测某个特定字符串是否存在于由逗号分割的一系列值之中[^1]。 ```sql SELECT * FROM users WHERE FIND_IN_SET('aa@email.com', emails); ``` #### HiveSQL 的解决方案 HiveSQL 支持通过内置函数 `LOCATE()` 来定位给定模式首次出现的位置。当目标字符串存在时会返回其索引位置(从1开始),反之则给出0表示未找到该字符串[^2]。 ```sql SELECT * FROM temp WHERE LOCATE("aaa", name) > 0; ``` 另外,在HiveSQL里还可以利用正则表达式来进行匹配操作或是简单的通配符查询: - 正则表达式的写法如下所示: ```sql SELECT '32002,32002,11001,11001,' REGEXP('.*2.*'); ``` - 或者使用 LIKE 关键字配合百分号 `%`作为任意数量字符占位符完成模糊搜索任务: ```sql SELECT '32002,32002,11001,11001,' LIKE '%2%'; ``` #### 标准 SQL 方案 除了上述两种针对具体DBMS特性的做法之外,标准SQL也提供了通用的方式来处理这个问题,即运用LIKE运算符加上合适的通配符组合即可达成目的。例如要在一个表名为table_name且列名为column_name的情况下寻找含有"value"这个单词的所有记录,则可执行下面这条语句: ```sql SELECT * FROM table_name WHERE column_name LIKE '%value%'; ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值