SpringBoot整合Mybatis之各种查询、模糊查询、批量删除、动态表名操作

软件发布|下载排行|最新软件

当前位置:首页IT学院IT技术

SpringBoot整合Mybatis之各种查询、模糊查询、批量删除、动态表名操作

花果水莲   2022-12-24 我要评论

一、普通查询

1. 若查询出的数据只有一条

a>可以通过实体类对象接收

    <!-- Dish getDishByName(@Param("name") String name);-->
    <select id="getDishByName" resultType="com.athorse.entities.Dish">
        select * from dish where name = #{name}
    </select>

b>可以通过list集合接收

<!-- List<Dish> getDishByName(@Param("name") String name);-->
    <select id="getDishByName" resultType="com.athorse.entities.Dish">
        select * from dish where name = #{name}
    </select>

c>可以通过map集合接收

<!-- Map<String,Object> getDishByName(@Param("name") String name);-->
    <select id="getDishByName" resultType="map">
        select * from dish where name = #{name}
    </select>

2. 若查询出的数据有多条

a> 可以通过list集合接收

<!-- List<Dish> getDishByName(@Param("name") String name);-->
    <select id="getDishByName" resultType="com.athorse.entities.Dish">
        select * from dish where name = #{name}
    </select>

b>可以通过map类型的list集合接收

<!-- List<Map<String,Object>> getDishByName(@Param("name") String name);-->
    <select id="getDishByName" resultType="map">
        select * from dish where name = #{name}
    </select>

c>可以在mapper接口的方法上添加@MapKey注解,此时就可以将每条数据转换的map集合作为值,以某个字段的值作为键。

二、模糊查询 like "%"#{name}"%"

<!-- List<Dish> getDishByName(@Param("name") String name);-->
 <select id="getDishByName" resultType="com.athorse.entities.Dish">
        select * from dish where name like "%"#{name}"%"
 </select>

三、批量删除 in (${ids})

<!--Integer deleteMore(@Param("ids") String ids);-->
    <delete id="deleteMore">
        delete from dish where id in (${ids})
    </delete>

四、动态设置表名 ${tableName}

<!-- List<Dish> getDishs(@Param("tableName") String tableName);-->
    <select id="getDishs" resultType="com.athorse.entities.Dish">
        select * from ${tableName}
    </select>

总结:#{}会自动的拼接上'',而${}不会,所以特殊场景下需要使用${}

Copyright 2022 版权所有 软件发布 访问手机版

声明:所有软件和文章来自软件开发商或者作者 如有异议 请与本站联系 联系我们