`
x放羊的星星
  • 浏览: 35202 次
  • 性别: Icon_minigender_1
  • 来自: 上海
社区版块
存档分类
最新评论

Mybatis多参数查询映射

 
阅读更多
最近在做一个Mybatis的项目,由于是接触不久,虽然看了一下资料,但在实际开发中还是暴露了很多问题,其中最让我头疼的就是selete的parameterType问题,网上这类的帖子虽然有但是不全,很多情况下很难找到你想要的答案。
为此我对这个问题进行了总结,希望对像我这样的新手有一定的帮助。

(一)单个参数
public List<XXBean> getXXBeanList(String xxCode);

<select id="getXXXBeanList" parameterType="java.lang.String" resultType="XXBean">
select 字段... from XXX where code = #{xxCode}
</select>

其中方法名和ID一致,#{}中的参数名与方法中的参数名一直, 我这里采用的是XXXBean是采用的短名字, select 后的字段列表要和bean中的属性名一致, 如果不一致的可以用 as 来补充。


(二)多参数
public List<XXXBean> getXXXBeanList(String xxId, String xxCode);

<select id="getXXXBeanList" resultType="XXBean">
select 字段... from XXX where id=#{0} code = #{1}
</select>

由于是多参数那么就不能使用parameterType, 改用#{index}是第几个就用第几个的索引,索引从0开始
(三)Map封装多参数

public List<XXXBean> getXXXBeanList(HashMap map);

<select id="getXXXBeanList" parameterType="hashmap" resultType="XXBean">
select 字段... from XXX where id=#{xxId} code = #{xxCode}
</select>

其中hashmap是mybatis自己配置好的直接使用就行。map中key的名字是那个就在#{}使用那个,map如何封装就不用了我说了吧。
(四)List封装IN
public List<XXXBean> getXXXBeanList(List<String> list);
<select id="getXXXBeanList" resultType="XXBean">
select 字段... from XXX where id in
<foreach item="item" index="index" collection="list"
open="(" separator="," close=")">
#{item}
</foreach>
</select>

foreach 最后的效果是select 字段... from XXX where id in ('1','2','3','4')
分享到:
评论
1 楼 QQ371496669 2013-01-25  
Thanks ,真好用到这里!!!

相关推荐

    Mybatis-03 SQL映射文件

    详解MyBatis框架中SQL映射文件的具体配置,包括实现增删改查操作、根据主键生成方式获取主键值、针对单个参数、多个参数和命名参数的处理与参数值获取以及select标签中resultMap的详解

    springmybatis

    MyBatis是支持普通SQL查询,存储过程和高级映射的优秀持久层框架。MyBatis消除了几乎所有的JDBC代码和参数的手工设置以及结果集的检索。MyBatis使用简单的XML或注解用于配置和原始映射,将接口和Java的POJOs(Plan ...

    mybatis配置数据源、别名,映射器,执行数据库的查询, 带一个参数及多个参数的查询,新增等

    mybatis配置数据源、别名,映射器,执行数据库的查询, 带一个参数及多个参数的查询,新增等 包含学习视频及项目源码, 包含授课笔记

    解析Mybatis连续传递多个参数的方法

    MyBatis是一个支持普通SQL查询,存储过程和高级映射的优秀持久层框架,这篇文章主要介绍了Mybatis连续传递多个参数的方法,需要的朋友可以参考下

    mybatis中文版教程

    MyBatis 是支持普通 SQL查询,存储过程和高级映射的优秀持久层框架。MyBatis 消除  了几乎所有的 JDBC 代码和参数的手工设置以及结果集的检索。MyBatis 使用简单的 XML  或注解用于配置和原始映射,将接口和 Java ...

    IDEA中MyBatis逆向工程.txt

    MyBatis 避免了几乎所有的 JDBC 代码和手动设置参数以及获取结果集。MyBatis 可以使用简单的 XML 或注解来配置和映射原生信息,将接口和 Java 的 POJOs(Plain Old Java Objects,普通的 Java对象)映射成数据库中的...

    mybatis学习笔记

    6.3.7 Mybatis Cache参数 64 6.3.8 mybatis整合ehcache 64 6.3.9 应用场景 67 6.3.10 局限性 67 7 与spring整合 68 7.1 mybatis与spring整合jar 68 7.2 Mybatis配置文件 68 7.3 Spring配置文件: 69 7.4 Mapper编写...

    mybatis-tutorial:mybatis 入门教程

    MyBatis 教程MyBatis 是一款优秀的持久层框架,它支持定制化 SQL、存储过程以及高级映射。...文章列表:一对一和一对多的延迟加载多对多的实现分页查询把SQL写在注解中自动生成Mapper代码和映射XML

    Spring+MVC+Mybatis 书城项目

    MyBatis避免了几乎所有的JDBC代码和手动设置参数以及获取结果集。MyBatis可以使用简单的XML或注解来配置和映射原生信息,将接口和Java的POJOs (Plain Old Java Objects, 普通的Java对象)映射为数据库中的记录。 项目...

    MyBatis项目:ALL

    maven02:获取参数值两种方式、查询结果单个或多条接收、模糊查询等特殊功能 maven03:两表多对一/一对多ResultMap解决字段与属性映射、动态SQL标签、缓存 MyBatis_MBG:逆向工程(奢华尊享版)(由数据库逆向自动...

    基于框架的Web开发-映射详解.doc

    为了避免使用多句resource语句引入多个映射xml文件,这里使用package将mappers包引入,会将这个包下面的映射文件一起引入 为了避免使用多句resource语句引入多个映射xml文件,这里使用package将mappers包引入,会将...

    深入浅出MyBatis框架

    MyBatis 避免了几乎所有的 JDBC 代码和手动设置参数以及获取结果集。MyBatis 可以使用简单的 XML 或注解来配置和映射原生信息,将接口和 Java 的 POJOs(Plain Old Java Objects,普通的 Java对象)映射成数据库中的...

    mybatis-cn:mybatis二进制的中文注释以及mybatis的使用和二进制解析

    :连接中需要引入多个参数,试一下注解模式吧:来试试高级映射功能:一对多的高级映射:一级缓存,二级缓存,提升性能的同时,也注意它的限制 :我再也不要在代码中拆分语句了!!来用mybatis动态SQL爽一爽吧 :sql...

    MyBatis 逆向工程

    MyBatis 免除了几乎所有的 JDBC 代码以及设置参数和获取结果集的工作。MyBatis 可以通过简单的 XML 或注解来配置和映射原始类型、接口和 Java POJO(Plain Old Java Objects,普通老式 Java 对象)为数据库中的记录...

    SSM框架的学习与应用-Java EE企业级应用开发学习记录(第三天)Mybatis的深入学习(动态sql的操作)

    通过元素示例演示了根据输入参数动态构建查询条件。 通过元素示例演示了多条件选择动态查询。 通过、元素示例演示了自动处理关键字的动态查询。 通过元素示例演示了动态更新指定字段。 通过元素示例演示了对数组列表...

    1000道 互联网Java架构师面试题.pdf和JAVA核心知识整理.zip

    18、为什么说 Mybatis 是半自动 ORM 映射工具?它与全自动的区别在哪里? 19、 一对一、一对多的关联查询 ? 20、MyBatis 实现一对一有几种方式?具体怎么操作的? 21、MyBatis 实现一对多有几种方式,怎么操作的?...

    MyBatis入门视频课程

    本课程以通俗易懂的方式讲解MyBatis技术,课程内容包括:...7.多参数查询 8.动态SQL 9.多表关系映射 10.代码生成器mybatis-generator 11.分页插件PageHelper 教学全程采用笔记+代码案例的形式讲解,通俗易懂!!!

    mybatis框架 快速入门 基础+提高 实战视频教程

    mybatis通过xml或注解的方式将要执行的各种statement配置起来,并通过java对象和statement中sql的动态参数进行映射生成最终执行的sql语句,最后由mybatis框架执行sql并将结果映射为java对象并返回。采用ORM思想解决...

    MyBatis实战教程

    本课程适合有JAVA和数据库基础的人员。 本课程使用Eclipse和IntelliJ IDEA两种开发工具,详细的讲解了MyBatis的各种语法,并且讲解了MyBatis逆向工程和MyBatis两种常用的插件:... 12.MyBatis处理多个参数的问题? ? ?

    spring-dubbo-service:微服务spring dubbo项目:dubbo rpc;德鲁伊数据源连接池; mybatis配置集成,多数据源; jmx监控MBean;定时任务; aop; ftp;测试;指标监控;参数验证;跨域处理; shiro权限控制; consul服务注册,发现; redis分布式锁; SPI服务机制; cat监控; netty服务代理; websocket; disconf; mongodb集成;休息; docker; fescar

    spring-dubbo-service微服务一,服务模块1,服务器配置:servlet,侦听器,拦截器,过滤器,aop,定时任务mybatis配置集成,多数据源;级联查询一对一对一对多注解配置及xml配置方式;分页处理:传递Page参数或继承...

Global site tag (gtag.js) - Google Analytics