当前位置: 首页 > news >正文

陕西网站建设哪家好开发一套小区多少钱

陕西网站建设哪家好,开发一套小区多少钱,wordpress 新浪微博分享,做网站wamp和xamp文章目录 前言一、一对一映射1.1 创建实体1.2 xml配置 二、一对多映射2.1 创建实体2.2 resultMap配置2.3 测试 三、 多对多映射3.1 创建实体3.2 resultMap配置3.3 测试 前言 MyBatis是一个Java持久化框架,它提供了一种将数据库表和Java对象之间进行关系映射的方式。…

文章目录

  • 前言
  • 一、一对一映射
    • 1.1 创建实体
    • 1.2 xml配置
  • 二、一对多映射
    • 2.1 创建实体
    • 2.2 resultMap配置
    • 2.3 测试
  • 三、 多对多映射
    • 3.1 创建实体
    • 3.2 resultMap配置
    • 3.3 测试

前言

MyBatis是一个Java持久化框架,它提供了一种将数据库表和Java对象之间进行关系映射的方式。这种关系映射可以通过XML配置文件或注解来定义。

在MyBatis中,关系映射是通过Mapper接口和SQL语句来实现的。Mapper接口定义了数据库操作的方法,而SQL语句则定义了具体的数据库操作。

在关系映射中,MyBatis提供了一些注解和XML配置来实现对象和数据库表之间的映射关系。例如,@Table注解可以用于指定Java对象对应的数据库表,@Column注解可以用于指定Java对象属性对应的数据库字段。

此外,MyBatis还支持一对一、一对多、多对一和多对多等复杂的关系映射。通过配置关联关系,可以在查询时自动加载相关联的对象。

一、一对一映射

一对一映射是指数据库中的两个表之间存在一对一的关系,即一个记录在一个表中只对应一个记录在另一个表中的情况。

1.1 创建实体

假设我们有两个表:student(学生表)和 id_card(身份证表)。每个学生只有一个身份证,而每个身份证只属于一个学生。

public class Student {private int id;private String name;private IdCard idCard;// 省略构造函数和getter/setter方法
}public class IdCard {private int id;private String number;private Student student;// 省略构造函数和getter/setter方法
}

1.2 xml配置

使用XML配置的方式,可以在Student类对应的中使用标签来定义关联关系:

<resultMap id="studentResultMap" type="com.xqx.model.Student"><!-- 省略其他映射配置 --><association property="idCard" javaType="com.xqx.model.IdCard"><id property="id" column="id_card_id"/><result property="number" column="id_card_number"/></association>
</resultMap>

通过以上配置,我们可以在查询学生信息时,自动加载关联的身份证信息。

二、一对多映射

一对多映射是指数据库中的两个表之间存在一对多的关系,即一个记录在一个表中对应多个记录在另一个表中的情况。例如,一个订单(Oeder)与一个订单详情(OrderItem)之间的关系。假设我们有以下表结构:
在这里插入图片描述

2.1 创建实体

建立一个OrderVo。OrderVo 类用于表示一个订单及其关联的订单项。

package com.xqx.vo;import com.xqx.model.Order;
import com.xqx.model.OrderItem;
import lombok.Data;import java.util.ArrayList;
import java.util.List;@Data
public class OrderVo extends Order {private List<OrderItem> orderItems = new ArrayList<>();
} 

2.2 resultMap配置

    <resultMap id="OrderVoMap" type="com.xqx.vo.OrderVo"><result column="order_id" property="orderId"></result><result column="order_no" property="orderNo"></result>//多关系使用collection<collection property="orderItems" ofType="com.xqx.model.OrderItem"><result column="order_item_id" property="orderItemId"></result><result column="product_id" property="productId"></result><result column="quantity" property="quantity"></result><result column="oid" property="oid"></result></collection></resultMap>

2.3 测试

OrderMapper

package com.xqx.mapper;import com.xqx.model.Order;
import com.xqx.vo.OrderVo;
import org.springframework.stereotype.Repository;@Repository
public interface OrderMapper {OrderVo selectbyOid(Integer boid);}

OrderBiz

package com.xqx.biz;import com.xqx.vo.OrderVo;public interface OrderBiz {OrderVo selectbyOid(Integer boid);
}

OrderBizImpl


package com.xqx.biz;import com.xqx.mapper.OrderMapper;
import com.xqx.vo.OrderVo;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;@Service
public class OrderBizImpl implements OrderBiz {@Autowiredprivate OrderMapper OrderMapper;@Overridepublic OrderVo selectbyOid(Integer boid) {return OrderMapper.selectbyOid(boid);}
}

Junit测试

package com.xqx.biz;import com.xqx.vo.OrderVo;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.test.context.ContextConfiguration;
import org.springframework.test.context.junit4.SpringJUnit4ClassRunner;@RunWith(SpringJUnit4ClassRunner.class)
@ContextConfiguration(locations={"classpath:Spring-context.xml"})
public class OrderBizImplTest {@Autowiredprivate OrderBiz OrderBiz;@Testpublic void selectbyOid() {OrderVo orderVO = OrderBiz.selectbyOid(7);System.out.println(orderVO);orderVO.getOrderItems().forEach(System.out::println);}
}

测试结果
在这里插入图片描述

三、 多对多映射

多对多映射是指多个对象与多个对象具有多对多的关系。以根据书籍id查找关联属性类别为例
在这里插入图片描述

3.1 创建实体

vo对象

package com.xqx.vo;import com.xqx.model.BookCategory;
import com.xqx.model.Book;
import lombok.Data;
import java.util.List;@Data
public class BookVo extends Book {private List<BookCategory> bookc = new ArrayList<>();
}

3.2 resultMap配置

  <resultMap id="BookVoMap" type="com.xqx.vo.BookVo" ><result column="book_id" property="bookId"></result><result column="book_name" property="bookName"></result><result column="price" property="price"></result><collection property="bookc" ofType="com.xqx.model.Category"><result column="category_id" property="categoryId"></result><result column="category_name" property="categoryName"></result></collection></resultMap><!--根据书籍的id查询书籍的信息及所属属性--><select id="selectByBookId" resultMap="BookVoMap" parameterType="java.lang.Integer">SELECT*FROMt_hibernate_book b,t_hibernate_category c,t_hibernate_book_category bcWHEREb.book_id = bc.bidAND c.category_id = bc.bcidAND b.book_id = #{bid}</select>

3.3 测试

BookMapper

package com.xqx.mapper;import com.xqx.model.Book;
import com.xqx.vo.BookVo;
import org.springframework.stereotype.Repository;@Repository
public interface BookMapper {HbookVo selectByBid(Integer bid);}

BookBiz

package com.xqx.biz;import com.xqx.vo.BookVo;public interface BookBiz {HbookVo selectByBid(Integer bid);
}

BookBizImpl

package com.xqx.biz;import com.xqx.mapper.BookMapper;
import com.xqx.vo.BookVo;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;@Service
public class BookBizImpl implements BookBiz {@Autowiredprivate BookMapper BookMapper;@Overridepublic BookVo selectByBid(Integer bid) {return BookMapper.selectByBid(bid);}
}

junit测试

package com.xqx.biz;import com.xqx.vo.BookVo;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.test.context.ContextConfiguration;
import org.springframework.test.context.junit4.SpringJUnit4ClassRunner;@RunWith(SpringJUnit4ClassRunner.class)
@ContextConfiguration(locations={"classpath:Spring-context.xml"})
public class BookBizImplTest {@Autowiredprivate BookBiz BookBiz;@Testpublic void selectByBid() {BookVo bookVo = BookBiz.selectByBid(8);System.out.println(bookVo);BookVo.getHcategory().forEach(System.out::println);}
}

在这里插入图片描述

http://www.yayakq.cn/news/911939/

相关文章:

  • 中山精品网站建设精英django 做网站
  • 北京城乡建设网站网站seo策划方案案例分析
  • 老榕树智能建站系统ps上怎么做网站轮播图
  • 石岩企业网站建设网页版梦幻西游五色石组合
  • 网站建设的关键技术wordpress侧边栏加入广告
  • 在线开发培训网站建设西安app网站开发
  • 建设工程新工艺网站高唐网站开发
  • 网站流量 用什么表示网站怎么做交易平台
  • 肃宁县做网站代理做网站合适吗
  • 福建省建设执业注册管理中心网站移动版网站建设
  • 高端品牌网站开发营销网站制作要素
  • 好推建站北京架设网站
  • 政务内网网站建设方案工程行业做的好的网站有哪些内容
  • 做网站建设公司crm在线的培训服务wordpress前端用户
  • 网站开发好做还是平面好做云狄网站建设
  • 保定网站开发怎么做公众号教程
  • 网站推广是做什么的找灵感的网站
  • 驰业网站建设ui设计师需要会什么
  • 公章在线制作网站做不了wordpress官方主题教程
  • 宁波模版建站公司网站开发工程师的工作描述
  • 哪家公司设计网站好郑州网站建设中国建设建设银行
  • 网站主页效果图网站开发的目的和意义
  • 石家庄+外贸网站建设公司东营住房和城乡建设官网
  • 网站设计学习网win7 iis 添加网站
  • 济南网站建设专业大岭山镇网站建设公司
  • ps最好用的素材网站中铁建设集团有限公司总承包公司
  • 犀牛云网站建设用php做企业网站的可行性
  • 重庆微信网站开发公司网站制作合同
  • 衡水企业做网站企业网站建设如何去规划
  • 开发中英文切换网站如何做怎么样做网站卖农产品