提示:

Mapper配置文件的命名空间为对应接口包名+接口名字,这个经常会忘记和搞错的!!


select标签

在接口中编写三个查询方法

//获取全部用户
List<User> selectUser(); //根据id查询用户
User getUserByID(int id); //根据一个对象查询
User getUserByUser(User user);

标签信息

    <select id="" parameterType="" resultType="" resultMap="">
-- sql语句 (#{name}--这个格式能获取方法参数与sql语句整合)
</select>

id:对应接口对应方法名字

parameterType:为参数类型

resultType:查询结果返回类型

resultMap:手动映射查询结果(之后随笔会介绍)

UserMapper.xml中select语句:

<select id="selectUser" resultType="com.ttt.pojo.User" >
select * from mybatis.user
</select> <select id="getUserByID" parameterType="int" resultType="com.ttt.pojo.User">
select * from mybatis.user where id=#{id}
</select> <select id="getUserByUser" parameterType="com.ttt.pojo.User" resultType="com.ttt.pojo.User">
select * from mybatis.user where name=#{name}
</select>

1、若返回结果为一个集合,那么返回类型就填返回集合里对象类型。

2、在接口方法的参数前加 @Param属性 ,Sql语句编写的时候,直接取@Param中设置的值即可,不需要单独设置参数类型

例如:

//通过密码和名字查询用户
User selectUserByNP(@Param("username") String username,@Param("pwd") String pwd);
/*
<select id="selectUserByNP" resultType="com.ttt.pojo.User">
select * from user where name = #{username} and pwd = #{pwd}
</select>
*/

测试语句:

@Test
public void test01(){
SqlSession sqlSession = MybatisUtils.getSqlSession(); UserMapper userMapper = sqlSession.getMapper(UserMapper.class);
List<User> users1 = userMapper.selectUser();
User user2 = userMapper.getUserByID(1);
User user3 = userMapper.getUserByUser(new User(1, "黑子", "123456")); System.out.println("selectUser方法结果:");
for (User user : users1) {
System.out.println(user);
} System.out.println("getUserByID方法结果:");
System.out.println(user2); System.out.println("getUserByUser方法结果:");
System.out.println(user3); sqlSession.close();
}

test


insert标签:

1、在接口添加方法

//insert一个用户
int addUser(User user);

2、UserMapper.xml中insert语句

<insert id="addUser" parameterType="com.ttt.pojo.User">
insert into user(id, name, pwd) values (#{id}, #{name}, #{pwd})
</insert>

3、测试

   @Test
public void test04(){
SqlSession sqlSession = MybatisUtils.getSqlSession();
UserMapper userMapper = sqlSession.getMapper(UserMapper.class); userMapper.addUser(new User(4,"demo", "1234" ));
sqlSession.commit(); sqlSession.close();
}

test


update标签

1、接口添加方法

//修改用户
int updateUser(User user);

2、UserMapper.xml中update语句

<update id="updateUser" parameterType="com.ttt.pojo.User">
update user set name = #{name}, pwd=#{pwd} where id=#{id} </update>

注:update语句没有返回标签

3、测试

@Test
public void test05(){
SqlSession sqlSession = MybatisUtils.getSqlSession();
UserMapper userMapper = sqlSession.getMapper(UserMapper.class); userMapper.updateUser(new User(4, "绿员君", "123456"));
sqlSession.commit(); sqlSession.close();
}

test


delete标签

1、接口中添加方法

//删除一个用户
int deleteUser(int id);

2、UserMapper.xml中delete语句

<delete id="deleteUser" parameterType="int">
delete from mybatis.user where id=#{id};
</delete>

3、测试

@Test
public void test06(){
SqlSession sqlSession = MybatisUtils.getSqlSession();
UserMapper userMapper = sqlSession.getMapper(UserMapper.class); userMapper.deleteUser(4);
sqlSession.commit(); sqlSession.close();
}

test


传参技巧--万能map

  1. 在接口方法中,参数直接传递Map  
    1. User selectUserByNP2(Map<String,Object> map);
  1. 编写sql语句的时候,需要传递参数类型,参数类型为map

    1. <select id="selectUserByNP2" parameterType="map" resultType="com.ttt.pojo.User">
      select * from user where name = #{username} and pwd = #{pwd}
      </select>
  2. 在使用方法的时候,Map的 key 为 sql中取的值即可,没有顺序要求!

    Map<String, Object> map = new HashMap<String, Object>();
    map.put("username","小明");
    map.put("pwd","123456");
    User user = mapper.selectUserByNP2(map);

  如果参数太多,我们可以使用map实现,而参数太少了,就直接传递参数即可。


小结:

  • 所有的增删改操作都需要提交事务!
  • 接口所有的普通参数,尽量都写上@Param参数,尤其是多个参数时,必须写上!
  • 有时候根据业务的需求,可以考虑使用map传递参数!
  • 为了规范操作,在SQL的配置文件中,我们尽量将Parameter参数和resultType都写上!

Mybatis:CRUD操作的更多相关文章

  1. MyBatis crud操作

    Test2.java package com.mycom.mybatis_1.crud; import java.util.List; import org.apache.ibatis.session ...

  2. 使用MyBatis对表执行CRUD操作

    一.使用MyBatis对表执行CRUD操作——基于XML的实现 1.定义sql映射xml文件 userMapper.xml文件的内容如下: <?xml version="1.0&quo ...

  3. MyBatis学习总结(二)——使用MyBatis对表执行CRUD操作(转载)

    本文转载自:http://www.cnblogs.com/jpf-java/p/6013540.html 上一篇博文MyBatis学习总结(一)--MyBatis快速入门中我们讲了如何使用Mybati ...

  4. MyBatis入门学习教程-使用MyBatis对表执行CRUD操作

    上一篇MyBatis学习总结(一)--MyBatis快速入门中我们讲了如何使用Mybatis查询users表中的数据,算是对MyBatis有一个初步的入门了,今天讲解一下如何使用MyBatis对use ...

  5. MyBatis学习总结(二)——使用MyBatis对表执行CRUD操作

    一.使用MyBatis对表执行CRUD操作--基于XML的实现 1.定义sql映射xml文件 userMapper.xml文件的内容如下: 1 <?xml version="1.0&q ...

  6. MyBatis学习总结(二)——使用MyBatis对表执行CRUD操作

    上一篇博文MyBatis学习总结(一)——MyBatis快速入门中我们讲了如何使用Mybatis查询users表中的数据,算是对MyBatis有一个初步的入门了,今天讲解一下如何使用MyBatis对u ...

  7. mybatis(二)执行CRUD操作的两种方式配置和注解

    一.使用MyBatis对表执行CRUD操作——基于XML的实现 1.定义sql映射xml文件 userMapper.xml文件的内容如下: <?xml version="1.0&quo ...

  8. MyBatis学习总结_02_使用MyBatis对表执行CRUD操作

    一.使用MyBatis对表执行CRUD操作——基于XML的实现 1.定义sql映射xml文件 userMapper.xml文件的内容如下: 1 <?xml version="1.0&q ...

  9. 【转】MyBatis学习总结(二)——使用MyBatis对表执行CRUD操作

    [转]MyBatis学习总结(二)——使用MyBatis对表执行CRUD操作 上一篇博文MyBatis学习总结(一)——MyBatis快速入门中我们讲了如何使用Mybatis查询users表中的数据, ...

  10. Mybatis的学习总结二:使用Mybatis对表进行CRUD操作【参考】

    一.使用Mybatis对表进行CRUD操作------基于XML的实现 1.定义SQL的映射文件 2.在conf.xml中进行注册. 2.创建测试类 [具体过程参考:Mybatis的学习总结一] 二. ...

随机推荐

  1. Linux 命令个人笔记

    [表示命令]man -f [] 显示一个命令的功能whatis [] 显示一个命令的功能ls -lR | grep '^-' | wc -l 统计一个目录下总共有多少个文件head [-n numbe ...

  2. SpringBoot源码分析之---SpringBoot项目启动类SpringApplication浅析

    源码版本说明 本文源码采用版本为SpringBoot 2.1.0BUILD,对应的SpringFramework 5.1.0.RC1 注意:本文只是从整体上梳理流程,不做具体深入分析 SpringBo ...

  3. 02-19 k近邻算法(鸢尾花分类)

    [TOC] 更新.更全的<机器学习>的更新网站,更有python.go.数据结构与算法.爬虫.人工智能教学等着你:https://www.cnblogs.com/nickchen121/ ...

  4. react-native开发经验

    # **RN开发经验** ## 一.环境配置关于环境配置,前辈已有完整的总结:http://tvrn.devops.letv.com/docs/Environment.html **IDE准备:** ...

  5. 导图梳理springboot手动、自动装配,让springboot不再难懂

    什么是springboot 在学springboot之前,你必须有spring.spring mvc基础,springboot的诞生其实就是用来简化新Spring应用的初始搭建以及开发过程,该框架使用 ...

  6. Redis实现分布式文件夹锁

    缘起 最近做一个项目,类似某度云盘,另外附加定制功能,本人负责云盘相关功能实现,这个项目跟云盘不同的是,以项目为分配权限的单位,同一个项目及子目录所有有权限的用户可以同时操作所有文件,这样就很容易出现 ...

  7. 九、Executor框架

    Executor框架 ​ 我们知道线程池就是线程的集合,线程池集中管理线程,以实现线程的重用,降低资源消耗,提高响应速度等.线程用于执行异步任务,单个的线程既是工作单元也是执行机制,从JDK1.5开始 ...

  8. 代码审计-YXcms1.4.7

    题外: 今天是上班第一天,全都在做准备工作,明天开始正式实战做事. 看着周围稍年长的同事和老大做事,自己的感觉就是自己还是差的很多很多,自己只能算个废物. 学无止境,我这样的垃圾废物就该多练,保持战斗 ...

  9. Powershell基础之脚本执行

    Bat 这就是我们常用的Bat脚本,全名为批处理文件,脚本中就是我们在CMD中使用到的命令,这里提一个小问题:CMD的命令行执行命令的优先级是.bat > .exe,那么假如我放一个cmd.ba ...

  10. Vue核心之数据劫持

    前瞻 当前前端界空前繁荣,各种框架横空出世,包括各类mvvm框架横行霸道,比如Anglar,Regular,Vue,React等等,它们最大的优点就是可以实现数据绑定,再也不需要手动进行DOM操作了, ...