12.1 商品订单数据模型.pptx

  1. 1、本文档共32页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 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在进行一对一

文档评论(0)

执着仅一次 + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档