11、mybatis的映射xml中参数类型的别名
在mapper.xml中,定义很多的statement,statement需要parameterType指定输入参数的类型、需要resultType指定输出结果的映射类型。
如果在指定类型时输入类型全路径,不方便进行开发,可以针对parameterType或resultType指定的类型定义一些别名,在mapper.xml中通过别名定义,方便开发。
在mybatis的开发中, 实体类对应的映射xml配置文件(比如UserMapper.xml等)里面的sql语句(比如:
<select id="findUserByid" parameterType="int" resultType="store.cloudspace.pojo.User">
SELECT * FROM USE WHERE id = #{id}
</select>
)都需要有输入/输出参数类型(上面的parameterType/resultType)。其中前者完整的写法应该是:parameterType="java.lang.Integer",但是在这里mybatis已经自动转换了,mybatis支持自动的类型有:



所以入参的类型一般不需要我们转换,但是输出参数的类型却需要我们做一些事情,因为输出参数大部分是某个包里面的实体类型。那么,我们该如何自定义这些类型呢?
返回值
返回值用resultType指定其类型,类型为简单类型,map,类等。
类型的形式为:
string java.lang.String
int java.lang.Integer
...
map java.util.Map
类 类的全路径,如self.exercise.model.User
举例说明:
返回值只是一个简单的数据类型。
<select id="getUserName" resultType="string">
select user_name from user where id = 1
</select>
String userName = sqlSession.selectOne("self.eercise.dao.UserDao.getUserName");
如果是多个字段对应的多个返回值,可以返回值类型设为map或类。
返回值为map,字段名会自动映射成key,属性名映射为key值;返回值为类,类中的变量名必须跟数据库中的字段名或者字段别名相同才可以,否则即使数据库中的字段值不为空,在类中对应的变量值也为空。
如果返回值不止一个,而是多个记录的结果集,返回值类型应设为为泛型,得到的结果集会自动封装到List集合中。
<select id="load_map" resultType="map" parameterType="map">
select * from user where id = #{id} and account = #{account}
</select>
Map<String, Object> map = new HashMap<String, Object>();
map.put("id", 1);
map.put("account", "dva");
List<Map<String, Object>> listMap = sqlSession.selectList("self.exercise.dao.UserDao.load_map", map);
参数
当只有一个参数时,参数类型用parameterType指定类型,可以是简单类型,map或者对象。
如果参数是一个简单的数据类型,那么#{param}中的param可以任意取名。
<select id="getUserName" resultType="string" parameterType="int">
select user_name from user where id = #{id}
</select>
String userName = sqlSession.selectOne("self.exercise.dao.UserDao.getUserName",1);
另外,在参数是一个简单类型的情况下,如果控制台报如下错误:
Caused by: org.apache.ibatis.reflection.ReflectionException: There is no getter for property named 'user_name' in 'class java.lang.String'
那么要将param改名为_parameter,具体原因还不清楚。。。在何种情况下使用也不清楚,目前我只能通过控制台报错来获取线索。如果有知道的dalao还请告知,谢谢。
如果有多个参数,有两种方法可以实现传参。
一 可以将参数封装到map或者类中
在parameterType中指明容器的类型即可;param取名要与map中的key或者类中的变量名相同,这样获取值时才会正确映射。例如上面load_map的例子。
二 直接传递参数,这种方式只有接口代理的才能使用。
这种情况下不用在映射文件中指明参数类型,又分三种解决方式。
(一)用0,1,2....来指明第几个参数
//接口中的方法
User getUser(String user_name,String account);
映射文件中的语句应为
<select id="getUser" resultType="sel.exercise.dao.UserDao">
select user_name from user where user_name = #{0} and account = #{1}
</select>
(二)用param1,param2...来代替参数
//接口中的方法
User getUser(String user_name,String account);
映射文件中的语句应为
<select id="getUser" resultType="sel.exercise.dao.UserDao" >
select user_name from user where user_name = #{param1} and account = #{param2}
</select>
前两种方式,where语句中字段名的顺序必须严格遵循接口中方法参数的顺序。
(三)@Param方法进行映射
//接口中的方法
User getUser(@Param("userName") String user_name,@Param("account") String account);
映射文件中的语句应为
<select id="getUser" resultType="sel.exercise.dao.UserDao" >
select user_name from user where user_name = #{userName} and account = #{account}
</select>
注意,#{param}中的param名为@Param方法映射出的新的参数名
11、mybatis的映射xml中参数类型的别名的更多相关文章
- Mybatis配置文件SqlMapConfig.xml中的标签
SqlMapConfig.xml配置文件中的属性 1 配置内容 properties(属性) settings(全局配置参数) typeAliases(类型别名) typeHandlers(类型处理器 ...
- Spring Boot (11) mybatis 关联映射
一对多 查询category中的某一条数据,同时查询该分类下的所有Product. Category.java public class Category { private Integer id; ...
- Mybatis配置映射文件中parameterType的用法小结
原创: 在mybatis映射接口的配置中,有select,insert,update,delete等元素都提到了parameterType的用法,parameterType为输入参数,在配置的时候,配 ...
- MyBatis 关系映射XML配置
关系映射 在我看来这些实体类就没啥太大关联关系,不就是一个sql语句解决的问题,直接多表查询就完事,程序将它设置关联就好 xml里面配置也是配置了sql语句,下面给出几个关系的小毛驴(xml) 一对多 ...
- Python函数中参数类型
在学习Python函数的时候,函数本身的定义和调用并不是很复杂,但是函数的参数类型和用法的确有些复杂.在此做一个小结,加深理解. Python参数的定义 负责给函数提供一些必要的数据或信息,以保证函数 ...
- mybatis where in语句中参数过多
ps : mybatis在in中参数过多 出现问题 com.microsoft.sqlserver.jdbc.SQLServerException: 传入的请求具有过多的参数.该服务器支持最多 210 ...
- mybatis配置文件xxxx.xml中缺失返回类型的后果A query was run and no Result Maps were found
使用mybatis时出现异常问题: 有如下的错误 Error querying database. Cause: org.apache.ibatis.executor.ExecutorExcepti ...
- Hibernate映射数据库中longtext类型属性时报错No Dialect mapping for JDBC type: -1的解决方案
出现错误的原因是:hibernate中对于数据库的longtext数据类型不支持. 解决方案: 1.写个类集成方言,然后自己实现对longtext的支持 import java.sql.Types; ...
- Spring集成mybatis时mybatis的映射XML配置
<?xml version="1.0" encoding="UTF-8" ?> <!DOCTYPE mapper PUBLIC "- ...
随机推荐
- jenkins设置
selenium.common.exceptions.WebDriverException: Message: 'chromedriver' executable needs to be in PAT ...
- windows脚本(VBS)之cmd命令行的妙用
windows脚本(VBS)之cmd命令行的妙用 (2009-08-06 13:40:55) 转载▼ 标签: 脚本 cmd 命令行 vbs js 简单 公式 windows it 分类: 计算机 脚本 ...
- SpringMVC中的 --- 异常处理
系统异常处理器SimpleMappingExceptionResolver 处理器方法执行过程中,可能会发生异常,不想看到错误黄页,想看到一个友好的错误提示页. 自定义异常处理器 使用异常处理注解
- 使用poi读取word2007(.docx)中的复杂表格
使用poi读取word2007(.docx)中的复杂表格 最近工作需要做一个读取word(.docx)中的表格,并以html形式输出.经过上网查询,使用了poi. 对于2007及之后的word文档,需 ...
- DCloud-MUI:事件管理
ylbtech-DCloud-MUI:事件管理 极简的JS函数 1.返回顶部 1.事件绑定 除了可以使用addEventListener()方法监听某个特定元素上的事件外, 也可以使用.on()方法实 ...
- 利用python+tkinter开发一个点名软件
最近上课学生多名字记不住,名册忘记了带,要点名怎么办,好久没有写代码了,于是自己写了个点名软件,记录下吧,第一次接触TK也不是太熟悉,写的不太好,记录下源代码 以后遇到要写桌面软件还是可以耍耍的. t ...
- [BZOJ2017][Usaco2009 Nov]硬币游戏(要复习系列)
又是DP? 好吧,或者说是博弈论,但是我不会啊. 先搞个O(n^3)的记忆化搜索,然后瞎搞好像发现两个状态几乎一样? 竟然过了样例,然后竟然A了... #include<iostream> ...
- C#中通过js实现个人用户和非个人用户的登陆
实现用户的登录功能,这里举一个个人和非个人用户的登录的例子 前台代码: <ul class="login_list clearfix"> <li> < ...
- Laravel5.1学习笔记7 视图
视图 (View) 基本用法 传递数据到视图 在多个视图中分享数据 视图组件 #基本用法 视图里面包含了你应用程序所提供的 HTML 代码,并且提供一个简单的方式来分离控制器和网页呈现上的逻辑.视 ...
- (转)Vue 爬坑之路(一)—— 使用 vue-cli 搭建项目
vue-cli 是一个官方发布 vue.js 项目脚手架,使用 vue-cli 可以快速创建 vue 项目,GitHub地址是:https://github.com/vuejs/vue-cli 一. ...