Mybatis必会的动态SQL

前言

Mybatis可谓是java开发者必须会的一项技能。MyBatis 的强大特性之一便是它的动态 SQL。如果你有使用 JDBC 或其它类似框架的经验,你就能体会到根据不同条件拼接 SQL 语句的痛苦。例如拼接时要确保不能忘记添加必要的空格,还要注意去掉列表最后一个列名的逗号。利用动态 SQL 这一特性可以彻底摆脱这种痛苦。

Mybatis动态sql

mybatis 动态SQL,通过 if, choose, when, otherwise, trim, where, set, foreach等标签,可组合成非常灵活的SQL语句,从而在提高 SQL 语句的准确性的同时,也大大提高了开发人员的效率。本文主要介绍这几个动态SQL.

具体示例

if标签 if就是用来对输入映射的字段进行判断 一般是非空判断 null 和""。

动态SQL 相当于 where关键字 可以自动处理第一个前and 或者or。 当条件都没有的时候 where也不会加上 。

select * from users

uid=#{uid}

uname like "%"#{uname}"%"

uid=1

动态sql之set 代替set关键字 set标签可以帮助我们去掉最后一个逗号

update users

uname =#{uname},

upwd =#{upwd},

sex =#{sex},

birthday =#{birthday},

where uid=#{uid}

Trim,trim代替where

Trim代替set:

update users

uname =#{uname},

upwd =#{upwd},

sex =#{sex},

birthday =#{birthday},

Foreach来遍历集合

总结

熟练掌握以上Mysql的动态SQL,我们可以更得心应手的完成我的功能,写更少的代码,实现更多的功能。

你可能感兴趣的:(Mybatis必会的动态SQL)