如何通过引擎解析自定义sql语句???

Birds_Cerebrum 2017-01-11 04:47:04
无意间看到别人定义的sql语句不同于平时见到的,之后才了解到是别人自己写的java解析sql的引擎去解析的sql语句,然后再执行解析之后的sql。请问大神,这个具体怎么实现的?
...全文
369 5 打赏 收藏 转发到动态 举报
写回复
用AI写文章
5 条回复
切换为时间正序
请发表友善的回复…
发表回复
Birds_Cerebrum 2017-01-24
  • 打赏
  • 举报
回复
引用 4 楼 piterlin 的回复:
这个可简单可复杂。 复杂的栗子可参考hibernate源码中的的hql处理部份 简单的栗子是: 输入自定义语句:select 1 from dual where 1=# 引擎处理:sql="select 1 from dual where 1=#".replaceAll("#","?"); 输出标准的sql:select 1 from dual where 1=? 个人认为能用标准的sql就用标准的sql。新人易上手,调试也容易
多谢提醒,没想到去看源码,结贴了。
Birds_Cerebrum 2017-01-12
  • 打赏
  • 举报
回复
引用 1 楼 ylovep 的回复:
归根到底实现自己的sql语句要做好语言的转换工作,需要定义一个强大的解释器 里面有各种if条件来替换你自己定义的sql
我想知道,普通的判断和替换实现自定义sql跟引擎具体有什么区别,或者说使用引擎有什么好处。以及具体的实现方法。
Birds_Cerebrum 2017-01-12
  • 打赏
  • 举报
回复
我想知道,普通的判断和替换实现自定义sql跟引擎具体有什么区别,或者说使用引擎有什么好处。以及具体的实现方法。
ylovep 2017-01-12
  • 打赏
  • 举报
回复
归根到底实现自己的sql语句要做好语言的转换工作,需要定义一个强大的解释器 里面有各种if条件来替换你自己定义的sql
piterlin 2017-01-12
  • 打赏
  • 举报
回复
这个可简单可复杂。 复杂的栗子可参考hibernate源码中的的hql处理部份 简单的栗子是: 输入自定义语句:select 1 from dual where 1=# 引擎处理:sql="select 1 from dual where 1=#".replaceAll("#","?"); 输出标准的sql:select 1 from dual where 1=? 个人认为能用标准的sql就用标准的sql。新人易上手,调试也容易

67,513

社区成员

发帖
与我相关
我的任务
社区描述
J2EE只是Java企业应用。我们需要一个跨J2SE/WEB/EJB的微容器,保护我们的业务核心组件(中间件),以延续它的生命力,而不是依赖J2SE/J2EE版本。
社区管理员
  • Java EE
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧