ibatis拥抱sql,在其sqlmapping中有各种sql的定义,定义中有#,$等占位符。那么ibatis是在哪里处理这些语句的呢?
每条定义(statement)对应一个MappedStatement, 来看MappedStatement的源代码。以queryForList为例:
在sqlMapExecutorDelegation中调用
ms.executeQueryForList(statementScope,xxx)得到结果list。
MappedStatement中executeQueryWithCallback(StatementScope,xxx)。其中有
sqlExecuteQuery(statementScope, conn, sqlString, parameters, skipResults, maxResults, callback);
可以看到这里已经生成了sqlString,这就是最终传递给数据库的sql语句。
怎么来的?往前看。
String sqlString = sql.getSql(statementScope, parameterObject);
sql是一个接口,有四个实现,以DynamicSql为例:
在getSql中调用process处理sql,并将参数解析出来放进statementScope里作为preparedStatement的参数。其中processBodyChildren()处理#,$符号,之后还有$的话再新建SimpleDynamicSql进行简单的文本替换。RawSql最简单它保存的是最原始的不需要替换的sql.
后记:
ibatis处理sql的过程:(SimpleDynamicSql)
1,在xml解析阶段就已经把#name#替换成了?。相关源码:MappedStatementConfig.applyInlineParameterMap()
2,在运行阶段完成$的简单文本替换。相关源码:SimpleDynamicSql.processDynamicElements()
dynamicSql的#变量也会在运行期间动态进行解析。
从使用的角度只要记住,#是preparedStatement的参数,$是简单文本替换。因此用$可能会导致sql注入如查询名字不填css而填' or 1=1 or ''='将会得到所有用户列表。
分享到:
相关推荐
ibatis-3-core-3.0.0.242.jar.zipibatis-3-core-3.0.0.242.jar.zipibatis-3-core-3.0.0.242.jar.zipibatis-3-core-3.0.0.242.jar.zipibatis-3-core-3.0.0.242.jar.zip
IBatis-SQL-MAPs 开发指南IBatis-SQL-MAPs 开发指南IBatis-SQL-MAPs 开发指南IBatis-SQL-MAPs 开发指南IBatis-SQL-MAPs 开发指南
iBATIS-SqlMaps-2-Tutorial_cniBATIS-SqlMaps-2-Tutorial_cn.pdf.pdfiBATIS-SqlMaps-2-Tutorial_cn.pdfiBATIS-SqlMaps-2-Tutorial_cn.pdf
ibatis-3-core-3.0.0.200
《深入解析iBatis核心库:ibatis-core-3.0.jar》 iBatis,一个优秀的持久层框架,以其轻量级、易用性、灵活性等特性深受开发者喜爱。在Java开发领域,iBatis作为数据访问层的解决方案,为数据库操作提供了强大的...
ibatis-3-core-3.0.0.242.zip ibatis-3-core-3.0.0.242.zip ibatis-3-core-3.0.0.242.zip ibatis-3-core-3.0.0.242.zip
ibatis-common-2.jar...........
ibatis-dao-2.jar gggggggggggg
ibatis-sqlmap-2.jar 对数据库进行操作的jar包 很方便使用
总结,`ibatis-sqlmap-2.jar.zip`中的`ibatis-sqlmap-2.jar`是iBatis-SQLMap 2的核心库,它为开发者提供了强大的SQL操作和对象映射功能。通过理解并熟练运用iBatis-SQLMap 2,开发者可以构建出高效、灵活的数据库...
ibatis-3-core-3.0.0.204 最新官方下载版
综上所述,通过对iBatis-SQLMap 2.3.4.726源码的学习,我们可以深入了解其设计思想,提升数据库操作的效率,更好地实现业务逻辑。同时,源码分析也有助于我们解决实际开发中遇到的问题,进行性能优化,甚至为框架...
Ibatis,全称为MyBatis,是一个优秀的Java持久层框架,它主要负责SQL映射,使得开发者能够将SQL语句与Java代码分离,从而更好地管理数据库操作。在Ibatis中,`sql-map`和`sql-map-config`是两个重要的XML配置文件,...
### iBATIS-SqlMaps-2_ja.pdf 相关知识点 #### iBATIS Data Mapper 概览 iBATIS Data Mapper(也称为 SQL Maps)是一个开源框架,它旨在简化与关系数据库交互所需的 Java 代码量。通过使用简单的 XML 配置文件,...
转ibatis动态sql - phoebus0501 - 博客园.mht
这个“iBATIS3学习--Demo”很可能是一个教程或示例项目,帮助初学者理解如何在实际应用中使用iBATIS。在这个项目中,我们可以找到几个关键的文件,它们分别是: 1. **HrMap.xml** - 这是iBATIS的SQL映射文件,用于...
apache开源项目源码ibatis-3-core-src-3.0.0.227 ibatis框架java源程序 spring,struts,hibernate,ibatis,框架源码 各种ibatis框架应用源码,你会从中得到意想不到的效果! apache开源组织开发的开源项目源码,其...
首先,需要将 ojdbc14.jar 和 ibatis-3-core-3.0.0.208.jar 添加到项目的 lib 文件夹中。然后,在 WEB-INF 文件夹下创建一个 lib 文件夹,并将相关依赖包复制到该文件夹中。 二、总配置文件 SqlMapConfig.xml ...
《ibatis-sqlmaps-2_cn》是一本专注于介绍IBATIS框架的中文教程,非常适合初学者和有经验的开发者进行深入学习。IBATIS,作为一个轻量级的持久层框架,它为Java应用程序提供了数据库操作的支持,尤其在处理SQL映射...