跳到内容

解决Oracle中CHAR类型数据中空格问题的方法是什么?

更新时间
快连VPN:速度和安全性最佳的VPN服务
快连VPN:速度和安全性最佳的VPN服务

有什么方法能将oracle中CHAR类型数据中的空

可以用脚本把CHAR类型字段全部转换成VARCHAR2类型,同时截掉字符串的空格,如下:

declare

begin

for c in (select *

from user_tab_columns t1

where t1.DATA_TYPE = 'CHAR'

) loop

execute immediate 'alter table ' || c.table_name || ' add g_w_' || c.column_name || ' varchar2(' || c.char_length || ')';

execute immediate 'update ' || c.table_name || ' set g_w_' || c.column_name || ' = ' || c.column_name;

execute immediate 'update ' || c.table_name || ' set ' || c.column_name || ' = null';

execute immediate 'alter table ' || c.table_name || ' modify ' || c.column_name || ' varchar2(' || c.char_length || ')';

execute immediate 'update ' || c.table_name || ' set ' || c.column_name || ' = trim(g_w_' || c.column_name || ')';

execute immediate 'alter table ' || c.table_name || ' drop column g_w_' || c.column_name;

end loop;

end;

如何去除Oracle库表结构中的类空格字符

1.首先是去除空格在进行比较(比如,把姓名中的所有空格去除):

Update table_name set xm=replace(xm , ' ') ;

如果要查找哪些记录含有' ',可用相关的语句查找。

然后可进行比较。

2.但是我们可能会发现,有些姓名中间或末尾还有类似空格的字符没被去掉,但它们显然已经不是一般的空格了,那么怀疑是Tab健作怪。于是参照网上说的去掉TAB键的办法来处理,用chr(9)来替代空格键(TAB键的ASCII值为9)。先取一条带有类空格字符的记录来做实验:

SELECT replace(xm, chr(9) ) from table_name where;

用这个办法会去掉一些真正的Tab键空格,然后采取批量更新的办法。

3.但我遇到的情况没有这么幸运,没能去掉类空格键。怎么办呢?我决定尝试先取得这个类空格键的ASCII码值,然后再用chr(ASCII码值)的方法来处理。

①.取得含类空格键整个字符串的长度 length(),从而确定出类空格键在字符串中的起始位置、类空格键的长度。

②.出类空格键的ASCII码值:ascii(substr(xm,n,m)); n为类空格键的起始位置;m为长度。

③.SELECT replace(xm, chr(第②步得的ASCII码值) ) from table_name where;

问题得以解决。但我发现,上述第②步得的ASCII码值为41377,这应该是一个汉字的ASCII码值,看起来又像空格,于是我怀疑,会不会是中文状态下的空格键、TAB键?尝试之后发现不是。我又怀疑,是不是全角、半角的区别?因为我们一般输入字符,是在半角下输入的。我按照第一步“1.首先是去除空格在进行比较……”尝试,输入全角下的空格,进行查找,结果惊喜出现,原来所有未剔除掉的类空格,是全角状态下输入的空格,并接证实了全角下输入的空格,其ASCII码值为41377。

以上就是解决Oracle中CHAR类型数据中空格问题的方法是什么?的详细内容,更多请关注本站其它相关文章!

更新时间

发表评论

请注意,评论必须在发布之前获得批准。