mybatis入门系列二之详解输入与输出参数

 

基础知识

 

mybatis规定mapp.xml中每一个SQL语句形式上只能有一个@parameterType和一个@resultType

1、 返回值是一个对象的集合,@resultType中只能写该对象的类型,而不是写list<T>

2、 输入参数可以用#{}和${}两种取值方法,两者区别与联系:

1、 当传入类型为JDBC基本类型(8种java基本类型+String)时,#{}里面可以写成任意值,${}里面必须写value  

2、 当传入类型为对象时,两种方式里面都应该写成类中属性名

3、 #{}方式传值会将传入的值当做一个字符串处理,会自动将其加入"",而${}方式则不会  

4、 #{}方式能够有效防止SQL注入,而${}不会,因此能够用#{}就不要用${}

5、 ${}的适用场景是利用数据库中的字段动态排序等例如想要根据id排序
如果用#{}传入id,SQL语句会变成order by "id"这样的SQL语句不能排序,
因此只能用${},对应的SQL语句是order by id符合要求

 

输入参数@parameterType

 

输入参数为基本类型

当输入参数为JDBC基本类型,则可以直接用#{xxx}或者${value}取值

 

输入参数为对象

当输入参数为对象时,则可以用#{属性名}或者${属性名}取值

 

输入参数为HashMap

则#{key}即可取得该key对应的value

<select id="queryStudentBystuageOrstuNameWithHashMap" 	parameterType="HashMap"	resultType="student" >
select stuno,stuname,stuage from student
where stuage= #{stuAge} or stuname like '%${stuName}%'
<select/>

 

输出参数@resultType

 

输出参数为JDBC基本数据类型

直接写输出类型

 

输出参数为类对象(或者类对象的集合)

这时要求数据库中的属性名、属性类型要与类对象能够对应

 

输出参数为HashMap

<!-- 别名作为Map的key -->
<select id="queryStudentOutByHashMap" resultType="HashMap" >
select stuno "no",stuname "name" from student where stuno=1
<select/>

 

HashMap<String,Object> studentMap = studentMapper.queryStudentOutByHashMap();
System.out.println(studentMap.get(no));

 

输出参数为广义类对象,但是属性名或者属性类型不能对应

例如数据库person表中属性为int id,varchar(20) name

对应的实体类属性为int num,varchar(20) name

若直接查询select * from person会报错

 

解决方法一:resultMap(适用于属性名或者属性类型不同且不能自动转换)

以下示例为属性名不同,属性类型不同且不能自动转换应该自定义类型转换器,会单独开文章介绍

<select id="XXX" @resultMap="queryWithResultmap">
select id,name from person
<select/>
<resultMap type = "person" id="queryWithResultmap">
<!-- 指定实体类属性与数据库属性之间的关系,主键用id标签,非主属性用result属性-->
<id property="num",column="id">
<result property="name" column="name">
</resultMap>

 

解决方法二:resultType+HashMap(适用于属性名不同)

<select id="XXX" @resulttype="person">
select id "num", name "name" from person
</select>

mybatis入门系列二之输入与输出参数的更多相关文章

  1. Java I/O系统学习系列二:输入和输出

    编程语言的I/O类库中常使用流这个抽象概念,它代表任何有能力产出数据的数据源对象或者是有能力接收数据的接收端对象.“流”屏蔽了实际的I/O设备中处理数据的细节. 在这个系列的第一篇文章:<< ...

  2. MyBatis入门(二)—— 输入映射和输出映射、动态sql、关联查询

    一.输入映射和输出映射 1. parameterType(输入类型) 1.1 传递简单类型 <select id="getUserById" parameterType=&q ...

  3. JavaWeb_(Mybatis框架)输入和输出参数_五

    系列博文: JavaWeb_(Mybatis框架)JDBC操作数据库和Mybatis框架操作数据库区别_一 传送门 JavaWeb_(Mybatis框架)使用Mybatis对表进行增.删.改.查操作_ ...

  4. mybatis入门系列三之类型转换器

    mybatis入门系列三之类型转换器 类型转换器介绍 mybatis作为一个ORM框架,要求java中的对象与数据库中的表记录应该对应 因此java类名-数据库表名,java类属性名-数据库表字段名, ...

  5. C# 互操作性入门系列(二):使用平台调用调用Win32 函数

    好文章搬用工模式启动ing ..... { 文章中已经包含了原文链接 就不再次粘贴了 言明 改文章是一个系列,但只收录了2篇,原因是 够用了 } --------------------------- ...

  6. [转]C# 互操作性入门系列(二):使用平台调用调用Win32 函数

    传送门 C#互操作系列文章: C# 互操作性入门系列(一):C#中互操作性介绍 C# 互操作性入门系列(二):使用平台调用调用Win32 函数 C# 互操作性入门系列(三):平台调用中的数据封送处理 ...

  7. Maven入门系列(二)--设置中央仓库的方法

    原文地址:http://www.codeweblog.com/maven入门系列-二-设置中央仓库的方法/ Maven仓库放在我的文档里好吗?当然不好,重装一次电脑,意味着一切jar都要重新下载和发布 ...

  8. MyBatis学习系列二——增删改查

    目录 MyBatis学习系列一之环境搭建 MyBatis学习系列二——增删改查 MyBatis学习系列三——结合Spring 数据库的经典操作:增删改查. 在这一章我们主要说明一下简单的查询和增删改, ...

  9. python入门(6)输入和输出

    python入门(6)输入和输出 输出 >>> print 'hello, world' >>> print 'The quick brown fox', 'jum ...

随机推荐

  1. SpringCloud微框架系列整体模块梳理

    以下为Spring Cloud的核心功能: 分布式/版本化配置服务注册和发现路由服务和服务之间的调用负载均衡断路器分布式消息传递 通过这张图,我们来了解一下各组件配置使用运行流程: 1.请求统一通过A ...

  2. 最强AngularJS资源合集

    AngularJS是Google开源的一款JavaScript MVC框架,弥补了HTML在构建应用方面的不足,其通过使用指令(directives)结构来扩展HTML词汇,使开发者可以使用HTML来 ...

  3. stop_token.go

    package engine import (     "bufio"     "log"     "os" ) type StopToke ...

  4. 【最小生成树】UVA1494Qin Shi Huang's National Road System秦始皇修路

    Description During the Warring States Period of ancient China(476 BC to 221 BC), there were seven ki ...

  5. BZOJ_1334_[Baltic2008]Elect_DP+语文题

    BZOJ_1334_[Baltic2008]Elect_DP Description N个政党要组成一个联合内阁,每个党都有自己的席位数. 现在希望你找出一种方案,你选中的党的席位数要大于 总数的一半 ...

  6. qtchooser

    qtchooser 的配置目录: /usr/lib/x86_64-linux-gnu/qtchooser qtchooser 的真实配置目录: /usr/share/qtchooser qtchoos ...

  7. (1)STM32使用HAL库操作GPIO

    一  初始化GPIO 使用HAL库的优点在于不用手动添加初始化的代码了,CubeMX会根据软件设置自动生成. 自动生成的HAL库GPIO初始化代码: static void MX_GPIO_Init( ...

  8. 报文ISO8583协议

    本人刚接触金融IT行业,对报文ISO8583协议也是刚刚了解,看了篇文章,个人觉得写得很好,特此分享如下: 如果单纯的讲IS08583那些字段的定义,我觉得没有什么意思,标准中已经对每个字段解释的非常 ...

  9. IE不兼容ES6箭头函数的解决方法(在浏览器中使用)

    polyfill.js下载方法: npm install babel-polyfill --save 页面中引用"polyfill.js" 和 "browser.min. ...

  10. <转>快速找到整数约数集方法<python><stackoverflow>

    [背景] 我需要从N遍历到1,当我已经判断N不符合要求时,我知道N的所有约数也是不符合的,所以所有N的约数也不用遍历.因此,对于遍历的每个N,我需要快速找到它的所有约数,放到一个集合里面,而当我遍历到 ...