一、创建项目
二、导入依赖
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<parent>
<groupId>com.biem</groupId>
<artifactId>mybatis-4ch</artifactId>
<version>1.0-SNAPSHOT</version>
</parent>
<artifactId>OneToOne</artifactId>
<properties>
<maven.compiler.source>20</maven.compiler.source>
<maven.compiler.target>20</maven.compiler.target>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
</properties>
<dependencies>
<dependency>
<groupId>org.mybatis</groupId>
<artifactId>mybatis</artifactId>
<version>3.4.6</version>
</dependency>
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>8.0.18</version>
</dependency>
<dependency>
<groupId>log4j</groupId>
<artifactId>log4j</artifactId>
<version>1.2.12</version>
</dependency>
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>4.12</version>
<scope>test</scope>
</dependency>
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
<version>1.18.0</version>
</dependency>
</dependencies>
</project>
三、 创建包等文件
1.一对一查询
1.1 数据库准备
USE mybatis;
CREATE TABLE tb_idcard(
id INT PRIMARY KEY AUTO_INCREMENT,
CODE VARCHAR(18));
INSERT INTO tb_idcard(CODE) VALUES('152221198711020624');
INSERT INTO tb_idcard(CODE) VALUES('152201199008150317');
CREATE TABLE tb_person(
id INT PRIMARY KEY AUTO_INCREMENT,
name VARCHAR(32),
age INT,
sex VARCHAR(8),
card_id INT UNIQUE,
FOREIGN KEY(card_id) REFERENCES tb_idcard(id));
INSERT INTO tb_person(name,age,sex,card_id) VALUES('Rose',22,'女',1);
INSERT INTO tb_person(name,age,sex,card_id) VALUES('jack',23,'男',2);
1.2 实体类
IdCard.java
Person.java
1.3用户配置接口
IdCardMapper.java
PersonMapper.java
package com.biem.mapper;
public interface PersonMapper {
}
1.4 用户配置文件
IdCardMapper.xml
PersonMapper.xml
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper
PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.biem.mapper.PersonMapper">
</mapper>
1.5嵌套查询方式
IdCardMapper.java添加
public IdCard findCodeById(Integer id);
PersonMapper.java添加
public Person findPersonById(Integer id);
IdCardMapper.xml添加
<select id="findCodeById" parameterType="Integer" resultType="IdCard">
select * from tb_idcard where id=#{id}
</select>
PersonMapper.xml添加
<resultMap id="IdCardWithPersonResult" type="Person">
<id property="id" column="id"></id>
<result property="name" column="name"/>
<result property="age" column="age"/>
<result property="sex" column="sex"/>
<association property="card" column="card_id" javaType="IdCard"
select="com.biem.mapper.IdCardMapper.findCodeById"/>
</resultMap>
<select id="findPersonById" parameterType="Integer" resultMap="IdCardWithPersonResult">
select * from tb_person where id = #{id}
</select>
PersonTest.java
package com.biem.test;
import com.biem.mapper.PersonMapper;
import com.biem.pojo.Person;
import com.biem.util.MybatisUtil;
import org.apache.ibatis.session.SqlSession;
import org.junit.Test;
public class PersoTest {
@Test
public void testFindPersonById(){
SqlSession session = MybatisUtil.openSession();
PersonMapper mapper = session.getMapper(PersonMapper.class);
Person person = mapper.findPersonById(1);
System.out.println(person);
session.close();
}
}
运行结果:![](https://img-blog.csdnimg.cn/94120c7d4e8a4f62af0d8a0abcf4a848.png)
1.6嵌套结果方式
PersonMapper.java 添加
public Person findPersonByIdWithNestedResults(Integer id);
PersonMapper.xml添加
<resultMap id="IdCardWithPersonResult2" type="Person">
<id property="id" column="id"></id>
<result property="name" column="name"/>
<result property="age" column="age"/>
<result property="sex" column="sex"/>
<association property="card" javaType="IdCard">
<id property="id" column="card_id"></id>
<result property="code" column="code"></result>
</association>
</resultMap>
<select id="findPersonByIdWithNestedResults" parameterType="Integer" resultMap="IdCardWithPersonResult">
select p.*, idcard.code
from tb_person p, tb_idcard idcard
where p.card_id = idcard.id and p.id = #{id}
</select>
PersonTest.java添加
@Test
public void testFindPersonByIdWithNestedResults(){
SqlSession session = MyBatisUtil.openSession();
PersonMapper mapper = session.getMapper(PersonMapper.class);
Person person = mapper.findPersonByIdWithNestedResults(1);
System.out.println(person);
session.close();
}