源码分析所得 char 与 int之间的转换

本文探讨了在使用Hibernate进行数据库查询时,源码中涉及char类型与int类型转换的问题。作者在深入研究源码后,对SQL正则校验的困惑以及为何将63作为int值传入并返回'?'字符的位置进行了详细解析,揭示了char到int转换的原理。
摘要由CSDN通过智能技术生成

 公司用的是 hibernate 做数据库查询,其中 jar 包是这些。

在翻阅源码的时候有些问题不得解。在不懈努力下,以及前辈大神的指导下终于明白了。

String biz_stage = "007";
StringBuilder sql1 = new StringBuilder();
sql1.append(" SELECT C.TASK_HANDLER,C.STATUS FROM C_CLAIM_TASKS C WHERE C.CASENO = ? AND C.BIZ_STAGE = ?");
List<Map<String, Object>> list = databaseDao.findAllBySqlMap(sql1.toString(), caseNo, biz_stage);
InjectionCheckUtils.checkValidSql(sql);
final String fnSql = processQL(sql, values);

 上面是重要代码(我有疑问的,以及大家阅读懂所必须的)。

SQL 正则校验(这块我弱项,没懂),然后就是 SQL 分析:

protected static String processQL(final String ql, final Object... values) {
    String newQL = ql;
    int 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值