mybatis处理数据库中关联关系

1.数据库关联关系

  • 一对一、一对多、多对多
  • 一对一关系处理
create  table t_person(
 id int(6) primary key auto_increment,
 name varchar(40),
 age int(3),
 cardNo varchar(18)
);

create  table t_info(
 id int(6) primary key auto_increment,
 cardNo varchar(18),
 address varchar(100)
);
  • mybatis中保存用户信息的同时保存身份信息
public class Info {
    private Integer id;
    private String cardNo;
    private String address;
    public Info() {
    }
    public Info(Integer id, String cardNo, String address) {
        this.id = id;
        this.cardNo = cardNo;
        this.address = address;
    }

    public Integer getId() {
        return id;
    }

    public void setId(Integer id) {
        this.id = id;
    }

    public String getCardNo() {
        return cardNo;
    }

    public void setCardNo(String cardNo) {
        this.cardNo = cardNo;
    }

    public String getAddress() {
        return address;
    }

    public void setAddress(String address) {
        this.address = address;
    }

    @Override
    public String toString() {
        return "Info{" +
                "id=" + id +
                ", cardNo='" + cardNo + '\'' +
                ", address='" + address + '\'' +
                '}';
    }
}
public class Person {
    private Integer id;
    private String name;
    private Integer age;
    private String cardNo;

    public Person() {
    }

    public Person(Integer id, String name, Integer age, String cardNo) {
        this.id = id;
        this.name = name;
        this.age = age;
        this.cardNo = cardNo;
    }

    public Integer getId() {
        return id;
    }

    public void setId(Integer id) {
        this.id = id;
    }

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    public Integer getAge() {
        return age;
    }

    public void setAge(Integer age) {
        this.age = age;
    }

    public String getCardNo() {
        return cardNo;
    }

    public void setCardNo(String cardNo) {
        this.cardNo = cardNo;
    }

    @Override
    public String toString() {
        return "Person{" +
                "id=" + id +
                ", name='" + name + '\'' +
                ", age=" + age +
                ", cardNo='" + cardNo + '\'' +
                '}';
    }
}

mybatis 插入语句

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper
        PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
        "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<!-- namespace:命名空间 用来书写当前mapper文件是对哪个dao接口的实现
全限定名:包。类
-->
<mapper namespace="com.baizhi.dao.InfoDao">
    <insert id="save" parameterType="com.baizhi.entity.Info" keyProperty="id" useGeneratedKeys="true">
        insert into t_info values (#{id},#{cardNo},#{address})
    </insert>
</mapper>
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper
        PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
        "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.baizhi.dao.PersonDAO">
    <insert id="save" parameterType="com.baizhi.entity.Person" keyProperty="id" useGeneratedKeys="true">
        insert into t_person values (#{id},#{name},#{age},#{cardNo})
    </insert>
</mapper>

数据库配置

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE configuration
        PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
        "http://mybatis.org/dtd/mybatis-3-config.dtd">
<configuration>
    <!--环境操作哪个数据库 environments 环境复数:prod 生产dev开发 test 测试-->
    <environments default="dev">
        <!--开发环境 -->
        <environment id="dev">
            <transactionManager type="JDBC"/>
            <dataSource type="POOLED">
                <property name="driver" value="com.mysql.cj.jdbc.Driver"/>
                <property name="url" value="jdbc:mysql://localhost:3306/study"/>
                <property name="username" value="root"/>
                <property name="password" value="12345"/>
            </dataSource>
        </environment>
        <!--生产环境 -->
        <environment id="prod">
            <transactionManager type="JDBC"/>
            <dataSource type="POOLED">
                <property name="driver" value="com.mysql.jdbc.Driver"/>
                <property name="url" value="jdbc:mysql://localhost:3306/study"/>
                <property name="username" value="root"/>
                <property name="password" value="12345"/>
            </dataSource>
        </environment>
        <!--测试环境 -->
        <environment id="test">
            <transactionManager type="JDBC"/>
            <dataSource type="POOLED">
                <property name="driver" value="com.mysql.jdbc.Driver"/>
                <property name="url" value="jdbc:mysql://localhost:3306/study?characterEncoding=utf-8"/>
                <property name="username" value="root"/>
                <property name="password" value="12345"/>
            </dataSource>
        </environment>
    </environments>
    <!--注册mapper配置文件-->
    <mappers>
        <mapper resource="com/baizhi/mapper/InfoDAO.xml"/>
        <mapper resource="com/baizhi/mapper/PersonDAO.xml"/>
    </mappers>
</configuration>

测试类

public class TestInfo {
    @Test
    public void testSaveInfo(){
        SqlSession sqlSession = MybatisUtil.getSqlSession();
        System.out.println(sqlSession);
        try {
            InfoDao infoDao = sqlSession.getMapper(InfoDao.class);
            System.out.println(infoDao);
            Info info = new Info();
            info.setCardNo("13456789900");
            info.setAddress("光谷春天");
            int count = infoDao.save(info);
            System.out.println(count);
            sqlSession.commit();
        } catch (Exception e) {
            e.printStackTrace();
            sqlSession.rollback();
        } finally {
            MybatisUtil.close(sqlSession);
        }
    }
}

public class TestPerson {
    @Test
    public void testSavePerson(){
        SqlSession sqlSession = MybatisUtil.getSqlSession();
        System.out.println(sqlSession);
        try {
            PersonDAO personDAO = sqlSession.getMapper(PersonDAO.class);
            System.out.println(personDAO);
            Person person = new Person();
            person.setName("销售");
            person.setAge(12);
            person.setCardNo("1222222");
            int count = personDAO.save(person);
            System.out.println(count);
            sqlSession.commit();
        } catch (Exception e) {
            e.printStackTrace();
            sqlSession.rollback();
        } finally {
            MybatisUtil.close(sqlSession);
        }
    }
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值