Mybatis基础

Mybatis

  MyBatis 是支撑一般 SQL
查询,存储过程及高级映射的优秀持久层框架
。MyBatis 消除 了几乎所有的
JDBC 代码和参数的手工安装以及结果集的找。MyBatis 使用简易的 XML
或注解用于配置以及原始映射,将接口和 Java 的 POJOs(Plan Old Java
Objects,普通的 Java 对象)映射成数据库中的记录。

基于配置文件配置

  每个基于 MyBatis 的采用还是因一个 SqlSessionFactory
的实例为基本的。SqlSessionFactory 的实例可以经
SqlSessionFactoryBuilder 获得。而 SqlSessionFactoryBuilder 则好打 XML
配置文件要一个预定制的 Configuration 的实例构建有 SqlSessionFactory
的实例。

布置文件(XML 构建 SqlSessionFactory)

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans" 
    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    xmlns:context="http://www.springframework.org/schema/context" 
    xmlns:jdbc="http://www.springframework.org/schema/jdbc"  
    xmlns:jee="http://www.springframework.org/schema/jee" 
    xmlns:tx="http://www.springframework.org/schema/tx"
    xmlns:aop="http://www.springframework.org/schema/aop" 
    xmlns:mvc="http://www.springframework.org/schema/mvc"
    xmlns:util="http://www.springframework.org/schema/util"
    xmlns:jpa="http://www.springframework.org/schema/data/jpa"
    xsi:schemaLocation="
        http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-3.2.xsd
        http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-3.2.xsd
        http://www.springframework.org/schema/jdbc http://www.springframework.org/schema/jdbc/spring-jdbc-3.2.xsd
        http://www.springframework.org/schema/jee http://www.springframework.org/schema/jee/spring-jee-3.2.xsd
        http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-3.2.xsd
        http://www.springframework.org/schema/data/jpa http://www.springframework.org/schema/data/jpa/spring-jpa-1.3.xsd
        http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-3.2.xsd
        http://www.springframework.org/schema/mvc http://www.springframework.org/schema/mvc/spring-mvc-3.2.xsd
        http://www.springframework.org/schema/util http://www.springframework.org/schema/util/spring-util-3.2.xsd">
    <!-- 定义dbcp组件DataSource -->
    <bean id="dbcp" 
class="org.apache.commons.dbcp.BasicDataSource">
        <property name="username" value="root">
        </property>
        <property name="password" value="123456">
        </property>
        <property name="driverClassName"
            value="com.mysql.jdbc.Driver">   
        </property>
        <property name="url" 
        value="jdbc:mysql://localhost:3306/cloud_note?useUnicode=true&amp;characterEncoding=utf8">
        </property>
    </bean>

    <!-- 定义SqlSessionFactory -->
    <bean id="ssf" 
class="org.mybatis.spring.SqlSessionFactoryBean">
        <property name="dataSource" ref="dbcp">
        </property>
        <property name="mapperLocations"
            value="classpath:mapper/*.xml">
        </property>
    </bean>
    <!-- 定义MapperScannerConfigurer -->
    <bean id="mapperScanner" class="org.mybatis.spring.mapper.MapperScannerConfigurer">
        <property name="basePackage" value="com.tedu.cloudnote.dao">
        </property>
        <!-- sqlSessionFactory可以省略不写 -->
        <property name="sqlSessionFactory" ref="ssf">
        </property>
    </bean>


</beans>    

XML 映射配置文件

  映射器是创建用来绑定映射语句的接口。映射器接口的实例是于
SqlSession 中赢得的。因此从技术面谈,映射器实例的卓绝特别发用域是与
SqlSession 相同的,因为其还是自 SqlSession
里叫求的。尽管如此,映射器实例的无限佳作用域是道作用域。也就是说,映射器实例应该于调用它们的方被给求,用了之后即可废弃。并不需要显式地关映射器实例,尽管在整整请求作用域(request
scope)保持映射器实例也非会见发出啊问题,但是高速你会发觉,像 SqlSession
一样,在此作用域上管理最多的资源的话语会难以给决定。所以只要保持简单,最好把映射器放在方法作用域(method
scope)内。

  MyBatis
的着实有力在于她的映射语词,也是其的魔力四处。由于它们的怪强硬,映射器的
XML 文件就显得相对简便易行。

Mapper XML 文件详解

  • cache – 给定命名空间的缓存配置。
  • cache-ref – 其他命名空间缓存配置的援。
  • resultMap –
    是最为复杂呢是最最强劲的素,用来讲述如何由数据库结果集中来加载对象。
  • sql – 可被另外语句引用的可重用语句块。
  • insert – 映射插入语句
  • update – 映射更新语句
  • delete – 映射删除语句
  • select – 映射查询语句

select

  查询语句是 MyBatis
中最为常用之素之一,光会把数据存到数据库被价值并无慌,如果还能重复赢得出来才起因此,多数用到也都是询问比修改要再三。对每个插入、更新或去操作,通常对承诺多独查询操作。这是
MyBatis
的中心原则之一,也是以焦点和努力放到查询与结果映射的原因。简单询问的
select 元素是非常简单的。比如:

<select id="selectPerson" parameterType="int" resultType="hashmap">
  SELECT * FROM PERSON WHERE ID = #{id}
</select>

其一讲话为名 selectPerson,接受一个 int(或
Integer)类型的参数,并返一个 HashMap
类型的对象,其中的键是列名,值便是结果实施吃之对应值。

Select Attributes(select 属性)

属性 描述
id 在命名空间中唯一的标识符,可以被用来引用这条语句。
parameterType 将会传入这条语句的参数类的完全限定名或别名。这个属性是可选的,因为 MyBatis 可以通过 TypeHandler 推断出具体传入语句的参数,默认值为 unset。
parameterMap 这是引用外部 parameterMap 的已经被废弃的方法。使用内联参数映射和 parameterType 属性。
resultType 从这条语句中返回的期望类型的类的完全限定名或别名。注意如果是集合情形,那应该是集合可以包含的类型,而不能是集合本身。使用 resultType 或 resultMap,但不能同时使用。
resultMap 外部 resultMap 的命名引用。结果集的映射是 MyBatis 最强大的特性,对其有一个很好的理解的话,许多复杂映射的情形都能迎刃而解。使用 resultMap 或 resultType,但不能同时使用。
flushCache 将其设置为 true,任何时候只要语句被调用,都会导致本地缓存和二级缓存都会被清空,默认值:false。
useCache 将其设置为 true,将会导致本条语句的结果被二级缓存,默认值:对 select 元素为 true。
timeout 这个设置是在抛出异常之前,驱动程序等待数据库返回请求结果的秒数。默认值为 unset(依赖驱动)。
fetchSize 这是尝试影响驱动程序每次批量返回的结果行数和这个设置值相等。默认值为 unset(依赖驱动)。
statementType STATEMENT,PREPARED 或 CALLABLE 的一个。这会让 MyBatis 分别使用 Statement,PreparedStatement 或 CallableStatement,默认值:PREPARED。
resultSetType FORWARD_ONLY,SCROLL_SENSITIVE 或 SCROLL_INSENSITIVE 中的一个,默认值为 unset (依赖驱动)。
databaseId 如果配置了 databaseIdProvider,MyBatis 会加载所有的不带 databaseId 或匹配当前 databaseId 的语句;如果带或者不带的语句都有,则不带的会被忽略。
resultOrdered 这个设置仅针对嵌套结果 select 语句适用:如果为 true,就是假设包含了嵌套结果集或是分组了,这样的话当返回一个主结果行的时候,就不会发生有对前面结果集的引用的情况。这就使得在获取嵌套的结果集的时候不至于导致内存不够用。默认值:false。
resultSets 这个设置仅对多结果集的情况适用,它将列出语句执行后返回的结果集并每个结果集给一个名称,名称是逗号分隔的。

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">
属性 描述
id 命名空间中的唯一标识符,可被用来代表这条语句。
parameterType 将要传入语句的参数的完全限定类名或别名。这个属性是可选的,因为 MyBatis 可以通过 TypeHandler 推断出具体传入语句的参数,默认值为 unset。
parameterMap 这是引用外部 parameterMap 的已经被废弃的方法。使用内联参数映射和 parameterType 属性。
flushCache 将其设置为 true,任何时候只要语句被调用,都会导致本地缓存和二级缓存都会被清空,默认值:true(对应插入、更新和删除语句)。
timeout 这个设置是在抛出异常之前,驱动程序等待数据库返回请求结果的秒数。默认值为 unset(依赖驱动)。
statementType STATEMENT,PREPARED 或 CALLABLE 的一个。这会让 MyBatis 分别使用 Statement,PreparedStatement 或 CallableStatement,默认值:PREPARED。
useGeneratedKeys (仅对 insert 和 update 有用)这会令 MyBatis 使用 JDBC 的 getGeneratedKeys 方法来取出由数据库内部生成的主键(比如:像 MySQL 和 SQL Server 这样的关系数据库管理系统的自动递增字段),默认值:false。
keyProperty (仅对 insert 和 update 有用)唯一标记一个属性,MyBatis 会通过 getGeneratedKeys 的返回值或者通过 insert 语句的 selectKey 子元素设置它的键值,默认:unset。如果希望得到多个生成的列,也可以是逗号分隔的属性名称列表。
keyColumn (仅对 insert 和 update 有用)通过生成的键值设置表中的列名,这个设置仅在某些数据库(像 PostgreSQL)是必须的,当主键列不是表中的第一列的时候需要设置。如果希望得到多个生成的列,也可以是逗号分隔的属性名称列表。
databaseId 如果配置了 databaseIdProvider,MyBatis 会加载所有的不带 databaseId 或匹配当前 databaseId 的语句;如果带或者不带的语句都有,则不带的会被忽略。

脚就 insert,update 和 delete 语词的言传身教:

<insert id="insertAuthor">
  insert into Author (id,username,password,email,bio)
  values (#{id},#{username},#{password},#{email},#{bio})
</insert>

<update id="updateAuthor">
  update Author set
    username = #{username},
    password = #{password},
    email = #{email},
    bio = #{bio}
  where id = #{id}
</update>

<delete id="deleteAuthor">
  delete from Author where id = #{id}
</delete>  

主键的自增

要是您的数据库支持自动生成主键的字段(比如 MySQL 和 SQL
Server
),那么您可以设置 useGeneratedKeys=”true”,然后再次将 keyProperty
设置及目标属性上便OK

<!-- Author 表已经对 id 使用了自动生成的列类型-->
<insert id="insertAuthor" useGeneratedKeys="true"
    keyProperty="id">
  insert into Author (username,password,email,bio)
  values (#{username},#{password},#{email},#{bio})
</insert>

若你的数据库尚支撑多行插入,
你吧足以流传一个Authors数组或集合,并回自动生成的主键

<insert id="insertAuthor" useGeneratedKeys="true"
    keyProperty="id">
  insert into Author (username, password, email, bio) values
  <foreach item="item" collection="list" separator=",">
    (#{item.username}, #{item.password}, #{item.email}, #{item.bio})
  </foreach>
</insert>

对于不支持自动生成类型的数据库(oracle)或可能不支持自动生成主键 JDBC
驱动来说,MyBatis 有另外一栽方法来转主键。

<insert id="insertAuthor">
  <selectKey keyProperty="id" resultType="int" order="BEFORE">
    select CAST(RANDOM()*1000000 as INTEGER) a from SYSIBM.SYSDUMMY1
  </selectKey>
  insert into Author
    (id, username, password, email,bio, favourite_section)
  values
    (#{id}, #{username}, #{password}, #{email}, #{bio}, #{favouriteSection,jdbcType=VARCHAR})
</insert>

在点的演示中,selectKey 元素将见面首先运行,Author 的 id
会被装置,然后插入语句会被调用。这让你了一个及数据库中来处理自动生成的主键类似的一言一行,避免了一旦
Java 代码变得复杂。

selectKey 元素描述如下:

<selectKey
  keyProperty="id"
  resultType="int"
  order="BEFORE"
  statementType="PREPARED">

selectKey Attributes

属性 描述
keyProperty selectKey 语句结果应该被设置的目标属性。如果希望得到多个生成的列,也可以是逗号分隔的属性名称列表。
keyColumn 匹配属性的返回结果集中的列名称。如果希望得到多个生成的列,也可以是逗号分隔的属性名称列表。
resultType 结果的类型。MyBatis 通常可以推算出来,但是为了更加确定写上也不会有什么问题。MyBatis 允许任何简单类型用作主键的类型,包括字符串。如果希望作用于多个生成的列,则可以使用一个包含期望属性的 Object 或一个 Map。
order 这可以被设置为 BEFORE 或 AFTER。如果设置为 BEFORE,那么它会首先选择主键,设置 keyProperty 然后执行插入语句。如果设置为 AFTER,那么先执行插入语句,然后是 selectKey 元素 – 这和像 Oracle 的数据库相似,在插入语句内部可能有嵌入索引调用。
statementType 与前面相同,MyBatis 支持 STATEMENT,PREPARED 和 CALLABLE 语句的映射类型,分别代表 PreparedStatement 和 CallableStatement 类型。

sql

  这个元素得以为用来定义可选用的 SQL
代码段,可以蕴涵在其它语句中。它好于静态地(在加载参数) 参数化.

  属性值可以用于包含的refid属性或者隐含的词句里面的属于性值

<select id="selectUsers" resultType="User">
  select id, username, password
  from users
  where id = #{id}
</select>

  示例说明了一个非常简单的取名参数映射。参数类型为设置为
int,这样是参数就可以被安装成其他内容。原生的种或者简捷数据类型(比如整型和字符串)因为尚未相关属性,它见面了用参数值来替。


<insert id="insertUser" parameterType="User">
  insert into users (id, username, password)
  values (#{id}, #{username}, #{password})
</insert>

  如果 User 类型的参数对象传递及了晓句被,id、username 和 password
属性将会晤为摸,然后以它的价传入预处理语句之参数中。


#{age,javaType=double,jdbcType=NUMERIC,numericScale=2}

jdbcType:指定一个独特的门类处理器类
numericScale:小数保留位数的安,来规定小数点后保留的位数。

Result Maps

  ResultMap
的规划虽简语句不需要鲜明的结果映射,而博繁杂语句确实要描述她的关系。

<select id="selectUsers" resultType="User">
  select
    user_id             as "id",
    user_name           as "userName",
    hashed_password     as "hashedPassword"
  from some_table
  where id = #{id}
</select>

缓解列名不兼容的另外一种方法

<resultMap id="userResultMap" type="User">
  <id property="id" column="user_id" />
  <result property="username" column="user_name"/>
  <result property="password" column="hashed_password"/>
</resultMap>

高等结果映射

<!-- Very Complex Result Map -->
<resultMap id="detailedBlogResultMap" type="Blog">
  <constructor>
    <idArg column="blog_id" javaType="int"/>
  </constructor>
  <result property="title" column="blog_title"/>
  <association property="author" javaType="Author">
    <id property="id" column="author_id"/>
    <result property="username" column="author_username"/>
    <result property="password" column="author_password"/>
    <result property="email" column="author_email"/>
    <result property="bio" column="author_bio"/>
    <result property="favouriteSection" column="author_favourite_section"/>
  </association>
  <collection property="posts" ofType="Post">
    <id property="id" column="post_id"/>
    <result property="subject" column="post_subject"/>
    <association property="author" javaType="Author"/>
    <collection property="comments" ofType="Comment">
      <id property="id" column="comment_id"/>
    </collection>
    <collection property="tags" ofType="Tag" >
      <id property="id" column="tag_id"/>
    </collection>
    <discriminator javaType="int" column="draft">
      <case value="1" resultType="DraftPost"/>
    </discriminator>
  </collection>
</resultMap>

  resultMap 元素的概念视图

resultMap

  • constructor – 类在实例化时,用来注入结果及构造方法中
  • idArg – ID 参数;标记结果作 ID 可以助提高总体效应
  • arg – 注入到构造方法的一个屡见不鲜结果

  • id – 一个 ID 结果;标记结果作为 ID 可以帮助提高总体效能

  • result – 注入到字段或 JavaBean 属性的常见结果

  • association – 一个犬牙交错的型涉及;许多结实用保证改成这种类型

  • 置于结果映射 – 结果映射自身之关联,或者参考一个

  • collection – 复杂类型的汇聚

  • 内置结果映射 – 结果映射自身的集结,或者参考一个

  • discriminator – 使用结果值来支配以谁结果映射

  • case – 基于某些价值的结果映射
  • 放置结果映射 – 这种景象结果吗映射它自身,因此得以涵盖众多并行
    同的要素,或者它可以参见一个外部的结果映射。

Id and Result Attributes

属性 描述
property 映射到列结果的字段或属性。如果匹配的是存在的,和给定名称相同的 JavaBeans 的属性,那么就会使用。否则 MyBatis 将会寻找给定名称 property 的字段。这两种情形你可以使用通常点式的复杂属性导航。比如,你可以这样映射一些东西: “username” ,或者映射到一些复杂的东西: “address.street.number” 。
column 从数据库中得到的列名,或者是列名的重命名标签。这也是通常和会传递给 resultSet.getString(columnName)方法参数中相同的字符串。
javaType 一个 Java 类的完全限定名,或一个类型别名(参考上面内建类型别名的列表) 。如果你映射到一个 JavaBean,MyBatis 通常可以断定类型。然而,如果你映射到的是 HashMap,那么你应该明确地指定 javaType 来保证所需的行为。
jdbcType 在这个表格之后的所支持的 JDBC 类型列表中的类型。JDBC 类型是仅仅需要对插入,更新和删除操作可能为空的列进行处理。这是 JDBC jdbcType 的需要,而不是 MyBatis 的。如果你直接使用 JDBC 编程,你需要指定这个类型-但仅仅对可能为空的值。
typeHandler 我们在前面讨论过默认的类型处理器。使用这个属性,你可以覆盖默认的类型处理器。这个属性值是类的完全限定名或者是一个类型处理器的实现,或者是类型别名。

今底哪怕描写及这里拿,这些都是极基础的,难之是事关映射,大家可下好好看下

网站地图xml地图