XML 映射器
MyBatis 的真正强大在于它的语句映射,这是它的魔力所在。由于它的异常强大,映射器的 XML 文件就显得相对简单。如果拿它跟具有相同功能的 JDBC 代码进行对比,你会立即发现省掉了将近 95% 的代码。MyBatis 致力于减少使用成本,让用户能更专注于 SQL 代码。
SQL映射文件只有很少的几个顶级元素(按照应被定义的顺序列出):
cache – 该命名空间的缓存配置。
cache-ref – 引用其它命名空间的缓存配置。
resultMap – 描述如何从数据库结果集中加载对象,是最复杂也是最强大的元素。
parameterMap – 老式风格的参数映射。此元素已被废弃,并可能在将来被移除!请使用行内参数映射。文档中不会介绍此元素。
sql – 可被其它语句引用的可重用语句块。
insert – 映射插入语句。
update – 映射更新语句。
delete – 映射删除语句。
select – 映射查询语句。
select
Select元素来定义查询操作。
<select id="selectOneById" resultType="org.pearl.mybatis.demo.pojo.entity.User" databaseId="mysql">
select * from base_user where user_id ={id}
</select>
select 元素允许你配置很多属性来配置每条语句的行为细节。
<select
id="selectPerson"
parameterType="int"
parameterMap="deprecated"
resultType="hashmap"
resultMap="personResultMap"
flushCache="false"
useCache="true"
timeout="10"
fetchSize="256"
statementType="PREPARED"
resultSetType="FORWARD_ONLY">
Select 元素的属性:
insert, update 和 delete
数据变更语句 insert,update 和 delete 的实现非常接近:
<insert
id="insertAuthor"
parameterType="domain.blog.Author"
flushCache="true"
statementType="PREPARED"
keyProperty=""
keyColumn=""
useGeneratedKeys=""
timeout="20">
<update
id="updateAuthor"
parameterType="domain.blog.Author"
flushCache="true"
statementType="PREPARED"
timeout="20">
<delete
id="deleteAuthor"
parameterType="domain.blog.Author"
flushCache="true"
statementType="PREPARED"
timeout="20">
Insert, Update, Delete 元素的属性:
简单使用案例:
为了方便调试,在settings中配置日志输出到控制台
<setting name="logImpl" value="STDOUT_LOGGING" />
1、 添加接口;
public interface UserMapper {
User selectOneById(Long id);
int insertUser(@Param("user") User user);
int updateUserById(@Param("user")User user);
int deleteUserById(Long id);
}
1、 添加SQL映射;
<!DOCTYPE mapper
PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="org.pearl.mybatis.demo.dao.UserMapper">
<!--插入用户-->
<insert id="insertUser" parameterType="user">
INSERT INTO base_user (user_id,user_name,login_name)
VALUES (#{user.userId},#{user.userName},#{user.loginName})
</insert>
<!--根据ID修改用户-->
<update id="updateUserById" parameterType="user">
UPDATE base_user SET
user_name=#{user.userName },
login_name={user.loginName}
WHERE user_id ={user.userId }
</update>
<!--根据ID删除用户-->
<delete id="deleteUserById">
DELETE FROM base_user WHERE user_id={id}
</delete>
<!--根据ID查询用户-->
<select id="selectOneById" resultType="user" databaseId="mysql">
select * from base_user where user_id ={id}
</select>
</mapper>
1、 执行SQL;
public class Test003 {
public static void main(String[] args) throws IOException {
String resource = "mybatis-config.xml";
InputStream inputStream = Resources.getResourceAsStream(resource);
SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);
SqlSession sqlSession = sqlSessionFactory.openSession();
UserMapper mapper = sqlSession.getMapper(UserMapper.class);
// 插入
User user = new User();
user.setUserId(333333L);
user.setUserName("liSi");
user.setLoginName("lilili");
int result = mapper.insertUser(user);
System.out.println(result);
// 修改
user.setUserId(33L);
int i1 = mapper.updateUserById(user);
System.out.println(i1);
// 删除
int i = mapper.deleteUserById(44L);
System.out.println(i);
// 提交事务
sqlSession.commit();
// 关闭会话
sqlSession.close();
}
}
主键生成方式
对于主键生成,MyBatis提供了多种生成方式。
(1)数据库支持自增(getGeneratedKeys)
如果数据库支持自动生成主键的字段(比如 MySQL 和 SQL Server),插入数据时,不需要设置主键,数据库会自己生成,但是要想获取到主键则需要使用useGeneratedKeys属性,(仅适用于 insert 和 update)这会令 MyBatis 使用 JDBC 的 getGeneratedKeys 方法来取出由数据库内部生成的主键。
案例演示:
1、 Insert标签添加属性getGeneratedKeys,并指定keyColumn及keyProperty;
<!--插入用户-->
<insert id="insertUser" parameterType="user" useGeneratedKeys="true" keyColumn="user_id" keyProperty="userId">
INSERT INTO base_user (user_id,user_name,login_name)
VALUES (#{user.userId},#{user.userName},#{user.loginName})
</insert>
1、 执行SQL,并获取数据库自动生成的主键;
(2)不支持自动生成主键数据库(selectKey)
对于不支持自动生成主键列的数据库和可能不支持自动生成主键的 JDBC 驱动,可以使用selectKey标签来生成主键。
selectKey 元素描述如下:
<selectKey
keyProperty="id"
resultType="int"
order="BEFORE"
statementType="PREPARED">
selectKey 元素的属性:
案例演示:
1、 添加selectKey标签,设置生成ID算法;
<insert id="insertUser" parameterType="user" useGeneratedKeys="true" keyColumn="user_id" keyProperty="userId">
<selectKey keyProperty="user.userId" keyColumn="user_id" resultType="long" order="BEFORE" >
select max(user_id)+1 as user_id from base_user
</selectKey>
INSERT INTO base_user (user_id,user_name,login_name)
VALUES (#{user.userId},#{user.userName},#{user.loginName})
</insert>
1、 测试,可以看出是先生成了ID,然后设置到实体类中;
sql
sql这个元素可以用来定义可重用的 SQL 代码片段,以便在其它语句中使用。
<!--定义通用SQL 片段 某个表的某些列-->
<sql id="commonSql">
${alias}.user_id,${alias}.user_name,${alias}.login_name
</sql>
alias参数可以静态地(在加载的时候)确定下来,并且可以在不同的 include 元素中定义不同的参数值。
<!--根据ID查询用户-->
<select id="selectOneById" resultType="user" databaseId="mysql">
select
<include refid="commonSql"><property name="alias" value="base_user"/></include>
from base_user where user_id ={id}
</select>
也可以在 include 元素的 refid 属性或内部语句中使用属性值,例如:
<sql id="sometable">
${prefix}Table
</sql>
<sql id="someinclude">
from
<include refid="${include_target}"/>
</sql>
<select id="select" resultType="map">
select
field1, field2, field3
<include refid="someinclude">
<property name="prefix" value="Some"/>
<property name="include_target" value="sometable"/>
</include>
</select>