1

我不知道为什么 update() 方法不适用于 ORACLE 数据库

deleteQuery = "delete from USBRPF where upper(userid) = upper(?)" ;

String s= "ABC " ;
getJdbcTemplate().update(deleteQuery, s.trim());

有一行 USERID 列具有数据“ABC”(“C”字符后有一些空格字符)

它似乎没有找到那一行。

但是,如果我将代码更改为下面,它可以工作

deleteQuery = "delete from USBRPF where upper(userid) like upper(?)" ;
String s= "ABC " ;
getJdbcTemplate().update(deleteQuery, s.trim() +  "%");

或者

deleteQuery = "delete from USBRPF where upper(trim(userid)) = upper(?)" ;
String s= "ABC " ;
getJdbcTemplate().update(deleteQuery, s.trim());

注意:所有都适用于 MSSQL 数据库,数据从 ORACLE 迁移。估计是数据库设置有问题。有人能弄清楚吗?谢谢

修改的:

栏目信息:

甲骨文

  BRANCH    CHAR(2 CHAR)          
  COMPANY   CHAR(1 CHAR)         
  DATIME    TIMESTAMP(6)          
  JOBNM CHAR(10 CHAR)          
  UNIQUE_NUMBER NUMBER(18,0)    
  USERID    CHAR(10 CHAR)         
  USRPRF    CHAR(10 CHAR)    

微软SQL

[UNIQUE_NUMBER] [bigint] IDENTITY(1,1) NOT NULL,    
[USERID] [nchar](10) NULL,  
[COMPANY] [nchar](1) NULL,  
[BRANCH] [nchar](2) NULL,   
[USRPRF] [nchar](10) NULL,  
[JOBNM] [nchar](10) NULL,   
[DATIME] [datetime2](6)> NULL,
4

1 回答 1

1

CHAR 是固定长度类型。因此,即使您的数据在数据库中看起来像“ABC”,它也会存储为“ABC”。CHAR 列将被填充其大小的空格

因此,在第一个示例中,您将“ABC”(存储在数据库中)与“ABC”(在 trim() 调用后从 Java 传递)进行比较。在您的第二个和第三个示例中,您正在解决这个问题。

我建议您使用 VARCHAR2,因为它更自然且更常用。如果不可能,您可以尝试将您从 Java 传递的值填充到 Oracle 中定义的 CHAR 大小。

于 2013-01-15T16:35:53.980 回答