0
点赞
收藏
分享

微信扫一扫

CGB2111Mybatis

NicoalsNC 2022-02-09 阅读 19
javamybatis

1.动态SQL

1.1动态更新
测试类

@Test
    public void testUpdate(){
        User user = new User();
        user.setId(5).setName("御弟哥哥").setAge(18);  //sex=null
        userMapper.updateUser(user);
        System.out.println("修改操作成功!!!");
}

Mapper接口

void updateUser(User user);

Mapper映射

    <update id="updateUser">
        update demo_user
            <set>
                <if test="name !=null">name=#{name},</if>
                <if test="age !=null">age=#{age},</if>
                <if test="sex !=null">sex=#{sex}</if>
            </set>
            where id=#{id}
    </update>

1.2动态SQL
choos when otherwise

测试类

 @Test
    public void testFindChoose(){
        User user = new User();
        user.setName("御弟哥哥").setAge(18).setSex("男");
        List<User> list = userMapper.findUserChoose(user);
        System.out.println(list);
    }

Mapper接口

List<User> findUserChoose(User user);

Mapper映射

    <select id="findUserChoose" resultType="User">
        select * from demo_user where
            <choose>
                <when test="name !=null">name=#{name}</when>
                <when test="age  !=null">age=#{age}</when>
                <otherwise>sex = #{sex}</otherwise>
            </choose>
    </select>

2.数据封装-resultMap

Pojo属性
在这里插入图片描述
测试类
在这里插入图片描述
测试接口
在这里插入图片描述
Mapper映射
在这里插入图片描述

3.Mybatis

3.1常见的关联性

核心从一头出发看向另一头
1.一对一

2.一对多

3.多对一

4.多对多

3.2编辑表
表1:emp
字段 id name age dept_id
在这里插入图片描述
表2:dept
在这里插入图片描述
3.3关联关系实现
编辑Emp对象
在这里插入图片描述
编辑Dept对象在这里插入图片描述

代码搭建
在这里插入图片描述

举报

相关推荐

0 条评论