SQL> create table a1(id int,name char(10));
Table created.
SQL> create table a2(id int,name char(10));
Table created.
SQL> insert into a1 values(1,'a');
1 row created.
SQL> commit;
Commit complete.
SQL> insert into a2 values(100,'a'||CHR(13));
1 row created.
SQL> select dump(name) from a1;
DUMP(NAME)
--------------------------------------------------------------------------------
Typ=96 Len=10: 97,32,32,32,32,32,32,32,32,32
SQL> select length(name) from a1;
LENGTH(NAME)
------------
10
SQL> select dump(name) from a2;
DUMP(NAME)
--------------------------------------------------------------------------------
Typ=96 Len=10: 97,13,32,32,32,32,32,32,32,32
SQL> select length(name) from a2;
LENGTH(NAME)
------------
10
SQL> select * from a1,a2
2 where a1.name=a2.name;
no rows selected
SQL> select * from a1,a2
2 where a1.name=replace(a2.name,CHR(13),'');
no rows selected
看来char 用这种方式是没法替换回车符的,原因:
SQL> select length(replace(a2.name,CHR(13),'')) from a2;
LENGTH(REPLACE(A2.NAME,CHR(13),''))
-----------------------------------
9
变成9位了,当然和a1.name 10位关联不上
SQL> select * from a1,a2 2 where a1.name=replace(a2.name,CHR(13),CHR(32)); ID NAME ID NAME---------- ---------- ---------- ---------- 1 a 100 aSQL> select * from a1,a2 2 where a1.name=replace(a2.name,CHR(13),''||' ');ID NAME ID NAME---------- ---------- ---------- ---------- 1 a 100 a需要在补上一个空格