用SQL怎么把一列所有字符串中包含的空格都删除呢

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了用SQL怎么把一列所有字符串中包含的空格都删除呢相关的知识,希望对你有一定的参考价值。

用SQL怎么把一列所有字符串中包含的空格都删除呢 如 :姓 名 三角形 性 别 把姓 名和性 别中间的空格都删掉 谢谢

参考技术A 用REPLACE函数,把空格替换成
''。
例:去除
表table

col
列的空字符
去除空格符:update
table
set
col
=
REPLACE(col,'
','')
还有tab制表符(即char(9)),显示效果类似空格。
去除制表符:update
table
set
col
=
REPLACE(col,CHAR(9),'')
参考技术B LTRIM()去掉字符串前面的空格
select
ltrim(site_name)
from
site
RTRIM()去掉字符串后面的空格
select
rtrim(site_name)
from
site
嵌套使用这两个函数可以去掉字符串前后的空格
select
ltrim(rtrim(site_name))
from
site
如果想去掉字符串中间的字符,则可以使用replace(),
例如要去掉“字符
串”中间的空格,如下:
replace(
'
字符
串','
','')

oracle语句中如何把一列的值合并为一个值,用逗号隔开?

select Name from User;
我想把Name的值合并成一个值,用逗号隔开。
例如:张三,李四,王五
请问该怎么做?
谢谢。

所有版本的oracle都可以使用wm_concat()函数 。例:select wm_concat(name) as name from user;

但如果是oracle11g,使用listagg() within group()函数 。例:select listagg(name, ‘,’) within group( order by name) as name from user;

使用wm_Concat:

使用ListAgg:

结果:

参考技术A 所有版本的oracle都可以使用select wm_concat(name) as name from user;
但如果是oracle11g,使用select listagg(name, ',') within group( order by name) as name from user;
效率更高,官方也更推荐这种写法。追问

wm开头的函数代表什么意思?
wm本身代表什么含义,是什么的缩写?
oracle的扩展函数的手册啥的叫什么名字?
或者说我上哪里去下载?

追答

在oracle中有一个wmsys用户,这个用户和sys,system等用户一样,是oracle安装的时候就创建的,主要负责oracle日常工作的管理(WM:work manager),wm开头的函数是这个用户下的函数。
oracle的函数介绍在oracle的官方网站上就有,
由于百度知道不让发网址,你可以在百度上搜索listagg,搜索出来的第三项有oracle的网址就是官方的函数介绍的网站,你可以再继续看别的函数的介绍,只不过它的分类是按照功能来分的,而且都是英文的,想看某个函数的话并不太好找。

本回答被提问者采纳
参考技术B select wm_concat(name) name from user;--10g写法
select listagg(name,',') within group (order by name) name from user;--11g写法追问

wm开头的函数代表什么意思?
wm本身代表什么含义,是什么的缩写?
oracle的扩展函数的手册啥的叫什么名字?
或者说我上哪里去下载?

以上是关于用SQL怎么把一列所有字符串中包含的空格都删除呢的主要内容,如果未能解决你的问题,请参考以下文章

oracle语句中如何把一列的值合并为一个值,用逗号隔开?

sql 里 怎么把一列的值合并成一个字符串

excel中能否将一列数据分成多列?

在sql中有个表a,有一列名为b的数据如bb,后面有几个空格,所以数据都是,怎么批量删除数据后面的空格?

怎么用excel把一列变成两列

sql语句:怎么把一列表里面包含某个字符都改成另外一个字符,就像word里面的替换功能一样的语句