MyBatis学习(三)
前言
感觉学习进度还是比较慢啊,一整天的学习效率不是很高,一会看电视,一会喝茶,对自己的要求不严格...今天就说说关联表数据的插入以及别名的使用。
正文
1.关联插入
之前,我在数据库中已经创建了一张users表,现在我新增了一张手机表cellphone,用来记录用户手机的信息,结构如下所示:

其中cellphone对应的实体类为:
package org.tonny.entity; public class Cellphone
{
private int id; private int userId; private String number; private String city; public int getId()
{
return id;
} public void setId(int id)
{
this.id = id;
} public int getUserId()
{
return userId;
} public void setUserId(int userId)
{
this.userId = userId;
} public String getNumber()
{
return number;
} public void setNumber(String number)
{
this.number = number;
} public String getCity()
{
return city;
} public void setCity(String city)
{
this.city = city;
} @Override
public String toString()
{
return "Cellphone [id=" + id + ", userId=" + userId + ", number=" + number + ", city=" + city + "]";
} }
cellphone中的字段user_id是外键,对应于users表的主键id。那现在我需要插入用户信息,同时包含他的手机信息该如何操作呢?思路是这样,先向users表中插入记录,然后再向cellphone中插入相关的记录,可是user_id如何获取成了一个难题。同样MyBatis为我们提供了解决方案,通过配置文件实现,配置信息如下:
<insert id="addUserBeforeCellphone" parameterType="org.tonny.entity.User">
<!-- 使用selectKey标签,用于主键返回
keyProperty:接受返回主键的属性,本例对应到实体类User的id属性
order:insert语句生成主键的时机,mysql在执行操作之后(即AFTER),oracle是在执行操作之前
resultType:返回给实体类User的Id属性的数据类型
SQL语句:生成主键值的sql语句:SELECT LAST_INSERT_ID()-->
<selectKey keyProperty="id" order="AFTER" resultType="java.lang.Integer">
SELECT LAST_INSERT_ID()
</selectKey>
INSERT INTO users(name,age)
VALUES(#{name},#{age})
</insert> <insert id="addCellphone4User" parameterType="org.tonny.entity.Cellphone">
INSERT INTO cellphone(user_id, number, city)
VALUES(#{userId},#{number},#{city})
</insert>
我在增加user的时候,使用了selectKey标签,这个标签的作用就是用来返回数据插入users返回的主键值,其子标签内容也比较详细,不再赘述。同样的,我加入增加cellphone的语句。接着就是Java测试代码了:
public void addUserAndCellphone()
{
SqlSession sqlSession = sqlSessionFactory.openSession(); //插入User表
String sql = "org.tonny.mapper.UsersMapper.addUserBeforeCellphone";// 映射sql的标识字符串
User user = new User();
user.setName("Jerry Chien");
user.setAge(-2);
int result = sqlSession.insert(sql, user);
System.out.println("插入user执行结果:" + result); //插入手机号码
Cellphone cellphone = new Cellphone();
cellphone.setUserId(user.getId());
cellphone.setNumber("18915892672");
cellphone.setCity("nj");
sql = "org.tonny.mapper.UsersMapper.addCellphone4User";
result = sqlSession.insert(sql, cellphone);
System.out.println("插入cellphone执行结果:" + result); sqlSession.commit();
sqlSession.close();
}
就是先插入users表,执行int result = sqlSession.insert(sql, user);后,MyBatis就会给user的id赋值,可以通过user.getId()取出来。然后再执行另外一条语句即可。
执行结果:

2.别名使用
使用别名可以简化名字的使用。在mybatis.xml中增加配置信息,如下:
<!-- 定义别名 -->
<typeAliases>
<!-- type:源类型名称 alias:目标别名 下面的意思就是把"org.tonny.entity.User" 别名为 "user" -->
<typeAlias type="org.tonny.entity.User" alias="aliasUser" />
</typeAliases>
我在这里定义了别名,将类型org.tonny.entity.User简化为user。这个标签要注意顺序,在properties之后,在enviroments之前,否则会报下面的错误。

完整内容如下:
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE configuration PUBLIC "-//mybatis.org//DTD Config 3.0//EN" "http://mybatis.org/dtd/mybatis-3-config.dtd"> <configuration>
<!-- 指定数据库信息文件 -->
<properties resource="db.properties"></properties> <!-- 定义别名 -->
<typeAliases>
<!-- type:源类型名称 alias:目标别名 下面的意思就是把"org.tonny.entity.User" 别名为 "user" -->
<typeAlias type="org.tonny.entity.User" alias="user" />
</typeAliases> <!-- 数据库环境配置如果和spring整合就不需要配置了,完全交给spring -->
<!-- environments中可以配置多个数据库,但是同一时间只能使用一个。
default标识当前默认使用的数据库,当前默认使用mysql
-->
<environments default="mysql">
<environment id="mysql">
<!-- 事务管理器,当前只使用了mybatis框架,所以使用jdbc事务管理器。
如果与spring集成的话,可以使用spring的事务管理器 -->
<transactionManager type="JDBC" />
<!-- 配置数据库连接信息,使用数据库连接池(POOLED)方式连接 -->
<dataSource type="POOLED">
<property name="driver" value="${driver}" />
<property name="url" value="${url}" />
<property name="username" value="${name}" />
<property name="password" value="${password}" />
</dataSource>
</environment>
</environments> <!-- 管理每张表的映射文件 -->
<mappers>
<!-- 需要将每张表的配置文件加载进来,使用resource引入 -->
<mapper resource="org/tonny/mapper/UsersMapper.xml" />
<mapper resource="org/tonny/mapper/PersonMapper.xml" />
</mappers>
</configuration>
这样就可以使用了,下面代码配置了通过别名的方式来查询数据。
<select id="getUserByMapUsingAlias" parameterType="java.util.Map" resultType="user">
SELECT *
FROM users WHERE id=#{id} and name like #{name}
</select>
测试代码如下:
@Test
public void getUserByMapUsingAlias()
{
SqlSession sqlSession = sqlSessionFactory.openSession();
// 映射sql的标识字符串
String sql = "org.tonny.mapper.UsersMapper.getUserByMapUsingAlias";
Map<String, Object> param = new HashMap<String, Object>();
param.put("id", 1);
param.put("name", "%Chien%");
List<User> userList = sqlSession.selectList(sql, param);
sqlSession.close();
System.out.println(userList);
}
执行结果:

后记
今天记录下来的内容比较少,明天继续....
MyBatis学习(三)的更多相关文章
- MyBatis学习(三)---MyBatis和Spring整合
想要了解MyBatis基础的朋友可以通过传送门: MyBatis学习(一)---配置文件,Mapper接口和动态SQL http://www.cnblogs.com/ghq120/p/8322302. ...
- mybatis学习三
Mybatis与pageHelper分页: 分页分为假分页和真分页对应的专业术语叫做逻辑分页和物理分页 逻辑分页:将所有的数据从数据库查询出来,根据需求截取符合要求的数据返回,方便统一但效 ...
- mybatis 学习三 关键文件解析
1: mybatis-config.xml <?xml version="1.0" encoding="UTF-8" ?> <!DOCTYP ...
- mybatis 学习三 mapper xml 配置信息
mapper xml 映射文件 1,select 标签 简单是用就这样,其中resultType 代表从这条语句中返回的期望类型的类的完全限定名或别名.也可以使用resultMap对应的id ...
- mybatis学习三 数据库连接池技术
1.在内存中开辟一块空间,存放多个数据库连接对象.就是Connection的多个实例2. 连接池技术有很多,c3p0,dbcp,druid,以及JDBC Tomcat Pool, JDBC Tomca ...
- MyBatis学习系列三——结合Spring
目录 MyBatis学习系列一之环境搭建 MyBatis学习系列二——增删改查 MyBatis学习系列三——结合Spring MyBatis在项目中应用一般都要结合Spring,这一章主要把MyBat ...
- MyBatis学习 之 三、动态SQL语句
目录(?)[-] 三动态SQL语句 selectKey 标签 if标签 if where 的条件判断 if set 的更新语句 if trim代替whereset标签 trim代替set choose ...
- 【转】MyBatis学习总结(三)——优化MyBatis配置文件中的配置
[转]MyBatis学习总结(三)——优化MyBatis配置文件中的配置 一.连接数据库的配置单独放在一个properties文件中 之前,我们是直接将数据库的连接配置信息写在了MyBatis的con ...
- MyBatis学习总结(三)——多表关联查询与动态SQL
在上一章中我们学习了<MyBatis学习总结(二)——MyBatis核心配置文件与输入输出映射>,这一章主要是介绍一对一关联查询.一对多关联查询与动态SQL等内容. 一.多表关联查询 表与 ...
随机推荐
- 转:Apache-Tomcat各发布包说明
下载地址:http://tomcat.apache.org/发布包说明: apache-tomcat-[version].zip---------------------------基本发布包.这些发 ...
- 书写优雅的shell脚本(五)- shell中(())双括号运算符
在使用shell的逻辑运算符"[]"使用时候,必须保证运算符与算数之间有空格. 四则运算也只能借助:let,expr等命令完成. 今天讲的双括号"(())"结构 ...
- BZOJ_2251_[2010Beijing Wc]外星联络_后缀数组
BZOJ_2251_[2010Beijing Wc]外星联络_后缀数组 Description 小 P 在看过电影<超时空接触>(Contact)之后被深深的打动,决心致力于寻 找外星人的 ...
- 「LuoguP4753」濑 River Jumping(贪心
Description 有一条宽度为 N 的河上,小D位于坐标为 0 的河岸上,他想到达坐标为 N 的河岸上后再回到坐标为 0 的位置.在到达坐标为 N 的河岸之前小D只能向坐标更大的位置跳跃,在到达 ...
- python利用mongodb上传图片数据 : GridFS 与 bson两种方式
利用mongodb保存图片通常有两种方法,一种是将图片数据转化为二进制作为字典的键值对进行保存,另一种是利用mongodb提供的GridFS进行保存,两者各有利弊.性能方面的优劣未曾测试,无法进行评价 ...
- 【前端】CentOS 7 系列教程之五: 安装最新版 nginx 并转发 node 服务
转载请注明出处:http://www.cnblogs.com/shamoyuu/p/linux_5.html 进入/usr/local目录 cd /usr/local 下载最新版的ngxin压缩包 w ...
- Linux终端那件事儿
我们将会讨论如何更好的控制用户终端:也就说是键盘输入与屏幕输出.除了这些,我们还会了解我们编写的程序如何由用户处读取输入,即使是在输入重定向的情况下,以及确保输出到屏幕的正确位置.这里所提供的一些底层 ...
- UI控件初始化问题:initWithFrame和initWithCoder、aweakFromNib的执行
在iOS学习和程序开发过程中,我们经常会遇到一些自定义UI控件或控制器在初始化时出现问题,尤其在大家刚开始接触时,几种初始化方法的作用以及调用的时机往往容易混淆,这也跟我们对iOS程序设计中,类的创建 ...
- F - Candy Bags
A. Candy Bags time limit per test 1 second memory limit per test 256 megabytes input standard input ...
- 2.25-2.26 MapReduce执行流程Shuffle讲解
原文链接:https://langyu.iteye.com/blog/992916 Shuffle过程是MapReduce的核心,也被称为奇迹发生的地方.要想理解MapReduce, Shuffle是 ...