Sql过滤有空格的数据

目的: 过滤某个字段中含有空格的数据。比如:字段name中有数据“nick zhang”, “nickZhang”,我想选出“nick zhang”。

常见做法:

使用charindex()函数:
select name from testUser where charindex(‘ ‘, name) > 0;

原理:使用charindex()判断当前的name是否包含空格。

Code:
Create table testUser (name nvarchar(2000));
insert into testUser values('nick zhang');
insert into testUser values('nickZhang');
-- filter data with space
select name from testUser where charindex(' ', name) > 0;

Result:
name
1. nick zhang

如果需求变为要将所有空格都去掉,那么可以使用

replace()函数: 用第三个表达式替换第一个字符串表达式中出现的所有第二个给定字符串表达式。

REPLACE ( 'string_expression1' , 'string_expression2' , 'string_expression3' )

select name= REPLACE(name, ' ', '') from testUser;

Result:
name
1. nickzhang
2. nickZhang

转载自:http://zhangyue.info/2011/07/sql%e8%bf%87%e6%bb%a4%e6%9c%89%e7%a9%ba%e6%a0%bc%e7%9a%84%e6%95%b0%e6%8d%ae/

转载于:https://www.cnblogs.com/TonnyGu/archive/2011/09/02/2163292.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值