MyBatis SELECT基本查询实现方法详解

 更新时间:2020年08月27日 15:41:26   作者:IT-執念  
这篇文章主要介绍了MyBatis SELECT基本查询实现方法详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下

1、返回一个LIST

<!-- public List<Employee> getEmpsByLastNameLike(String lastName); -->
  <!--resultType:如果返回的是一个集合,要写集合中元素的类型 -->
  <select id="getEmpsByLastNameLike" resultType="com.atguigu.mybatis.bean.Employee">
    select * from tbl_employee where last_name like #{lastName}
  </select>

2、将查询记录封装为一个Map

<!--public Map<String, Object> getEmpByIdReturnMap(Integer id); -->
   <select id="getEmpByIdReturnMap" resultType="map">
     select * from tbl_employee where id=#{id}
   </select>

返回一条记录的map;key就是列名,值就是对应的值。

3、多条记录封装为一个map

@MapKey("id")
public Map<Integer, Employee> getEmpByLastNameLikeReturnMap(String lastName);

   <select id="getEmpByLastNameLikeReturnMap" resultType="com.atguigu.mybatis.bean.Employee">
     select * from tbl_employee where last_name like #{lastName}
   </select>

  Map<Integer,Employee>:键是这条记录的主键,值是记录封装后的javaBean。

  @MapKey:告诉mybatis封装这个map的时候使用哪个属性作为map的key。

4、多条件查询  

public Employee getEmpByIdAndLastName(@Param("id")Integer id,@Param("lastName")String lastName);

   <select id="getEmpByIdAndLastName" resultType="com.atguigu.mybatis.bean.Employee">
     select * from tbl_employee where id = #{id} and last_name=#{lastName}
   </select>

  @Param("id")标注查询条件的key,查询条件都会封装为map。id为key,value为参数所对应的值。

5、插入操作(自增主键mysql)

<insert id="addEmp" parameterType="com.atguigu.mybatis.bean.Employee"
    useGeneratedKeys="true" keyProperty="id" databaseId="mysql">
    insert into tbl_employee(last_name,email,gender) 
    values(#{lastName},#{email},#{gender})
</insert>

   获取自增主键的值:

    mysql支持自增主键,自增主键值的获取,mybatis也是利用statement.getGenreatedKeys();

    useGeneratedKeys="true";使用自增主键获取主键值策略

    keyProperty;指定对应的主键属性,也就是mybatis获取到主键值以后,将这个值封装给javaBean的哪个属性。

6、插入操作(非自增主键oracle)

  ①非自增主键oracle BEFORE格式推荐 

<!-- public void addEmp(Employee employee); --><insert id="addEmp" databaseId="oracle">
    <selectKey keyProperty="id" order="BEFORE" resultType="Integer">
      select EMPLOYEES_SEQ.nextval from dual 
    </selectKey>
    insert into employees(EMPLOYEE_ID,LAST_NAME,EMAIL) 
    values(#{id},#{lastName},#{email) 
</insert>

  ②非自增主键oracle AFTER存在并发有可能不准确,不推荐

<!-- public void addEmp(Employee employee); --><insert id="addEmp" databaseId="oracle">
    <selectKey keyProperty="id" order="AFTER" resultType="Integer">
       select EMPLOYEES_SEQ.currval from dual 
    </selectKey>
    insert into employees(EMPLOYEE_ID,LAST_NAME,EMAIL) 
    values(#{id},#{lastName},#{email}) 
</insert>

Oracle不支持自增;Oracle使用序列来模拟自增;每次插入的数据的主键是从序列中拿到的值;如何获取到这个值;

使用selectKey:

keyProperty:查出的主键值封装给javaBean的哪个属性

order="BEFORE":当前sql在插入sql之前运行
    AFTER:当前sql在插入sql之后运行
resultType:查出的数据的返回值类型

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

相关文章

  • Spring应用抛出NoUniqueBeanDefinitionException异常的解决方案

    Spring应用抛出NoUniqueBeanDefinitionException异常的解决方案

    这篇文章介绍了解决org.springframework.beans.factory.NoUniqueBeanDefinitionException异常的一些解决方案,从这些解决方案可以看出Spring框架的设计精妙,遇见此问题的朋友可以参考下该解决方案
    2021-06-06
  • Spring中@Value使用详解及SPEL表达式

    Spring中@Value使用详解及SPEL表达式

    这篇文章主要介绍了Spring中@Value使用详解及SPEL表达式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2023-09-09
  • Java 无符号右移与右移运算符的使用介绍

    Java 无符号右移与右移运算符的使用介绍

    这篇文章主要介绍了Java 无符号右移与右移运算符的使用介绍,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-06-06
  • 详解Java 虚拟机垃圾收集机制

    详解Java 虚拟机垃圾收集机制

    这篇文章主要介绍了Java 虚拟机垃圾收集机制的相关资料,帮助大家更好的理解和学习Java虚拟机的相关知识,感兴趣的朋友可以了解下
    2020-12-12
  • response.setHeader各种用法详解

    response.setHeader各种用法详解

    本文主要介绍了response.setHeader各种用法。具有很好的参考价值,下面跟着小编一起来看下吧
    2017-03-03
  • 如何使用MAVEN打JAR包(直接使用)

    如何使用MAVEN打JAR包(直接使用)

    这篇文章主要介绍了如何使用MAVEN打JAR包(直接使用),文中通过实例代码介绍了maven 使用assembly插件进行打包的方法,需要的朋友可以参考下
    2023-03-03
  • 泛谈Java中的不可变数据结构

    泛谈Java中的不可变数据结构

    开发人员通常认为拥有final引用,或者val在Kotlin或Scala中,足以使对象不可变。这篇博客文章深入研究了不可变引用和不可变数据结构,下面小编来和大家一起学习它
    2019-05-05
  • Java实现消消乐中的消除功能

    Java实现消消乐中的消除功能

    这篇文章主要为大家详细介绍了Java实现消消乐中的消除功能,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-07-07
  • springboot结合maven实现多模块打包

    springboot结合maven实现多模块打包

    本文主要介绍了springboot借助maven完成多模块打包,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-04-04
  • Maven pom.xml文件获取当前时间戳方式

    Maven pom.xml文件获取当前时间戳方式

    这篇文章主要介绍了Maven pom.xml文件获取当前时间戳方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2021-12-12

最新评论