- 1、本文档共32页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
12.1 商品订单数据模型12.2 一对一查询12.3 一对多查询12.4 多对多查询12.5 延迟加载12.1 商品订单数据模型商品订单数据模型,包括订单表、订单明细表、用户表、商品信息表等,具体如下:订单表(orders):记录用户创建的订单,字段有user_id(外键)、订单id、创建时间、订单状态等。订单明细表(orderdetail):记录用户购买信息,字段有订单id(外键)、商品id(外键)、商品数量、商品购买价格等。用户表(user):记录购买商品的用户信息,字段有user_id(唯一标识一个用户)、用户名、联系电话等。商品信息表(items):记录所有商品信息,字段有商品id(主键)、商品名称、商品介绍、商品价格等。12.2 一 对 一 查 询12.2.1 方法一:使用resultType使用resultType定义订单信息po类。该po类中包括了订单信息和用户信息。(1) sql语句:SELECT orders.*, user.username, userss.addressFROM orders, user WHERE orders.user_id = user.id(2) 定义po类。po类中应该包括上边sql查询出来的所有字段,代码如下:public class OrdersCustom extends Orders { private String username; // 用户名称 private String address; // 用户地址get/set...OrdersCustom类继承Orders类后,OrdersCustom类中包括了Orders类的所有字段,因此只需要定义用户的信息字段。(3) Mapper.xml:!-- 查询所有订单信息 --select id=findOrdersList resultType=cn.itcast.mybatis.po.OrdersCustomSELECTorders.*,user.username,user.addressFROMorders, userWHERE orders.user_id = user.id /select(4) Mapper接口:public ListOrdersCustom findOrdersList() throws Exception;(5) 测试:Public void testfindOrdersList()throws Exception{ //获取session SqlSession session = sqlSessionFactory.openSession(); //获取Mapper接口实例 UserMapper userMapper = session.getMapper(UserMapper.class); //查询订单信息 ListOrdersCustom list = userMapper.findOrdersList(); System.out.println(list); //关闭session session.close();}(6) 总结:定义专门的po类作为输出类型,其中定义了sql查询结果集所有的字段。此方法较为简单,企业中使用普遍。12.2.2 方法二:使用resultMap使用resultMap定义专门的resultMap用于映射一对一查询结果。(1) sql语句:SELECT orders.*, user.username, user.addressFROM orders, user WHERE orders.user_id = user.id(2) 定义po类。在Orders类中加入user属性,user属性中用于存储关联查询的用户信息,因为订单关联查询用户是一对一关系,所以这里使用单个user对象存储关联查询的用户信息。(3) Mapper.xml:select id=findOrdersListResultMap resultMap=userordermapSELECTorders.*,user.username,user.addressFROMorders,userWHERE orders.user_id = user.id /select这里resultMap指定userordermap。(4) 定义resultMap。需要关联查询映射的是用户信息,使用association将用户信息映射到订单对象的用户属性中。!-- 订单信息resultmap --resultMap type=cn.itcast.mybatis.po.Orders id=userordermap!-- 这里的id,是MyBatis在进行一对一
您可能关注的文档
- 01 智能机器人的硬件.pptx
- 1.项目一 Linux操作系统环境搭建.pptx
- 02 智能机器人的软件.pptx
- 2.项目二 Linux目录和文件管理.pptx
- 03 智能机器的传感器.pptx
- 3.项目三 Linux用户和用户组管理.pptx
- 04 实验:超声波传感器.pptx
- 04 实验:温湿度传感器.pptx
- 4.项目四 Linux目录和文件权限管理.pptx
- 5.项目五 Linux磁盘管理.pptx
- 第十一章 电流和电路专题特训二 实物图与电路图的互画 教学设计 2024-2025学年鲁科版物理九年级上册.docx
- 人教版七年级上册信息技术6.3加工音频素材 教学设计.docx
- 5.1自然地理环境的整体性 说课教案 (1).docx
- 4.1 夯实法治基础 教学设计-2023-2024学年统编版九年级道德与法治上册.docx
- 3.1 光的色彩 颜色 电子教案 2023-2024学年苏科版为了八年级上学期.docx
- 小学体育与健康 四年级下册健康教育 教案.docx
- 2024-2025学年初中数学九年级下册北京课改版(2024)教学设计合集.docx
- 2024-2025学年初中科学七年级下册浙教版(2024)教学设计合集.docx
- 2024-2025学年小学信息技术(信息科技)六年级下册浙摄影版(2013)教学设计合集.docx
- 2024-2025学年小学美术二年级下册人美版(常锐伦、欧京海)教学设计合集.docx
文档评论(0)