java对ORACLE中的于NCHAR数据的处理,查询

nchar 数据如果指定了长度,如果数据不满指定的位数,将会在后面补空格。
所以当你使用 jdbc 或者其他框架以该字段作为查询条件时,形成的 sql 也会自动补空格
如:

1
SELECT FROM marketing_menu WHERE CDMC = “TEST ”

  



由于存在空格,查询的时候会出错。
正确书写方式去除空格:

1
SELECT FROM marketing_menu WHERE trim(' ' from CDMC) = ‘Test’

  

由于历史原因,当初设计这个表结构的人走了,代码有php转java,发现nchar无论如何查询不到,于是采用上面方法
亲测有效:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
<select id="selectByOidOrHoid" parameterType="java.lang.String"  resultMap="BaseResultMap">
       select
       <include refid="Base_Column_List" />
       from WX_PAY_LOG
       where
       ESTATE = 1
       <if test="oid != null" >
           and trim(' ' from OID) = #{oid}
       </if>
       <if test="hoid != null" >
           and HOID= #{hoid}
       </if>
       order by MTIME
   </select>

  

【转】https://blog.csdn.net/jacxuan/article/details/78780921

 

posted @   穆晟铭  阅读(454)  评论(0编辑  收藏  举报
编辑推荐:
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
阅读排行:
· 周边上新:园子的第一款马克杯温暖上架
· Open-Sora 2.0 重磅开源!
· 分享 3 个 .NET 开源的文件压缩处理库,助力快速实现文件压缩解压功能!
· Ollama——大语言模型本地部署的极速利器
· DeepSeek如何颠覆传统软件测试?测试工程师会被淘汰吗?
历史上的今天:
2015-04-15 listview去掉底部多出的边框黑色
2015-04-15 使用fragmenttabhost后,子fragment怎么获取ID?怎么用getSharedPreferences
点击右上角即可分享
微信分享提示