MyBatis04:使用注解开发

MyBatis04:使用注解开发

使用注解

UserMapper接口中直接使用注解

public interface UserMapper {

    @Select("select * from user")
    public List<User> getAllUser();

}

使用class绑定接口

<mappers>
    <mapper class="com.wgg.mapper.UserMapper"/>
</mappers>

测试

@Test
public void testGetAllUser(){
    SqlSession session = MybatisUtils.getSession();
    //本质上利用了jvm的动态代理机制
    UserMapper mapper = session.getMapper(UserMapper.class);
    List<User> users = mapper.getAllUser();
    for (User user : users) {
        System.out.println(user);
    }
    session.close();
}

image-20201109111728658

image-20201109112236464

本质上是动态代理

image-20201106165738045

mybatis详细执行流程

mybatis执行流程

重载MybatisUtils工具类中的getSession()方法
  • true:自动提交事务
  • false:关闭自动提交
  • 默认是false
//获取sqlSession连接
public static SqlSession getSession(){
    return sqlSessionFactory.openSession(true);
}

public static SqlSession getSession(boolean flag){
    return sqlSessionFactory.openSession(flag);
}

查询

  1. UserMapper接口
@Select("select * from user where id=#{id}")
User selectUserById(@Param("id") int id);
  1. 测试
@Test
public void testSelectUserById() {
    SqlSession session = MybatisUtils.getSession();
    UserMapper mapper = session.getMapper(UserMapper.class);
    User user = mapper.selectUserById(1);
    System.out.println(user);

    session.close();
}

添加

  1. UserMapper接口
@Insert("insert into user(id,name,pwd) values(#{id},#{name},#{pwd})")
int addUser(User user);
  1. 测试
    @Test
    public void testAddUser() {
        SqlSession session = MybatisUtils.getSession();
        UserMapper mapper = session.getMapper(UserMapper.class);
        mapper.addUser(new User(12, "小三", "xiaosan"));

        //已经设置事务自动提交
        session.close();
    }

修改

  1. UserMapper接口
@Update("update user set name=#{name},pwd=#{pwd} where id=#{id}")
int updateUser(User user);
  1. 测试
@Test
public void testUpdateUser(){
    SqlSession session = MybatisUtils.getSession();
    UserMapper mapper = session.getMapper(UserMapper.class);
    mapper.updateUser(new User(12,"唐三","tangsan"));

    //已经设置事务自动提交
    session.close();
}

删除

  1. UserMapper接口
@Delete("delete from user where id=#{id}")
int deleteUser(@Param("id")int id);
  1. 测试
@Test
public void testDeleteUser(){
    SqlSession session = MybatisUtils.getSession();
    UserMapper mapper = session.getMapper(UserMapper.class);
    mapper.deleteUser(12);

    //已经设置事务自动提交
    session.close();
}

@Param

@Param注解用于给方法参数起一个名字

  • 在方法只接受一个参数的情况下,可以不使用@Param。
  • 在方法接受多个参数的情况下,建议一定要使用@Param注解给参数命名。
  • 如果参数是 JavaBean , 则不能使用@Param
  • 不使用@Param注解时,参数只能有一个,并且是Javabean。

#与$的区别

  • #{} 的作用主要是替换预编译语句(PrepareStatement)中的占位符? 【推荐使用】
INSERT INTO user (name) VALUES (#{name});
INSERT INTO user (name) VALUES (?);
  • ${} 的作用是直接进行字符串替换
INSERT INTO user (name) VALUES ('${name}');
INSERT INTO user (name) VALUES ('wgg');
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值