Oracle数据库中NARCHAR转换成NUMBER类型

1.修改后的代码:

    public void addDirectorActorKeyword(long idStart, long idEnd) {
        SeriesMgr seriesMgr = new SeriesMgr();
        String strCondition = "";
        List<Comparable> paramlist = new ArrayList<Comparable>();
        List<Series> seriesList = new ArrayList<Series>();
        if(idStart != 0 && idEnd != 0){
            //以下两种sql方式都可以...Series表中parentmmobjectid为NVARCHAR2类型,不能使用直接使用between and
            //strCondition = "  to_number(parentmmobjectid) between ? and ? ";
            strCondition = "  parentmmobjectid between to_number(?) and to_number(?) ";
            paramlist.add(idStart);
            paramlist.add(idEnd);
            seriesList = seriesMgr.find(strCondition, paramlist,"parentmmobjectid asc");
        } 
        ********
    }

直接执行sql语句是可以正常查询到内容的,上面代码对应Hibernate翻译成的sql语句是 select * from series where parentmmobjectid between '11111'  and '99999';可以正常的的查询到内容.

但是通过Hibernate进行查询,对应的如果是strCondition = "  parentmmobjectid between ? and ? "; 就查询不到...

原因就是在设置表字段的时候parentmmobjectid设置成了NVARCHAR类型,Oracle中的隐式自动转换没有NARCHAR类型到Number类型的转换,需要借助to_number()函数.

select * from emp where hiredate = '17-11月-81'; 这个就是一个字符串转换成了日期.

隐式转换的前提:被转换对象是可以转换的

select * from emp where deptno = 10 和 select * from emp where deptno = '10'是一样的.

显示转换:

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值