线程同步和互斥(条件变量控制生产者消费者模型)
2016-04-22 13:09
519 查看
ibatis作为一种半自动化的OR Mapping工具,2010年这个项目由apache sofeware foundation 迁移到了google code,并且改名为mybatis。其灵活性日益体现出来,越来越多的人都倾向于在项目中使用。由于Sql中经常有与xml规范相冲突的字符对xml映射文件的合法性造成影响。许多人都知道使用<![CDATA[ ]]>标记来避免冲突,但是在sql配置中有动态语句的时候,还是有一些细节需要特别注意的,不然是费心又费力。 在使用ibatis时,经常需要配置待执行的sql语句。使用过ibatis的朋友都知道,无可避免的都会碰到一些不兼容、冲突的字符,多数人也都知道用<![CDATA[ ]]>标记避免Sql中与xml规范相冲突的字符对xml映射文件的合法性造成影响。但是,如果在ibatis中使用了动态语句的时候,还是有一些细节需要注意。下面举例说明一下:
环境:oracle、ibatis、java
错误例1:符号“<=”会对xml映射文件的合法性造成影响
错误例2:将整个sql语句用<![CDATA[ ]]>标记来避免冲突,在一般情况下都是可行的,但是由于该sql配置中有动态语句(where部分),将导致系统无法识别动态判断部分,导致整个sql语句非法。
正确做法:缩小范围,只对有字符冲突部分进行合法性调整。
环境:oracle、ibatis、java
错误例1:符号“<=”会对xml映射文件的合法性造成影响
<select id="find" parameterClass="java.util.Map" resultClass="java.lang.Long"> select id from tableA a, tableB b <dynamic prepend="WHERE"> <isNotNull prepend="AND" property="startDate"> a.act_time >= #startDate# and a.act_time <= #endDate# and a.id = b.id </isNotNull> </dynamic> </select>
错误例2:将整个sql语句用<![CDATA[ ]]>标记来避免冲突,在一般情况下都是可行的,但是由于该sql配置中有动态语句(where部分),将导致系统无法识别动态判断部分,导致整个sql语句非法。
<select id="find" parameterClass="java.util.Map" resultClass="java.lang.Long"> <![CDATA[ select id from tableA a, tableB b <dynamic prepend="WHERE"> <isNotNull prepend="AND" property="startDate"> a.act_time >= #startDate# and a.act_time <= #endDate# and a.id = b.id </isNotNull> </dynamic> ]]> </select>
正确做法:缩小范围,只对有字符冲突部分进行合法性调整。
<select id="find" parameterClass="java.util.Map" resultClass="java.lang.Long"> select id from tableA a, tableB b <dynamic prepend="WHERE"> <isNotNull prepend="AND" property="startDate"> a.act_time >= #startDate# <![CDATA[ and a.act_time <= #endDate# ]]> and a.id = b.id </isNotNull> </dynamic> </select>
相关文章推荐
- CSS3组件化之单线箭头
- mfc-串口控件变量设置
- OpenCV之imgproc 模块. 图像处理(5)在图像中寻找轮廓 计算物体的凸包 创建包围轮廓的矩形和圆形边界框 为轮廓创建可倾斜的边界框和椭圆 轮廓矩 多边形测试
- Oracle登录命令
- 修改 liunx时间命令
- 生成唯一订单号
- java学习之注解
- linux
- PHP源代码生成 main/config.w32.h
- 华为的冬天(来自网路)---任正非
- 大数据比赛-综述
- OpenCV之imgproc 模块. 图像处理(4)直方图均衡化 直方图计算 直方图对比 反向投影 模板匹配
- 计算的本质:有关表示,编译,赋值,异步和流的杂谈
- logging.xml file setfile(null,true) call failed
- onPostCreate——Activity彻底运行起来之后的回调
- start.S解析5
- JNI error:libEGL: call to OpenGL ES API with no current context (logged once per
- Linux/CentOS学习记录
- 奋斗吧,程序员!——第二章 君因风送入青云,我被人驱向鸭群
- 【C++】引用计数