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. 你不知道的JavaScript--Item6 var预解析与函数声明提升(hoist )

    1.var 变量预编译 JavaScript 的语法和 C .Java.C# 类似,统称为 C 类语法.有过 C 或 Java 编程经验的同学应该对"先声明.后使用"的规则很熟悉, ...

  2. Doctype作用?标准模式与兼容模式各有什么区别?

    Doctype作用?标准模式与兼容模式各有什么区别? DOCTYPE是document type(文档类型)的简写,用来告诉浏览器的解析器使用哪种HTML或XHTML规范解析页面.DOCTYPE不存在 ...

  3. [SQL Server]用 C# 在 LinqPad 建立 Linked Server 跨服务器数据库操作

    在涉及老项目数据迁移的时候,数据库结构已经完全发生变化,而且需要对老数据进行特殊字段的处理,而且数据量较大,使用Navicat导出单表之后,一个表数据大概在100多万的样子,直接导出SQL执行根本行不 ...

  4. MySQL使用一张表的字段更新另一张表的字段

    转自https://blog.csdn.net/anxpp/article/details/73173274 update table1 t1 left join table2 t2 on t1.ke ...

  5. go源文件中是否有main函数

    import (    "go/parser" "go/token"    "go/ast"  )  func HasMain(file s ...

  6. retry.go

    package clientv3 import (     "github.com/coreos/etcd/etcdserver/api/v3rpc/rpctypes"     p ...

  7. React组件设计

    React组件设计 组件分类 展示组件和容器组件 展示组件 容器组件 关注事物的展示 关注事物如何工作 可能包含展示和容器组件,并且一般会有DOM标签和css样式 可能包含展示和容器组件,并且不会有D ...

  8. javascript的键盘事件大全

    javascript的键盘事件大全 ------------------------------------------------------------------- 使用event对象的keyC ...

  9. 计算机17-3,4作业E

    E.complete number Description 完数是指一个整数的因子和等于这个数本身,例如6=1+2+3,所以6是一个完数. 按照给定数据范围,找出期中所有完数并输出. Input 数据 ...

  10. Scala 枚举介绍及深入应用

    本文详细地总结了Scala枚举的几种实现方式,对我们更好地进行函数式编程有很好地指导和帮助. Scala 枚举示例和特性 枚举(Enumerations)是一种语言特性,对于建模有限的实体集来说特别有 ...