MYSQL语句中有空格如何解决?

UPDATEcdb_postsSETmessage=REPLACE(message,'123456','1234')wheretid=123456;这个替换语句中需要替换... UPDATE cdb_posts SET message=REPLACE(message,'123 456','1234') where tid=123456;

这个替换语句中需要替换的内容有空格,请问该怎么处理呢?
但事实上我执行这个语句了,123 456并没有替换成1234
展开
 我来答
奔驰M888
2009-07-30 · TA获得超过1.1万个赞
知道大有可为答主
回答量:1846
采纳率:0%
帮助的人:2708万
展开全部
1、首先replace函数可以做到替换【'123 456'】为【'1234'】,测试log如下:

mysql> select replace('123 456','123 456','1234');
+-------------------------------------+
| replace('123 456','123 456','1234') |
+-------------------------------------+
| 1234 |
+-------------------------------------+
1 row in set (0.05 sec)

2、如果你想去掉【message】中的所有空格的话
【replace(message,' ','')】就可以的。测试log如下:

mysql> select replace('1 2 3 4 5 6',' ','');
+-------------------------------+
| replace('1 2 3 4 5 6',' ','') |
+-------------------------------+
| 123456 |
+-------------------------------+
1 row in set (0.00 sec)

3、所以你的sql改成下面这样就可以了应该:
UPDATE cdb_posts SET message=REPLACE(message,' ','') where tid=123456;

4、改完了记住commit,使改正永久话。

---
以上,希望对你有所帮助。
阳光上的桥
2009-07-30 · 知道合伙人软件行家
阳光上的桥
知道合伙人软件行家
采纳数:21423 获赞数:65813
网盘是个好东东,可以对话和传文件

向TA提问 私信TA
展开全部
你的这个语句能够执行,能够把"123 456"替换为"1234",包括空格一起被替换掉。

莫非你还有其它要求吗?

参考资料:  

已赞过 已踩过<
你对这个回答的评价是?
评论 收起
hemu780924
2009-07-30 · TA获得超过662个赞
知道小有建树答主
回答量:495
采纳率:0%
帮助的人:524万
展开全部
UPDATE cdb_posts SET message=REPLACE(message,'123 456','1234') where replace(tid,' ','')=123456
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
百度网友a800768
2009-07-30 · TA获得超过1841个赞
知道大有可为答主
回答量:1928
采纳率:0%
帮助的人:1729万
展开全部
select * from cdb_posts where tid=123456

看看查询结果中的message值
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(2)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式