免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 3171 | 回复: 8
打印 上一主题 下一主题

在Oracle里怎么删除字符串中的第N个字符 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2004-02-15 12:20 |只看该作者 |倒序浏览
在Oracle里怎么删除字符串中的第N个字符


急,急,急

论坛徽章:
0
2 [报告]
发表于 2004-02-15 12:40 |只看该作者

在Oracle里怎么删除字符串中的第N个字符

在字段name中有一个值为happiy
我在用select name from aa where name='happiy'时最好能显示happy,而又没有修改数据库中的happiy

论坛徽章:
0
3 [报告]
发表于 2004-02-15 13:49 |只看该作者

在Oracle里怎么删除字符串中的第N个字符

select replace(name,'i','') from aa where name='happiy';

论坛徽章:
0
4 [报告]
发表于 2004-02-16 22:42 |只看该作者

在Oracle里怎么删除字符串中的第N个字符

这样不行,我要删除一个空格,在这个字段后面有N个空格,由于oracle的bug,我在用rpad导致在某些中文后面会多一个空格,例如:rpad (我,30,' '),在"我"的后面应该有28空格,但在某些中文后面会有29个空格,导致长度为31,所以我要删掉第31个空格,请高手指教,谢谢

论坛徽章:
0
5 [报告]
发表于 2004-02-16 23:04 |只看该作者

在Oracle里怎么删除字符串中的第N个字符

substr(val,1,n-1) || substr(val,n+1)

论坛徽章:
0
6 [报告]
发表于 2004-02-16 23:05 |只看该作者

在Oracle里怎么删除字符串中的第N个字符

有中文的好象要用substrb

论坛徽章:
0
7 [报告]
发表于 2004-02-17 15:45 |只看该作者

在Oracle里怎么删除字符串中的第N个字符

就是oracle对中文支持有问题,用rpad(我,30,' ')时,对某些中文会多一个空格,所以我要删除第31个空格,请赐教,谢谢

论坛徽章:
0
8 [报告]
发表于 2004-02-17 16:01 |只看该作者

在Oracle里怎么删除字符串中的第N个字符

SQL>; select substr(rpad('我',30,' '),1,30)||'31' from dual;

SUBSTR(RPAD('我',30,''),1,30)||'31'
--------------------------------
我                            31
用substr截取前30位能满足你的要求吗?

论坛徽章:
0
9 [报告]
发表于 2004-02-17 17:15 |只看该作者

在Oracle里怎么删除字符串中的第N个字符

我也用这个函数,很奇怪,这个空格跑到最后一个去了,不能载取,一定要删
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP