我不知道为什么 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,