深圳Java培训:Mybatis必会的动态SQL

深圳Java培训: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 和""。
1.   
2.  
3.    select * from users where 1=1   
4.     and uname like “%”#{uname}"%"    
5.    and sex = #{sex}    
6.  
动态SQL 相当于 where关键字 可以自动处理第一个前and 或者or。 当条件都没有的时候 where也不会加上 。
1.   
2.  
3.    select * from users   
4.      
5.     and uname like “%”#{uname}"%"    
6.    and sex = #{sex}    
7.     
choose—when–when–otherwise when可以多个 otherwise只能有一个 类似于 switch case。
需求:输入用户id 按照用户id进行精确查找 其他条件不看 没有输入 id 用户名模糊查找 都没有的话 查询id=1的用户
1.   
2.  
3.  
4.    select * from users   
5.      
6.              
7.                 uid=#{uid}  
8.                 uname like “%”#{uname}"%"  
9.                uid=1  
10.              
11.               
12.      
13.
动态sql之set 代替set关键字 set标签可以帮助我们去掉最后一个逗号
1.  
2.    
3.    update users    
4.      
5.    
6.     uname =#{uname},  
7.     upwd =#{upwd},  
8.     sex =#{sex},  
9.     birthday =#{birthday},  
10.    
11.    where  uid=#{uid}  
12.    
Trim,trim代替where
1.   
2.      
3.    select * from users   
4.       
10.  
11. and uname like “%”#{uname}"%"    
12.and sex = #{sex}    
13.  
14.  
Trim代替set:
1.         
2.        
3.  
4.update users    
5.      
6.    
7.     uname =#{uname},  
8.     upwd =#{upwd},  
9.     sex =#{sex},  
10.     birthday =#{birthday},  
11.    
12.      
Foreach来遍历集合
1.   
2.  
3.    select * from users  where uid  in    
4.       
12.      
13.        #{item}  
14.      
15.  
16.

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

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Android是一种基于Linux内核(不包含GNU组件)的自由及开放源代码的移动操作系统,主要应用于移动设备,如智能手机和平板电脑。该系统最初由安迪·鲁宾开发,后被Google公司收购并注资,随后与多家硬件制造商、软件开发商及电信营运商共同研发改良。 Android操作系统的特点包括: 开放源代码:Android系统采用开放源代码模式,允许开发者自由访问、修改和定制操作系统,这促进了技术的创新和发展,使得Android系统具有高度的灵活性和可定制性。 多任务处理:Android允许用户同时运行多个应用程序,并且可以轻松地在不同应用程序之间切换,提高了效率和便利性。 丰富的应用生态系统:Android系统拥有庞大的应用程序生态系统,用户可以从Google Play商店或其他第三方应用市场下载和安装各种各样的应用程序,满足各种需求。 可定制性:Android操作系统可以根据用户的个人喜好进行定制,用户可以更改主题、小部件和图标等,以使其界面更符合个人风格和偏好。 多种设备支持:Android操作系统可以运行在多种不同类型的设备上,包括手机、平板电脑、智能电视、汽车导航系统等。 此外,Android系统还有一些常见的问题,如应用崩溃、电池耗电过快、Wi-Fi连接问题、存储空间不足、更新问题等。针对这些问题,用户可以尝试一些基本的解决方法,如清除应用缓存和数据、降低屏幕亮度、关闭没有使用的连接和传感器、限制后台运行的应用、删除不需要的文件和应用等。 随着Android系统的不断发展,其功能和性能也在不断提升。例如,最新的Android版本引入了更多的安全性和隐私保护功能,以及更流畅的用户界面和更强大的性能。此外,Android系统也在不断探索新的应用场景,如智能家居、虚拟现实、人工智能等领域。 总之,Android系统是一种功能强大、灵活可定制、拥有丰富应用生态系统的移动操作系统,在全球范围内拥有广泛的用户基础。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值