Mybatis 杂记 (二)

本贴最后更新于 2381 天前,其中的信息可能已经时移世改

Mybatis 杂记:

当数据库涉及到一对多时 Mybatis 的处理方法:

  • 例如在 bean 中定义如下两个类(Order 类和 User 类),用户和订单是一对多关系,1 个用户可能会有多个订单,但是一个订单只属于一个用户。
    此时你需要在那个 1 的地方定义一个集合,Set 和 List 皆可!
public class Order { private long id; private String name; private double price; public User user; //Getter and Setter //toString //Constuctor } public class User { private long id; private String name; private Set<Order> orders; //Getter and Setter //toString //Constuctor }
  • 扯到一点插入语句在 Mybatis 中的使用!例如在 User 表中插入数据时:
    数据库:Oracle
    主键通过序列进行维护时,就可以用 selectKey 来引入我们的主键。
    order 中参数有两种:
    1.AFTER:在 insert 之后执行
    2.BEFORE:在 insert 之前执行
    keyProperty:查询到的结果(这里即序列的值)将要赋给哪个列
    resultType:查询到的结果的属性(即 keyProperty 中的属性)
<insert id="saveUser" parameterType="user"> <selectKey order="BEFORE" keyProperty="id" resultType="long"> select u_seq.nextval from dual </selectKey> insert into s_user(id,name) values(#{id},#{name}) </insert>

  • 做一些查询的 demo:
    1.基于 User 的 id 去查询所有的信息:
    在 Mapper 接口中定义:User findUserAndOrders(long id);

Mapper.xml 中:

同样的套路,先定义一个 orderresultMap

<resultMap id="order_mod1" type="order"> <id property="id" column="ids"/> <result property="name" column="names"/> <result property="price" column="price"/> </resultMap>

随后定义 User 的 resultMap:
一对一的时候用的是 association,这里使用 collection 来描述“多”的这个关系,另一方面,在 bean 中写的也是个集合!
collection 中,property 参数根据之前谈过的规则(Mybatis 会自动去搜寻 getXX()方法,并将其以去掉 get,并取后面字段小写的方式来获取属性名),resultMap 参数写的是刚才写的 id 为 order_mod1 的 resultMap.

<resultMap id="user_mod1" type="user" > <id property="id" column="id"/> <result property="name" column="name"/> <!-- 表示集合的封装 property指向封装对象中的集合引用变量,引用对象 --> <collection property="orders" resultMap="order_mod1" /> </resultMap>

这样的话 select 就可以这么写:

<select id="findUserAndOrders" parameterType="long" resultMap="user_mod1"> select s.id,s.NAME,d.id ids,d.name names,d.PRICE,d.USER_ID from S_USER s, S_ORDER d where s.ID = d.USER_ID and s.ID = #{id} </select>

2.根据用户的 id 去寻找所有的 Order:
在 Mapper 中定义:Set<Order> selectOrderByUser_id(long id);

Mapper.xml 中:

<select id="selectOrderByUser_id" parameterType="long" resultMap="order_mod1"> select id ids,name names,PRICE from S_ORDER where USER_ID = #{id} </select>

3.查询所有的用户及订单:
在 Mapper 接口中定义:List<User> selectUserandOrder();

Mapper.xml 中:

collectionselect 中填写的是刚才 2 中的操作(根据用户的 id 去寻找所有的 Order),column 属性又把 user_Id 传过去,查询到的所有数据就会拼接在 property 的属性中,这样就完成了查询所有数据的能力!

<resultMap id="mod_user" type="user"> <id property="id" column="id"/> <result property="name" column="name"/> <!-- 基于当前查询的用户 id 去 order 表找订单 --> <collection property="orders" column="id" select="selectOrderByUser_id"/> </resultMap>

select 标签:

<select id="selectUserandOrder" resultMap="mod_user"> select s.id,s.NAME,d.id ids,d.NAME names,d.PRICE,d.USER_ID from S_USER s, S_ORDER d where s.ID = d.USER_ID </select>
  • MyBatis

    MyBatis 本是 Apache 软件基金会 的一个开源项目 iBatis,2010 年这个项目由 Apache 软件基金会迁移到了 google code,并且改名为 MyBatis ,2013 年 11 月再次迁移到了 GitHub。

    173 引用 • 414 回帖 • 368 关注

相关帖子

欢迎来到这里!

我们正在构建一个小众社区,大家在这里相互信任,以平等 • 自由 • 奔放的价值观进行分享交流。最终,希望大家能够找到与自己志同道合的伙伴,共同成长。

注册 关于
请输入回帖内容 ...

推荐标签 标签

  • CSDN

    CSDN (Chinese Software Developer Network) 创立于 1999 年,是中国的 IT 社区和服务平台,为中国的软件开发者和 IT 从业者提供知识传播、职业发展、软件开发等全生命周期服务,满足他们在职业发展中学习及共享知识和信息、建立职业发展社交圈、通过软件开发实现技术商业化等刚性需求。

    14 引用 • 155 回帖
  • 深度学习

    深度学习(Deep Learning)是机器学习的分支,是一种试图使用包含复杂结构或由多重非线性变换构成的多个处理层对数据进行高层抽象的算法。

    54 引用 • 41 回帖
  • SpaceVim

    SpaceVim 是一个社区驱动的模块化 vim/neovim 配置集合,以模块的方式组织管理插件以
    及相关配置,为不同的语言开发量身定制了相关的开发模块,该模块提供代码自动补全,
    语法检查、格式化、调试、REPL 等特性。用户仅需载入相关语言的模块即可得到一个开箱
    即用的 Vim-IDE。

    3 引用 • 31 回帖 • 121 关注
  • jsoup

    jsoup 是一款 Java 的 HTML 解析器,可直接解析某个 URL 地址、HTML 文本内容。它提供了一套非常省力的 API,可通过 DOM,CSS 以及类似于 jQuery 的操作方法来取出和操作数据。

    6 引用 • 1 回帖 • 486 关注
  • OpenStack

    OpenStack 是一个云操作系统,通过数据中心可控制大型的计算、存储、网络等资源池。所有的管理通过前端界面管理员就可以完成,同样也可以通过 Web 接口让最终用户部署资源。

    10 引用 • 5 关注
  • 运维

    互联网运维工作,以服务为中心,以稳定、安全、高效为三个基本点,确保公司的互联网业务能够 7×24 小时为用户提供高质量的服务。

    151 引用 • 257 回帖
  • OnlyOffice
    4 引用 • 22 关注
  • 浅吟主题

    Jeffrey Chen 制作的思源笔记主题,项目仓库:https://github.com/TCOTC/Whisper

    1 引用 • 28 回帖
  • Hadoop

    Hadoop 是由 Apache 基金会所开发的一个分布式系统基础架构。用户可以在不了解分布式底层细节的情况下,开发分布式程序。充分利用集群的威力进行高速运算和存储。

    89 引用 • 122 回帖 • 616 关注
  • BAE

    百度应用引擎(Baidu App Engine)提供了 PHP、Java、Python 的执行环境,以及云存储、消息服务、云数据库等全面的云服务。它可以让开发者实现自动地部署和管理应用,并且提供动态扩容和负载均衡的运行环境,让开发者不用考虑高成本的运维工作,只需专注于业务逻辑,大大降低了开发者学习和迁移的成本。

    19 引用 • 75 回帖 • 668 关注
  • Outlook
    1 引用 • 5 回帖
  • Spring

    Spring 是一个开源框架,是于 2003 年兴起的一个轻量级的 Java 开发框架,由 Rod Johnson 在其著作《Expert One-On-One J2EE Development and Design》中阐述的部分理念和原型衍生而来。它是为了解决企业应用开发的复杂性而创建的。框架的主要优势之一就是其分层架构,分层架构允许使用者选择使用哪一个组件,同时为 JavaEE 应用程序开发提供集成的框架。

    948 引用 • 1460 回帖
  • 锤子科技

    锤子科技(Smartisan)成立于 2012 年 5 月,是一家制造移动互联网终端设备的公司,公司的使命是用完美主义的工匠精神,打造用户体验一流的数码消费类产品(智能手机为主),改善人们的生活质量。

    4 引用 • 31 回帖 • 9 关注
  • 钉钉

    钉钉,专为中国企业打造的免费沟通协同多端平台, 阿里巴巴出品。

    15 引用 • 67 回帖 • 290 关注
  • TextBundle

    TextBundle 文件格式旨在应用程序之间交换 Markdown 或 Fountain 之类的纯文本文件时,提供更无缝的用户体验。

    1 引用 • 2 回帖 • 82 关注
  • CentOS

    CentOS(Community Enterprise Operating System)是 Linux 发行版之一,它是来自于 Red Hat Enterprise Linux 依照开放源代码规定释出的源代码所编译而成。由于出自同样的源代码,因此有些要求高度稳定的服务器以 CentOS 替代商业版的 Red Hat Enterprise Linux 使用。两者的不同在于 CentOS 并不包含封闭源代码软件。

    239 引用 • 224 回帖 • 1 关注
  • VirtualBox

    VirtualBox 是一款开源虚拟机软件,最早由德国 Innotek 公司开发,由 Sun Microsystems 公司出品的软件,使用 Qt 编写,在 Sun 被 Oracle 收购后正式更名成 Oracle VM VirtualBox。

    10 引用 • 2 回帖 • 17 关注
  • Eclipse

    Eclipse 是一个开放源代码的、基于 Java 的可扩展开发平台。就其本身而言,它只是一个框架和一组服务,用于通过插件组件构建开发环境。

    76 引用 • 258 回帖 • 626 关注
  • 导航

    各种网址链接、内容导航。

    43 引用 • 177 回帖
  • GAE

    Google App Engine(GAE)是 Google 管理的数据中心中用于 WEB 应用程序的开发和托管的平台。2008 年 4 月 发布第一个测试版本。目前支持 Python、Java 和 Go 开发部署。全球已有数十万的开发者在其上开发了众多的应用。

    14 引用 • 42 回帖 • 812 关注
  • Swift

    Swift 是苹果于 2014 年 WWDC(苹果开发者大会)发布的开发语言,可与 Objective-C 共同运行于 Mac OS 和 iOS 平台,用于搭建基于苹果平台的应用程序。

    36 引用 • 37 回帖 • 544 关注
  • Solo

    Solo 是一款小而美的开源博客系统,专为程序员设计。Solo 有着非常活跃的社区,可将文章作为帖子推送到社区,来自社区的回帖将作为博客评论进行联动(具体细节请浏览 B3log 构思 - 分布式社区网络)。

    这是一种全新的网络社区体验,让热爱记录和分享的你不再感到孤单!

    1441 引用 • 10068 回帖 • 495 关注
  • B3log

    B3log 是一个开源组织,名字来源于“Bulletin Board Blog”缩写,目标是将独立博客与论坛结合,形成一种新的网络社区体验,详细请看 B3log 构思。目前 B3log 已经开源了多款产品:SymSoloVditor思源笔记

    1063 引用 • 3455 回帖 • 160 关注
  • TGIF

    Thank God It's Friday! 感谢老天,总算到星期五啦!

    289 引用 • 4492 回帖 • 656 关注
  • 安装

    你若安好,便是晴天。

    132 引用 • 1184 回帖
  • jQuery

    jQuery 是一套跨浏览器的 JavaScript 库,强化 HTML 与 JavaScript 之间的操作。由 John Resig 在 2006 年 1 月的 BarCamp NYC 上释出第一个版本。全球约有 28% 的网站使用 jQuery,是非常受欢迎的 JavaScript 库。

    63 引用 • 134 回帖 • 735 关注
  • Q&A

    提问之前请先看《提问的智慧》,好的问题比好的答案更有价值。

    9634 引用 • 43810 回帖 • 95 关注