一个字段 sa,asdf,asdf,asdf怎么用SQL查找出里面有几个逗号?

lei19890721 2009-10-12 03:03:02
谢了
...全文
128 9 打赏 收藏 转发到动态 举报
写回复
用AI写文章
9 条回复
切换为时间正序
请发表友善的回复…
发表回复
chen_ya_ping 2009-10-12
  • 打赏
  • 举报
回复
[Quote=引用 3 楼 jiangshun 的回复:]
SQL codedeclare@svarchar(200)set@s='sa,asdf,asdf,asdf'selectlen(@s)-len(replace(@s,',',''))/*

-----------
3

(所影响的行数为 1 行)*/
[/Quote]
good
Hide1984 2009-10-12
  • 打赏
  • 举报
回复
三楼的学习一个。
确实好办法。
zjybushiren88888 2009-10-12
  • 打赏
  • 举报
回复
3楼的学习个
SK_Aqi 2009-10-12
  • 打赏
  • 举报
回复
[Quote=引用 3 楼 jiangshun 的回复:]
SQL codedeclare@svarchar(200)set@s='sa,asdf,asdf,asdf'selectlen(@s)-len(replace(@s,',',''))/*

-----------
3

(所影响的行数为 1 行)*/
[/Quote]
这也是一个好方法,把,替换掉然后减去长度
tkscascor 2009-10-12
  • 打赏
  • 举报
回复
hehe 三楼 好简洁.
moduofanchen 2009-10-12
  • 打赏
  • 举报
回复
Up
jiangshun 2009-10-12
  • 打赏
  • 举报
回复

declare @s varchar(200)
set @s='sa,asdf,asdf,asdf'
select len(@s)-len(replace(@s,',',''))

/*

-----------
3

(所影响的行数为 1 行)

*/
Hide1984 2009-10-12
  • 打赏
  • 举报
回复
运行结果12
Hide1984 2009-10-12
  • 打赏
  • 举报
回复

DECLARE @count INT
DECLARE @cursor INT
DECLARE @string NVARCHAR(2000)
DECLARE @char NVARCHAR(1)
SET @count = 0
SET @cursor = 0
SET @string = ',,,as,asd,asdf,assss,wewe.,asd,,,,'
SET @char = ','
WHILE (CHARINDEX(@char,@string)>0)
BEGIN

Set @cursor = CHARINDEX(@char,@string)
SET @string = SUBSTRING(@string,@cursor+1,LEN(@string)-@cursor);
SET @count = @count+1;
END
PRINT @count

62,072

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术交流专区
javascript云原生 企业社区
社区管理员
  • ASP.NET
  • .Net开发者社区
  • R小R
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

.NET 社区是一个围绕开源 .NET 的开放、热情、创新、包容的技术社区。社区致力于为广大 .NET 爱好者提供一个良好的知识共享、协同互助的 .NET 技术交流环境。我们尊重不同意见,支持健康理性的辩论和互动,反对歧视和攻击。

希望和大家一起共同营造一个活跃、友好的社区氛围。

试试用AI创作助手写篇文章吧