技术文摘
Mybatis 动态 SQL 优化:<if>与<choose>标签的正确使用方法
Mybatis作为一款优秀的持久层框架,其动态SQL功能极大地提升了开发效率与灵活性。在动态SQL中,
<select id="selectUser" parameterType="map" resultType="user">
SELECT * FROM user
<if test="name!= null and name!= ''">
WHERE name = #{name}
</if>
</select>
在上述代码中,只有当传入的参数map中包含name且name不为空字符串时,WHERE name = #{name}这段SQL才会被拼接到最终的查询语句中,这样就实现了灵活的条件查询。
而
<select id="selectUserByRole" parameterType="map" resultType="user">
SELECT * FROM user
<choose>
<when test="role == 'admin'">
WHERE role = 'admin'
</when>
<when test="role == 'user'">
WHERE role = 'user'
</when>
<otherwise>
WHERE role = 'guest'
</otherwise>
</choose>
</select>
在这个例子中,根据传入的role值,Mybatis会选择相应的
正确使用
TAGS:
SQL优化
MyBatis动态SQL
- Spring注解注入属性的使用
- Net与WebSphere Application Server V7.0的互操作性
- Java核心技术高手学习笔记
- IBM本周推出云计算产品及服务
- Twitter五大值得关注趋势:实时搜索引擎
- JSP中使用JavaMail的方法教程
- JBoss AS的特性及发布时间表
- JBoss Seam的发展前景
- 微软云计算业务细节将发布 合作伙伴仍是战略关键
- JBoss中mysql数据库连接池的配置
- 甲骨文涉足Web 2.0 瞄准社交网络
- JBoss5.0的下载与安装
- JavaMail API详细解析(上)
- Google着手测试Fusion Tables云计算数据库
- JS.Class 2.1发布 用JavaScript实现Ruby风格