Java Web 学习08

更新:

@Update("update emp set username=#{username},name=#{name},gender=#{gender},image=#{image},job=#{job},entrydate=#{entrydate}," +
        "dept_id=#{deptId},update_time=#{updateTime} where id = #{id}")
public void update(Emp emp);
@Test
public void testUpdate(){
    Emp emp = new Emp();
    emp.setId(18);
    emp.setUsername("lucy");
    emp.setName("路西");
    emp.setImage("1.rpg");
    emp.setGender((short)1);
    emp.setJob((short)1);
    emp.setEntrydate(LocalDate.of(2020,01,01));
    emp.setUpdateTime(LocalDateTime.now());
    emp.setDeptId(1);
    empMapper.update(emp);
}

查询:

@Select("select * from emp where id = #{id}")
public Emp select(Integer id);
@Test
public void testSelect(){
    Emp select = empMapper.select(20);
    System.out.println(select);
}

解决方法1:驼峰命名 (起别名) 

@Select("select id, username, password, name, gender, image, job, entrydate, " +
        "dept_id AS deptId, create_time AS createTime, update_time AS updateTime from emp where id = #{id}")
public Emp select(Integer id);

方案2:使用注解

@Results({
        @Result(column = "dept_id", property = "deptId"),
        @Result(column = "create_time", property = "createTime"),
        @Result(column = "update_time", property = "updateTime")
})
@Select("select * from emp where id = #{id}")
public Emp select(Integer id);

方案3:开启mybatis驼峰自动映射开关(推荐)

在配置文件中设置

mybatis.configuration.map-underscore-to-camel-case=true

条件查询:

例:

@Test
public void testList(){
    List<Emp> empList = empMapper.list("张", (short) 1, LocalDate.of(2010, 01, 01), LocalDate.of(2020, 1, 1));
    System.out.println(empList);
}
@Select("select * from emp where name like '%${name}%' and gender = #{gender} and entrydate between #{begin} and #{end} order by update_time desc")
public List<Emp> list(String name, Short gender, LocalDate begin, LocalDate end);

#{}不能卸载''里面所以使用'%${name}%'   效率低,不安全

解决方法:使用concat拼接字符串 

concat('%',#{name},'%')

XML映射文件:

 

EmpMapper.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.example.de.mapper.EmpMapper">

    <select id="list" resultType="com.example.de.pojo.Emp">
        select * from emp where name like concat('%',#{name},'%') and gender = #   {gender} and entrydate between #{begin} and #{end} order by update_time desc
    </select>
</mapper>
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值