一、单个参数:

  1. public List<XXBean> getXXBeanList(String xxCode);
  2.  
  3. <select id="getXXXBeanList" parameterType="java.lang.String" resultType="XXBean">
  4.  
  5.   select t.* from tableName t where t.id= #{id}
  6.  
  7. </select>
  8.  
  9. 其中方法名和ID一致,#{}中的参数名与方法中的参数名一直, 我这里采用的是XXXBean是采用的短名字,
  10.  
  11. select 后的字段列表要和bean中的属性名一致, 如果不一致的可以用 as 来补充。

二、多参数:

  1. public List<XXXBean> getXXXBeanList(String xxId, String xxCode);
  2.  
  3. <select id="getXXXBeanList" resultType="XXBean">
  4.  
  5.   select t.* from tableName where id = #{0} and name = #{1}
  6.  
  7. </select>
  8.  
  9. 由于是多参数那么就不能使用parameterType 改用#{index}是第几个就用第几个的索引,索引从0开始

三、Map封装多参数:

  1. public List<XXXBean> getXXXBeanList(HashMap map);
  2.  
  3. <select id="getXXXBeanList" parameterType="hashmap" resultType="XXBean">
  4.  
  5.   select 字段... from XXX where id=#{xxId} code = #{xxCode}
  6.  
  7. </select>
  8.  
  9. 其中hashmapmybatis自己配置好的直接使用就行。mapkey的名字是那个就在#{}使用那个,map如何封装就不用了我说了吧。

 四、List封装in:

  1. public List<XXXBean> getXXXBeanList(List<String> list);
  2.  
  3. <select id="getXXXBeanList" resultType="XXBean">
  4.   select 字段... from XXX where id in
  5.   <foreach item="item" index="index" collection="list" open="(" separator="," close=")">
  6.     #{item}
  7.   </foreach>
  8. </select>
  9.  
  10. foreach 最后的效果是select 字段... from XXX where id in ('1','2','3','4')

五、多参数传递之注解方式示:

  1. 例子:
  2.  
  3. public AddrInfo getAddrInfo(@Param("corpId")int corpId, @Param("addrId")int addrId);
  4.  
  5. xml配置这样写:
  6.  
  7. <select id="getAddrInfo" resultMap="com.xxx.xxx.AddrInfo">
  8. SELECT * FROM addr__info
        where addr_id=#{addrId} and corp_id=#{corpId}
  9. </select>
  10.  
  11. 以前在<select>语句中要带parameterType的,现在可以不要这样写。

六、selectList()只能传递一个参数,但实际所需参数既要包含String类型,又要包含List类型时的处理方法:

将参数放入Map,再取出Map中的List遍历。如下:

  1. List<String> list_3 = new ArrayList<String>();
    Map<String, Object> map2 = new HashMap<String, Object>();

  2. list.add("1");
  1. list.add("2");
  1. map2.put("list", list); //网址id
  2.  
  3. map2.put("siteTag", "0");//网址类型
  1. public List<SysWeb> getSysInfo(Map<String, Object> map2) {
  2.   return getSqlSession().selectList("sysweb.getSysInfo", map2);
  3. }
  1. <select id="getSysInfo" parameterType="java.util.Map" resultType="SysWeb">
  2.   select t.sysSiteId, t.siteName, t1.mzNum as siteTagNum, t1.mzName as siteTag, t.url, t.iconPath
  3. from TD_WEB_SYSSITE t
  4. left join TD_MZ_MZDY t1 on t1.mzNum = t.siteTag and t1.mzType = 10
  5. WHERE t.siteTag = #{siteTag }
  6. and t.sysSiteId not in
  7. <foreach collection="list" item="item" index="index" open="(" close=")" separator=",">
  8. #{item}
  9. </foreach>
  10. </select>

MyBatis:参数传递 [转]的更多相关文章

  1. Mybatis参数传递及返回类型

    mybatis参数传递: 单个参数:不做特殊处理        #{参数名}:取出参数值    多个参数:做特殊处理        多个参数会被封装成一个map            key:para ...

  2. MyBatis参数传递

    一.单个参数: public List<XXBean> getXXBeanList(String xxCode); <select id="getXXXBeanList&q ...

  3. 1. Mybatis 参数传递

    方法1:顺序传参法 public User selectUser(String name, int deptId); <select id="selectUser" resu ...

  4. MyBatis进阶(一)

    MyBatis参数传递 1. MyBatis单参数传递 单参数传递不做特殊处理,直接取出参数值赋给xml文件,如#{id} 2. MyBatis多参数传递 多参数传递默认使用{arg1, arg0, ...

  5. MyBatis 各种参数传递方式

    MyBatis参数传递方式 情况一:Mapper映射器接口方法参数只有一个且为基本类型 接口方法: public List<UserEntity> selectUserByAge(int ...

  6. MyBatis快速上手与知识点总结

    目录 1.MyBatis概述 1.1 MyBatis概述 1.2 JDBC缺点 1.3 MyBatis优化 2.MyBatis快速入门 3.Mapper代理开发 3.1 Mapper代理开发概述 3. ...

  7. 慕课网金职位 Java工程师2020 百度网盘下载

    百度网盘链接:https://pan.baidu.com/s/1xshLRO3ru0LAsQQ0pE67Qg 提取码:bh9f 如果失效加我微信:610060008[视频不加密,资料代码齐全,超清一手 ...

  8. Mybatis中自定义映射xml参数传递使用

    在使用mybatis框架时,大多时候自动生成的mapper.xml文件能满足我们所需的数据库操作,但一些情况下还是需要我们自己写sql:为了加深印象,总结了下参数传递的方式以及各个关键字的含义如下: ...

  9. MyBatis多参数传递之注解方式示例--转

    原文地址:http://legend2011.blog.51cto.com/3018495/1015003 若映射器中的方法只有一个参数,则在对应的SQL语句中,可以采用#{参数名}的方式来引用此参数 ...

随机推荐

  1. 网络协议抓包分析——IP互联网协议

    前言 IP协议是位于OSI模型的第三层协议,其主要目的就是使得网络间可以相互通信.在这一层上运行的协议不止IP协议,但是使用最为广泛的就是互联网协议. 什么是IP数据报 TCP/IP协议定义了一个在因 ...

  2. 十分钟了解ZAB(Zookeeper Atomic Broadcast)协议

    Zookeeper基于ZAB(Zookeeper Atomic Broadcast),实现了主备模式下的系统架构,保持集群中各个副本之间的数据一致性. ZAB协议定义了选举(election).发现( ...

  3. Django 系列博客(四)

    Django 系列博客(四) 前言 本篇博客介绍 django 如何和数据库进行交互并且通过 model 进行数据的增删查改 ORM简介 ORM全称是:Object Relational Mappin ...

  4. navicat连接不上Linux服务器上的MySQL

    1.首先确定你的linux已经关闭防火墙 详细操作点这里: 如果是公司服务器防火墙比较重要不能关闭,那就麻烦点了,需要在防火墙的配置文件下配置属性. 如果还不能解决,请继续往下看. 2.如果是云服务器 ...

  5. JQuery官方学习资料(译):操作元素

      获取和设置元素的信息     有很多种方式可以改变现有的元素,最常见的是改变HTML内容或者元素的属性.JQuery提供了简单的夸浏览器的方法来帮助你实现元素信息的获取和设置. .html():获 ...

  6. frp 初探

    条件: (1) 服务器端要有公网 IP (2) 客户端能上网,能够访问服务器的公网 IP 下载 https://github.com/fatedier/frp/releases 根据服务器和客户端的操 ...

  7. 数据库索引(Oracle和Mysql)学习总结

    旭日Follow_24 的CSDN 博客 ,全文地址请点击: https://mp.csdn.net/postedit/80910082 索引概念:     索引是关系数据库中用于存放每一条记录的一种 ...

  8. 构造方法为private与类修饰符为final

    构造方法为private的:在这个类外1:不能继承这个类2:不能用new来产生这个类的实例 在这个类内:1:可以继承这个类2:可以用new来产生这个类的实例 类修饰符为final的:在这个类外1:不能 ...

  9. date('Y-m-d H:i:s',time()) 与 date('Y-m-d h:i:s',time())区别是什么

    date('Y-m-d H:i:s',time()) 按24小时制 date('Y-m-d h:i:s',time()) 按12小时制

  10. jfinal框架学习过程

    刚刚学习jfinal,通过一天左右的时间大体上理解了这个框架的用法,我对他的理解是JFinal 是基于 Java 语言的极速 WEB + ORM 框架,其核心设计目标是开发迅速.代码量少.学习简单.功 ...