MyBatis select标签的用法
From《MyBatis从入门到精通》
第一步,在接口中添加方法:
public interface UserMapper {
SysUser selectById(Long id);
}
第二步,完成映射文件:
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper
PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="tk.mybatis.simple.mapper.UserMapper">
<!--
对接口和接口方法映射的讲解:
XML与接口是通过namespace的值设置为接口的全限定名称进行关联
XML与接口中的方法是通过select标签的id属性值和定义的接口方法名一致进行关联
如果接口方法中没有和XML中的id属性值相对应,启动程序就会报错。
映射XML和接口的命名需要符合如下规则:
1.当只只用XML而不使用接口的时候,namespace的值可以设置为任意不重复的名称
2.标签的id属性值在任何时候都不能出现英文句号“.”,并且同一个命名空间下不能出现重复的id
3.因为接口中的方法是可以重载的,所以接口中所有的同名方法会对应XML中的同一个id的方法。
最常见的用法是,同名方法中其中一个增加衣蛾RowBound类型的参数用于实现分页查询。
-->
<!--
resultMap是一种很重要的配置结果映射的方法,resultMap的属性:
id:必填,并且唯一。
type:用于配置查询列所映射到的Java对象类型
extends:选填,可以配置当前的resultMap继承自其他的resultMap,属性值为继承resultMap的id
autoMapping:选填,用于配置是否启用非映射字段(没有在resultMap中配置的字段)的自动映射功能
该配置可以覆盖全局的autoMappingBehavior配置(!!!针对没有在resultMap中配置的字段)
resultMap包含的标签:
<constructor>:配置用构造方法注入结果,包含两个字标签
<idArg>:id参数,标记结果作为id(唯一值),可以帮助提高整体性能
<arg>:注入到构造方法的一个普通结果
<id>:id参数,标记结果作为id(唯一值),可以帮助提高整体性能
<result>:主导到Java对象属性的普通结果
====================================================
后面会详细讲解的部分
====================================================
<association>:一个复杂的类型关联,许多结果将包装成这种类型
<collection>:复杂类型的集合
<discriminator>:根据结果值来决定使用哪个结果映射
<case>:基于某些值的结果映射
====================================================
====================================================
id和result标签包含的属性:
column:从数据库得到的列名(来源于数据库的数据)
property:映射到列结果的属性(来源与resultMap标签type属性指明的对象的属性)
===================================================================
这部分我还没有遇到过,还不是很熟悉
===================================================================
javaType:如果映射到一个JavaBean,Mybatis通常可以自动的判断属性的类型
如果映射到HashMap,则需要明确的指明javaType。
jdbcType:列对应的数据库类型。JDBC类型仅仅需要对插入、更新、删除操作可能为空
的列进行处理。这是JDBC jdbcType的需要,而不是MyBatis的需要。
typeHandler:使用这个属性可以覆盖默认的类型处理器。这个属性值是类的完全限定
名或者类型别名。
===================================================================
===================================================================
-->
<resultMap id="userMap" type="tk.mybatis.simple.model.SysUser">
<id property="id" column="id"/>
<result property="userName" column="user_name"/>
<result property="userPassword" column="user_password"/>
<result property="userEmail" column="user_email"/>
<result property="userInfo" column="user_info"/>
<result property="headImg" column="head_img" jdbcType="BLOB"/>
<result property="createTime" column="user_password" jdbcType="TIMESTAMP"/>
</resultMap>
<!--
<select>:映射查询语句使用的标签
id:命名空间唯一标识符,可用来代表这句话
resultMap:用来设置返回值的类型和映射关系
#{id}:MyBatis SQL中使用预编译参数的一种方式,这个id需要与形式参数一模一样么
-->
<select id="selectById" resultMap="userMap">
SELECT * FROM sys_user WHERE id = #{id}
</select>
</mapper>
第三步,如何在程序中使用
@Test
public void testSelectById(){
SqlSession sqlSession=getSqlSession();
try{
/*
这个地方和以前的代码比,已经发生了变化:
List<Country> countryList = sqlSession.
selectList("tk.mybatis.simple.mapper.CountryMapper.selectAll");
以前这个地方,使用的是从sqlSession中通过xml文件的命名空间集selectId找到一个方法,
而现在直接通过接口的方式,相对而言十分的方便。
*/
UserMapper userMapper = sqlSession.getMapper(UserMapper.class);
SysUser user = userMapper.selectById(1L);
Assert.assertNotNull(user);
Assert.assertEquals("admin",user.getUserName());
}finally {
sqlSession.close();
}
}
MyBatis select标签的用法的更多相关文章
- MyBatis foreach标签的用法
From<MyBatis从入门到精通> 一.foreach实现in集合 1.映射文件中添加的代码: <!-- 4.4 foreach用法 SQL语句有时会使用IN关键字,例如id i ...
- MyBatis bind标签的用法
From<MyBatis从入门到精通> <!-- 4.5 bind用法 bind标签可以使用OGNL表达式创建一个变量并将其绑定到上下文中. 需求: concat函数连接字符串,在M ...
- MyBatis if标签的用法
<!-- 4.1.1 在WHERE条件中使用if 需求: 实现一个用户管理高级查询功能,根据输入的条件去检索用户信息.这个功能 还需要支持以下三种情况:当只有输入用户名时,需要根据用户名进行模糊 ...
- mybatis001-动态标签Trim用法
Mybatis动态标签Trim用法 一.<trim></trim>标签用法 示例一: select * from user <trim prefix="WHER ...
- 9.mybatis动态SQL标签的用法
mybatis动态SQL标签的用法 动态 SQL MyBatis 的强大特性之一便是它的动态 SQL.如果你有使用 JDBC 或其他类似框架的经验,你就能体会到根据不同条件拼接 SQL 语句有多么 ...
- MyBatis映射文件4(参数获取#{}和${}/select标签详解[返回类型为list])
参数获取 之前我们都是采用#{}的方式进行参数传递,其实MyBatis还有另外的参数传递方式${} 使用方法相同,但是还是有很大区别的 这里做一个测试: <select id="get ...
- select标签multiple属性的用法
前些日子公司让做一个功能模块.对于里面一个小功能费了些周折,现将其总结一下: 一.实现效果: watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvZ2FvaHVh ...
- [刘阳Java]_MyBatis_映射文件的select标签入门_第3讲
1.Mybatis映射文件的<select>标签主要帮助我们完成SQL语句查询功能,<select>标签它包含了很多属性,下面简单对<select>标签的属性做一个 ...
- SpringMVC +mybatis+spring 结合easyui用法及常见问题总结
SpringMVC +mybatis+spring 结合easyui用法及常见问题总结 1.FormatString的用法. 2.用postAjaxFillGrid实现dataGrid 把form表单 ...
随机推荐
- Windows 10开发基础——启动默认应用的URI
主要内容:通过指定的URI来启动默认的应用(设置,应用商店,地图,人脉) 方法一:直接在XAML中添加如下代码 <TextBlock x:Name="LocationDisabledM ...
- SQLServer 使用sp_repldone标识所有未分发的事务为已分发
原文:SQLServer 使用sp_repldone标识所有未分发的事务为已分发 对于发布数据库的数据大量操作时,会使日志扫描并读取太多,会导致分发堵塞很久.也有一些解决方法,参考 <SqlSe ...
- SqlServer 可更新订阅升级字段队列数据丢失原因
原文:SqlServer 可更新订阅升级字段队列数据丢失原因 之前简单描述过数据冲突发生的原因:SQLServer可更新订阅数据冲突的一个原因 ,但具体内部原理是怎么丢失的还不清楚,今天补充说明.可更 ...
- Delphi 编写DLL动态链接库文件的知识和样例(有详细步骤,很清楚)
一.DLL动态链接库文件的知识简介: Windows的发展要求允许同时运行的几个程序共享一组函数的单一拷贝.动态链接库就是在这种情况下出现的.动态链接库不用重复编译或链接,一旦装入内存,Dlls函数可 ...
- MySQL学习-SQL约束
约束分类 主键:PRIMARY KEY用于唯一标识表中的一行,不可重复.e.g.:id INT(10) PRIMARY KEY 默认值:DEFAULT插入时,若没有指定该列的值,则为DEFAULT指定 ...
- DIY Delphi 半透明窗体(2)
写文章的时候 脑子有点乱 unit uMainForm; interface uses Windows, Messages, SysUtils, Variants, Classes, Graphics ...
- QT运行cmd指令(两种办法:QProcess.start然后waitForFinished,运行cmd /c命令)
QProcess p(); p.start("route");//写入要运行的指令即可 p.waitForStarted(); p.waitForFinished(); qDebu ...
- 【Web前端Talk】无聊吗?写个【飞机大战】来玩吧(上篇)
01前言介绍 微信小游戏是基于微信客户端的游戏,它即点即玩,无需下载安装,体验轻便,可以和微信内的好友一起玩,比如PK.围观等,享受小游戏带来的乐趣.那如何开发一款属于自己的小游戏呢? 源码地址: h ...
- MySQL 事务嵌套
MySQL默认自动提交(autocommit=1),如果要开启事务,先关闭自动提交(autocommit=0): InnoDB支持事务,MyISAM不支持: MySQL不支持事务嵌套:已经开启事务后, ...
- mysql数据库在linux下的导出和导入及每天的备份
mysql数据库的导出,导入 1. 导出数据库为sql文件 mysqldump 数据库名 -uroot -p > xxx.sql 导出数据表结构和数据 eg. mysqldump cloud ...