mybatis映射XML文件详解及实例
作者:数据库技术 • 更新时间:2023-08-30 •
          mybatis映射XML文件
一个简单的映射文件:
| 
								1 
								2 
								3 
								4 | <?xmlversion="1.0"encoding="UTF-8"?><!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd" ><mappernamespace="com.cnx.wxcar.mapper.CustomerMapper"></mapper> | 
当然这个文件中没有任何的元素
The Mapper XML files have only a few first class elements :
- cache – Configuration of the cache for a given namespace.
- cache-ref – Reference to a cache configuration from another namespace.
- resultMap – The most complicated and powerful element that describes how to load your objects from the database result sets.
- sql – A reusable chunk of SQL that can be referenced by other statements.
- insert – A mapped INSERT statement.
- update – A mapped UPDATE statement.
- delete – A mapped DELETE statement.
- select – A mapped SELECT statement.
select
简单的例子:
| 
								1 
								2 
								3 | <selectid="selectPerson"parameterType="int"resultType="hashmap"> SELECT * FROM PERSON WHERE ID = #{id}</select> | 
select也有很多属性可以让你配置:
| 
								1 
								2 
								3 
								4 
								5 
								6 
								7 
								8 
								9 
								10 
								11 
								12 | <select id="selectPerson" parameterType="int" parameterMap="deprecated" resultType="hashmap" resultMap="personResultMap" flushCache="false" useCache="true" timeout="10000" fetchSize="256" statementType="PREPARED" resultSetType="FORWARD_ONLY"> | 
insert, update and delete
| 
								1 
								2 
								3 
								4 
								5 
								6 
								7 
								8 
								9 
								10 
								11 
								12 
								13 
								14 
								15 
								16 
								17 
								18 
								19 
								20 
								21 
								22 
								23 | <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"> | 
语句:
| 
								1 
								2 
								3 
								4 
								5 
								6 
								7 
								8 
								9 
								10 
								11 
								12 
								13 
								14 
								15 
								16 
								17 | <insertid="insertAuthor"> insert into Author (id,username,password,email,bio) values (#{id},#{username},#{password},#{email},#{bio})</insert><updateid="updateAuthor"> update Author set  username = #{username},  password = #{password},  email = #{email},  bio = #{bio} where id = #{id}</update><deleteid="deleteAuthor"> delete from Author where id = #{id}</delete> | 
f your database supports auto-generated key fields (e.g. MySQL and SQL Server),上面的插入语句可以写成:
| 
								1 
								2 
								3 
								4 
								5 | <insertid="insertAuthor"useGeneratedKeys="true"  keyProperty="id"> insert into Author (username,password,email,bio) values (#{username},#{password},#{email},#{bio})</insert> | 
如果你的数据库还支持多条记录插入,可以使用下面这个语句:
| 
								1 
								2 
								3 
								4 
								5 
								6 
								7 | <insertid="insertAuthor"useGeneratedKeys="true"  keyProperty="id"> insert into Author (username, password, email, bio) values <foreachitem="item"collection="list"separator=",">  (#{item.username}, #{item.password}, #{item.email}, #{item.bio}) </foreach></insert> | 
sql
这个element可以定义一些sql代码的碎片,然后在多个语句中使用,降低耦合。比如:
| 
								1 | <sqlid="userColumns"> ${alias}.id,${alias}.username,${alias}.password </sql> | 
然后在下面的语句中使用:
| 
								1 
								2 
								3 
								4 
								5 
								6 
								7 | <selectid="selectUsers"resultType="map"> select  <include refid="userColumns"><property name="alias"value="t1"/></include>,  <include refid="userColumns"><property name="alias"value="t2"/></include> fromsome_table t1  crossjoinsome_table t2</select> | 
Result Maps
官网给了个最最复杂的例子
大体意思呢就是一个博客系统有一个作者,很多博文,博文中有一个作者,很多评论,很多标签(包括了一对多,一对一)
| 
								1 
								2 
								3 
								4 
								5 
								6 
								7 
								8 
								9 
								10 
								11 
								12 
								13 
								14 
								15 
								16 
								17 
								18 
								19 
								20 
								21 
								22 
								23 
								24 
								25 
								26 
								27 
								28 
								29 
								30 
								31 
								32 
								33 
								34 
								35 
								36 
								37 
								38 
								39 
								40 
								41 
								42 
								43 
								44 
								45 
								46 
								47 
								48 
								49 
								50 
								51 
								52 
								53 
								54 
								55 
								56 
								57 
								58 
								59 
								60 
								61 
								62 
								63 
								64 | <!-- Very Complex Statement --><selectid="selectBlogDetails"resultMap="detailedBlogResultMap"> select    B.id asblog_id,    B.title asblog_title,    B.author_id asblog_author_id,    A.id asauthor_id,    A.username asauthor_username,    A.passwordasauthor_password,    A.email asauthor_email,    A.bio asauthor_bio,    A.favourite_section asauthor_favourite_section,    P.id aspost_id,    P.blog_id aspost_blog_id,    P.author_id aspost_author_id,    P.created_on aspost_created_on,    P.sectionaspost_section,    P.subject aspost_subject,    P.draft asdraft,    P.body aspost_body,    C.id ascomment_id,    C.post_id ascomment_post_id,    C.nameascomment_name,    C.comment ascomment_text,    T.id astag_id,    T.nameastag_name fromBlog B    leftouterjoinAuthor A onB.author_id = A.id    leftouterjoinPost P onB.id = P.blog_id    leftouterjoinComment C onP.id = C.post_id    leftouterjoinPost_Tag PT onPT.post_id = P.id    leftouterjoinTag T onPT.tag_id = T.id whereB.id = #{id}</select><!-- 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">   <casevalue="1"resultType="DraftPost"/>  </discriminator> </collection></resultMap> | 
感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!
原文链接:https://my.oschina.net/gef/blog/704880
本文由主机测评网发布,不代表主机测评网立场,转载联系作者并注明出处:https://zhujiwo.jb51.net/shujuku/2907.html


