技术文摘
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
- SVN1.4.5配置方法技术分享揭秘
- TortoiseSVN中文使用手册,专家推荐,新手必备
- SVN与MyEclipse整合内幕全程揭秘
- Myeclipse中SVN配置方法专家深度解析
- HTML 5成IE9核心 向第三方开发者开放
- Visual Studio 2010快速关闭文档窗口技巧
- Myeclipse Svn用户名和密码修改问题专家详解
- 程序员面临的十大技术困扰
- 探秘未知的PHP函数与功能
- SVNEclipse插件Subclipse安装与配置专家指导
- Eclipse安装SVN支持的详细方法
- SVN图标状态不显示问题深度解析
- Eclipse中SVN插件的简明安装方式
- Google和Spring联合推出合作版Insight
- Windows环境中搭建svn服务器的方法指引