配置文件和映射文件還有挺多的屬性我尚未講的,如今就把它們一一補全java
在mapper.xml文件中配置不少的sql語句,執行每一個sql語句時,封裝爲MappedStatement對象,mapper.xml以statement爲單位管理sql語句mysql
Statement的實際位置就等於namespace+StatementIdsql
在Mybatis中,有兩種佔位符數據庫
若是咱們在Hibernate中,當咱們插入數據的時候,咱們是能夠選擇是UUID策略的…微信
那麼在Mybatis是怎麼作的呢??mybatis
<!-- mysql的uuid生成主鍵 --> <insert id="insertUser" parameterType="cn.itcast.mybatis.po.User"> <selectKey keyProperty="id" order="BEFORE" resultType="string"> select uuid() </selectKey> INSERT INTO USER(id,username,birthday,sex,address) VALUES(#{id},#{username},#{birthday},#{sex},#{address}) </insert>
<insert id="insertUser" parameterType="cn.itcast.mybatis.po.User">
<selectKey keyProperty="id" order="BEFORE" resultType="string">
select uuid()
</selectKey>
INSERT INTO USER(id,username,birthday,sex,address) VALUES(#{id},#{username},#{birthday},#{sex},#{address})
</insert>
若是咱們通常插入數據的話,若是咱們想要知道剛剛插入的數據的主鍵是多少,咱們能夠經過如下的方式來獲取oracle
需求:app
解決思路:ide
mysql:性能
<insert id="insertUser" parameterType="cn.itcast.mybatis.po.User"> <selectKey keyProperty="id" order="AFTER" resultType="int"> select LAST_INSERT_ID() </selectKey> INSERT INTO USER(username,birthday,sex,address) VALUES(#{username},#{birthday},#{sex},#{address}) </insert>
<selectKey keyProperty="id" order="AFTER" resultType="int">
select LAST_INSERT_ID()
</selectKey>
INSERT INTO USER(username,birthday,sex,address) VALUES(#{username},#{birthday},#{sex},#{address})
</insert>
oracle:
實現思路:
<!-- oracle 在執行insert以前執行select 序列.nextval() from dual取出序列最大值,將值設置到user對象 的id屬性 --> <insert id="insertUser" parameterType="cn.itcast.mybatis.po.User"> <selectKey keyProperty="id" order="BEFORE" resultType="int"> select 序列.nextval() from dual </selectKey> INSERT INTO USER(id,username,birthday,sex,address) VALUES( 序列.nextval(),#{username},#{birthday},#{sex},#{address}) </insert>
<insert id="insertUser" parameterType="cn.itcast.mybatis.po.User">
<selectKey keyProperty="id" order="BEFORE" resultType="int">
select 序列.nextval() from dual
</selectKey>
INSERT INTO USER(id,username,birthday,sex,address) VALUES( 序列.nextval(),#{username},#{birthday},#{sex},#{address})
</insert>
有的時候,咱們看別的映射文件,可能看不到如下這麼一段代碼:
<resultMap id="userListResultMap" type="user" > <!-- 列名 id_,username_,birthday_ id:要映射結果集的惟 一標識 ,稱爲主鍵 column:結果集的列名 property:type指定的哪一個屬性中 --> <id column="id_" property="id"/> <!-- result就是普通列的映射配置 --> <result column="username_" property="username"/> <result column="birthday_" property="birthday"/> </resultMap>
<!-- 列名
id_,username_,birthday_
id:要映射結果集的惟 一標識 ,稱爲主鍵
column:結果集的列名
property:type指定的哪一個屬性中
-->
<id column="id_" property="id"/>
<!-- result就是普通列的映射配置 -->
<result column="username_" property="username"/>
<result column="birthday_" property="birthday"/>
</resultMap>
由於,若是咱們的數據表的字段和JavaBean的屬性名稱是相同時,咱們就不用上面那段代碼了。Mybatis會自動幫咱們把返回的結果進行封裝成JavaBean
那當咱們數據表的字段和JavaBean的屬性名稱不是相同時,咱們就須要使用resultMap,也就是上面那段代碼
resultType :指定輸出結果的類型(pojo、簡單類型、hashmap..),將sql查詢結果映射爲java對象 。
resultMap:將sql查詢結果映射爲java對象。
<resultMap id="userListResultMap" type="user" > <!-- 列名 id_,username_,birthday_ id:要映射結果集的惟 一標識 ,稱爲主鍵 column:結果集的列名 property:type指定的哪一個屬性中 --> <id column="id_" property="id"/> <!-- result就是普通列的映射配置 --> <result column="username_" property="username"/> <result column="birthday_" property="birthday"/> </resultMap>這裏寫圖片描述 這裏寫圖片描述
<!-- 列名
id_,username_,birthday_
id:要映射結果集的惟 一標識 ,稱爲主鍵
column:結果集的列名
property:type指定的哪一個屬性中
-->
<id column="id_" property="id"/>
<!-- result就是普通列的映射配置 -->
<result column="username_" property="username"/>
<result column="birthday_" property="birthday"/>
</resultMap>
resultType:
resultMap:
association:
collection:
Collection在前面好像並無用過,下面就看一下它的用法:
Order與OrderDetails關係
package cn.itcast.mybatis.po;import java.io.Serializable;import java.util.Date;import java.util.List;public class Orders implements Serializable { private Integer id; private Integer userId; private String number; private Date createtime; private String note; //關聯用戶信息 private User user; //訂單明細 private List<Orderdetail> orderdetails; public Integer getId() { return id; } public void setId(Integer id) { this.id = id; } public Integer getUserId() { return userId; } public void setUserId(Integer userId) { this.userId = userId; } public String getNumber() { return number; } public void setNumber(String number) { this.number = number == null ? null : number.trim(); } public Date getCreatetime() { return createtime; } public void setCreatetime(Date createtime) { this.createtime = createtime; } public String getNote() { return note; } public void setNote(String note) { this.note = note == null ? null : note.trim(); } public User getUser() { return user; } public void setUser(User user) { this.user = user; } public List<Orderdetail> getOrderdetails() { return orderdetails; } public void setOrderdetails(List<Orderdetail> orderdetails) { this.orderdetails = orderdetails; } }
import java.io.Serializable;
import java.util.Date;
import java.util.List;
public class Orders implements Serializable {
private Integer id;
private Integer userId;
private String number;
private Date createtime;
private String note;
//關聯用戶信息
private User user;
//訂單明細
private List<Orderdetail> orderdetails;
public Integer getId() {
return id;
}
public void setId(Integer id) {
this.id = id;
}
public Integer getUserId() {
return userId;
}
public void setUserId(Integer userId) {
this.userId = userId;
}
public String getNumber() {
return number;
}
public void setNumber(String number) {
this.number = number == null ? null : number.trim();
}
public Date getCreatetime() {
return createtime;
}
public void setCreatetime(Date createtime) {
this.createtime = createtime;
}
public String getNote() {
return note;
}
public void setNote(String note) {
this.note = note == null ? null : note.trim();
}
public User getUser() {
return user;
}
public void setUser(User user) {
this.user = user;
}
public List<Orderdetail> getOrderdetails() {
return orderdetails;
}
public void setOrderdetails(List<Orderdetail> orderdetails) {
this.orderdetails = orderdetails;
}
}
SQL語句
<!-- 一對多查詢使用reusltMap完成 查詢訂單關聯查詢訂單明細 --> <select id="findOrderAndOrderDetails" resultMap="orderAndOrderDetails" > SELECT orders.*, user.username, user.sex , orderdetail.id orderdetail_id, orderdetail.items_num, orderdetail.items_id FROM orders, USER, orderdetail WHERE orders.user_id = user.id AND orders.id = orderdetail.orders_id </select>
<select id="findOrderAndOrderDetails" resultMap="orderAndOrderDetails" >
SELECT
orders.*,
user.username,
user.sex ,
orderdetail.id orderdetail_id,
orderdetail.items_num,
orderdetail.items_id
FROM
orders,
USER,
orderdetail
WHERE orders.user_id = user.id AND orders.id = orderdetail.orders_id
</select>
resultMap
<!-- 一對多,查詢訂單及訂單明細 --> <resultMap type="orders" id="orderAndOrderDetails" extends="ordersUserResultMap"> <!-- 映射訂單信息,和用戶信息,這裏使用繼承ordersUserResultMap --> <!-- 映射訂單明細信息 property:要將關聯信息映射到orders的哪一個屬性中 ofType:集合中pojo的類型 --> <collection property="orderdetails" ofType="cn.itcast.mybatis.po.Orderdetail"> <!-- id:關聯信息訂單明細的惟 一標識 property:Orderdetail的屬性名 --> <id column="orderdetail_id" property="id"/> <result column="items_num" property="itemsNum"/> <result column="items_id" property="itemsId"/> </collection> </resultMap>
<resultMap type="orders" id="orderAndOrderDetails" extends="ordersUserResultMap">
<!-- 映射訂單信息,和用戶信息,這裏使用繼承ordersUserResultMap -->
<!-- 映射訂單明細信息
property:要將關聯信息映射到orders的哪一個屬性中
ofType:集合中pojo的類型
-->
<collection property="orderdetails" ofType="cn.itcast.mybatis.po.Orderdetail">
<!-- id:關聯信息訂單明細的惟 一標識
property:Orderdetail的屬性名
-->
<id column="orderdetail_id" property="id"/>
<result column="items_num" property="itemsNum"/>
<result column="items_id" property="itemsId"/>
</collection>
</resultMap>
通常地使用resultMap會多一點。
第一種方法:
第二種方法:
配置文件typeAliases別名:
這裏寫圖片描述自定義別名:
<!-- 定義 別名 --> <typeAliases> <!-- 單個別名的定義 alias:別名,type:別名映射的類型 --> <!-- <typeAlias type="cn.itcast.mybatis.po.User" alias="user"/> --> <!-- 批量別名定義 指定包路徑,自動掃描包下邊的pojo,定義別名,別名默認爲類名(首字母小寫或大寫) --> <package name="cn.itcast.mybatis.po"/> </typeAliases>
<typeAliases>
<!--
單個別名的定義
alias:別名,type:別名映射的類型 -->
<!-- <typeAlias type="cn.itcast.mybatis.po.User" alias="user"/> -->
<!-- 批量別名定義
指定包路徑,自動掃描包下邊的pojo,定義別名,別名默認爲類名(首字母小寫或大寫)
-->
<package name="cn.itcast.mybatis.po"/>
</typeAliases>
<mappers> <!-- 經過resource引用mapper的映射文件 --> <mapper resource="sqlmap/User.xml" /> <!-- <mapper resource="mapper/UserMapper.xml" /> --> <!-- 經過class引用mapper接口 class:配置mapper接口全限定名 要求:須要mapper.xml和mapper.java同名而且在一個目錄 中 --> <!-- <mapper class="cn.itcast.mybatis.mapper.UserMapper"/> --> <!-- 批量mapper配置 經過package進行自動掃描包下邊的mapper接口, 要求:須要mapper.xml和mapper.java同名而且在一個目錄 中 --> <package name="cn.itcast.mybatis.mapper"/> </mappers>
<!-- 經過resource引用mapper的映射文件 -->
<mapper resource="sqlmap/User.xml" />
<!-- <mapper resource="mapper/UserMapper.xml" /> -->
<!-- 經過class引用mapper接口
class:配置mapper接口全限定名
要求:須要mapper.xml和mapper.java同名而且在一個目錄 中
-->
<!-- <mapper class="cn.itcast.mybatis.mapper.UserMapper"/> -->
<!-- 批量mapper配置
經過package進行自動掃描包下邊的mapper接口,
要求:須要mapper.xml和mapper.java同名而且在一個目錄 中
-->
<package name="cn.itcast.mybatis.mapper"/>
</mappers>
在進行數據查詢時,爲了提升數據庫查詢性能,儘可能使用單表查詢,由於單表查詢比多表關聯查詢速度要快。
若是查詢單表就能夠知足需求,一開始先查詢單表,當須要關聯信息時,再關聯查詢,當須要關聯信息再查詢這個叫延遲加載。
在Mybatis中延遲加載就是在resultMap中配置具體的延遲加載..
這裏寫圖片描述在Mybatis的文件中配置全局延遲加載
<!-- 全局配置參數 --> <settings> <!-- 延遲加載總開關 --> <setting name="lazyLoadingEnabled" value="true" /> <!-- 設置按需加載 --> <setting name="aggressiveLazyLoading" value="false" /> </settings>
<settings>
<!-- 延遲加載總開關 -->
<setting name="lazyLoadingEnabled" value="true" />
<!-- 設置按需加載 -->
<setting name="aggressiveLazyLoading" value="false" />
</settings>
當須要用戶時調用 Orders類中的getUser()方法執行延遲加載 ,向數據庫發出sql。
因爲是對User進行延遲加載,那麼咱們只要查詢Orders相關的信息便可了
<!-- 一對一查詢延遲加載 開始只查詢訂單,對用戶信息進行延遲加載 --> <select id="findOrderUserListLazyLoading" resultMap="orderCustomLazyLoading"> SELECT orders.* FROM orders </select>
<select id="findOrderUserListLazyLoading" resultMap="orderCustomLazyLoading">
SELECT
orders.*
FROM
orders
</select>
使用resultMap來配置延遲加載
<!-- 一對一查詢延遲加載 的配置 --> <resultMap type="orders" id="orderCustomLazyLoading"> <!-- 完成了訂單信息的映射配置 --> <!-- id:訂單關聯用戶查詢的惟 一 標識 --> <id column="id" property="id" /> <result column="user_id" property="userId" /> <result column="number" property="number" /> <result column="createtime" property="createtime" /> <result column="note" property="note" /> <!-- 配置用戶信息的延遲加載 select:延遲加載執行的sql所在的statement的id,若是不在同一個namespace須要加namespace sql:根據用戶id查詢用戶信息【column就是參數】 column:關聯查詢的列 property:將關聯查詢的用戶信息設置到Orders的哪一個屬性 --> <!--當須要user數據的時候,它就會把column所指定的user_id傳遞過去給cn.itcast.mybatis.mapper.UserMapper.findUserById做爲參數來查詢數據--> <association property="user" select="cn.itcast.mybatis.mapper.UserMapper.findUserById" column="user_id"></association> </resultMap>這裏寫圖片描述 總結
<resultMap type="orders" id="orderCustomLazyLoading">
<!-- 完成了訂單信息的映射配置 -->
<!-- id:訂單關聯用戶查詢的惟 一 標識 -->
<id column="id" property="id" />
<result column="user_id" property="userId" />
<result column="number" property="number" />
<result column="createtime" property="createtime" />
<result column="note" property="note" />
<!--
配置用戶信息的延遲加載
select:延遲加載執行的sql所在的statement的id,若是不在同一個namespace須要加namespace
sql:根據用戶id查詢用戶信息【column就是參數】
column:關聯查詢的列
property:將關聯查詢的用戶信息設置到Orders的哪一個屬性 -->
<!--當須要user數據的時候,它就會把column所指定的user_id傳遞過去給cn.itcast.mybatis.mapper.UserMapper.findUserById做爲參數來查詢數據-->
<association property="user"
select="cn.itcast.mybatis.mapper.UserMapper.findUserById" column="user_id"></association>
</resultMap>
若是文章有錯的地方歡迎指正,你們互相交流。習慣在微信看技術文章,想要獲取更多的Java資源的同窗,能夠關注微信公衆號:Java3y