MyBatis框架多态SQL

        MyBatis框架主要通过标签的配合使用实现SQL语句的动态拼接、前后缀格式化处理、复杂参数处理等功能。

        if标签是MyBatis框架动态SQL技术中重要且常用的标签之一,它所实现的功能与Java中的if语句基本相同,用法也很相似。

where标签的主要作用是对SQL语句中的where关键字进行简化处理。

otherwise 标签:

choose(when、otherwise)是一个组合标签,when otherwise 标签写在 choose 标签中。

当 when 标签中的 test 属性判断为 tue,就会执行它所包含的语句。

choose 中的多个 when 标签只会执行匹配成功的第一个,执行之后跳出 choose 标签
当所有的 when 标签中的 test 属性判断都为 false 时,进入 otherwise 标签。

item:遍历数组时,为数组或 Ust集合中的元素起的别名。

open:起始位置的拼接字符,表示in语句以"("左括号开始。close:结束位置的拼接字符,表示in语句以")"右括号结束。
Separator:元素之间的连接符,表示in语句中的元素之间以“,逗号连接。

Collection:参数名称。当参数为数组类型时,默认参数名为array。当参数类型为List集合时,默认参数名为ist。当参数类型为Map时,参数名为Map中集合元素所在键值对的 key。

prefix:前缀,可以自动对 trim 标签所包含的语句是否有返回值进行判断。如果有返回
值,则为 SQL 语句拼接相应前缀。

sufix:后缀,在 trim 标签包含的语句末尾拼接后缀。

suffxOverrides:忽略的后缀,忽略 trim 标签包含内容尾部指定的内容。

prefixOverrides:忽略的前缀,忽略 trim 标签内部首部指定的内容。

  • 12
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Java面试八股文是指在Java面试中常被问到的一些基础知识点和常见问题。而MyBatis是一种持久层框架,用于简化Java应用程序与数据库之间的交互。下面是关于Java面试八股文和MyBatis的介绍: Java面试八股文包括但不限于以下几个方面的内容: 1. Java基础知识:包括Java的特性、面向对象的概念、封装、继承、多态、异常处理、集合框架等。 2. 数据库相关:包括SQL语句的基本语法、数据库事务、索引、连接池等。 3. 多线程:包括线程的生命周期、线程同步与互斥、线程池、线程安全等。 4. JVM相关:包括JVM的内存模型、垃圾回收机制、类加载机制等。 5. 设计模式:包括单例模式、工厂模式、代理模式、观察者模式等常见的设计模式。 关于MyBatis,它是一种轻量级的持久层框架,主要用于将Java对象与数据库之间进行映射。MyBatis提供了一种将SQL语句与Java代码解耦的方式,通过XML或注解的方式来配置SQL语句,使得开发人员可以更加灵活地操作数据库。 MyBatis的核心特点包括: 1. 简化数据库操作:MyBatis提供了简洁的API,可以方便地进行增删改查操作。 2. 动态SQLMyBatis支持动态SQL,可以根据不同的条件生成不同的SQL语句,提高了SQL的灵活性。 3. 缓存机制:MyBatis提供了一级缓存和二级缓存的支持,可以提高查询性能。 4. 映射关系配置:MyBatis通过XML或注解的方式来配置Java对象与数据库表之间的映射关系,使得开发人员可以更加灵活地进行数据库操作。 5. 插件机制:MyBatis提供了插件机制,可以对SQL语句进行拦截和修改,扩展了MyBatis的功能。 以上是关于Java面试八股文和MyBatis的简要介绍,希望对你有所帮助。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值