Mybatis注解学习-增删改查

导读:本篇文章讲解 Mybatis注解学习-增删改查,希望对大家有帮助,欢迎收藏,转发!站点地址:www.bmabk.com

自动提交事务:

请添加图片描述

增删改查:去掉了Mapper.xml文件,改成了使用注解:

请添加图片描述

请添加图片描述

import com.ftz.Demo.dao.UserMapper;
import com.ftz.Demo.po.User;
import com.ftz.Demo.utils.MybatisUtil;
import org.apache.ibatis.session.SqlSession;
import org.junit.Test;

public class TestUser {


   @Test
    public  void  Test(){
       SqlSession sqlSession = MybatisUtil.getSqlSession();
       UserMapper mapper = sqlSession.getMapper(UserMapper.class);
       mapper.addNewUser(new User(13,"helloo","123321"));
       sqlSession.close();
   }

   @Test
   public void  Find(){
      SqlSession sqlSession = MybatisUtil.getSqlSession();
      UserMapper mapper = sqlSession.getMapper(UserMapper.class);
      mapper.getUserBuId(9);
      sqlSession.close();

   }
   @Test
   public void  IdTest(){
      SqlSession sqlSession = MybatisUtil.getSqlSession();
      UserMapper mapper = sqlSession.getMapper(UserMapper.class);
      mapper.updateUser(new User(5,"范直至","123456"));
      sqlSession.close();

   }

   @Test
   public  void DeleteUser(){
      SqlSession sqlSession = MybatisUtil.getSqlSession();
      UserMapper mapper = sqlSession.getMapper(UserMapper.class);
      mapper.Delete(8);
      sqlSession.close();

   }


}

配置文件:

请添加图片描述

对比之前:

请添加图片描述

测试代码几乎一样:

import com.ftz.Demo.dao.UserMapper;
import com.ftz.Demo.po.User;
import com.ftz.Demo.utils.MybatisUtil;
import org.apache.ibatis.session.SqlSession;
import org.junit.Test;

public class TestUser {


   @Test
    public  void  Test(){
       SqlSession sqlSession = MybatisUtil.getSqlSession();
       UserMapper mapper = sqlSession.getMapper(UserMapper.class);
       mapper.addNewUser(new User(13,"helloo","123321"));
       sqlSession.close();
   }

   @Test
   public void  Find(){
      SqlSession sqlSession = MybatisUtil.getSqlSession();
      UserMapper mapper = sqlSession.getMapper(UserMapper.class);
      mapper.getUserBuId(9);
      sqlSession.close();

   }
   @Test
   public void  IdTest(){
      SqlSession sqlSession = MybatisUtil.getSqlSession();
      UserMapper mapper = sqlSession.getMapper(UserMapper.class);
      mapper.updateUser(new User(5,"范直至","123456"));
      sqlSession.close();

   }

   @Test
   public  void DeleteUser(){
      SqlSession sqlSession = MybatisUtil.getSqlSession();
      UserMapper mapper = sqlSession.getMapper(UserMapper.class);
      mapper.Delete(8);
      sqlSession.close();

   }


}

这里说两个小细节,那就是在注释中的sql语句:举个例子:

1:

@Insert("insert into user(id,name,pwd) values(#{id},#{name},#{password})")

这里的除了user(id,name,pwd) 这个地方的括号里面的名字需要对应数据库中的名字,其他的都是要和实体类对应的,自己的的实体类构造方法名字相对应!

2:在括号中使用参数的时候:举个例子:


    @Delete("delete from user where id = #{uid}")
    int Delete(@Param("uid") int id);

这里的注解里面是uid,那么#{}这个括号里面的必须对应这个注解里面设置的名字,就不是实体类中的名字了

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

文章由极客之音整理,本文链接:https://www.bmabk.com/index.php/post/81004.html

(0)
小半的头像小半

相关推荐

极客之音——专业性很强的中文编程技术网站,欢迎收藏到浏览器,订阅我们!