mybatis plus CRUD
首先我们的项目建立之后我们要建立一个实体类来对应我们的数据裤中的信息
employee
import com.baomidou.mybatisplus.annotation.IdType;
import com.baomidou.mybatisplus.annotation.TableField;
import com.baomidou.mybatisplus.annotation.TableId;
import com.baomidou.mybatisplus.annotation.TableName;
import com.dailuobo.devops.common.domain.entity.BaseEntity;
import lombok.Data; /**
* TableName
* 是让我们的类和数据库的表建立关系
* value 是表明 默认不写value
*/
@Data
@TableName("tbl_employee")
public class Employee { /**
* TableId
* value 指定表中额主键列名 如果实体属性和列名一致 可以省略不写
* type指定主键策略 mybatisplus文档上有
*/
//主键注解 因为我们的表设置的是自增的但是要让mybatisplus同步否则报错
@TableId(value = "id",type = IdType.AUTO) //设置自增 因为
private Integer id; @TableField(value = "last_name") //标注当前数据库的列名
private String lastName;
private String email;
private Integer gender;
private Integer age; //如果这个类中有其他的非数据的字段这个时候可以使用
@TableField(exist = false)
private Double salary; //再插入的时候就会忽略这个字段不去数据库中校验
}
然后为这个类再建立能操作数据的方法类Mapper
EmployeeMapper
import com.baomidou.mybatisplus.core.mapper.BaseMapper;
import com.dailuobo.devops.mp.common.domain.entity.Employee; /**
* Mapper接口
* 基于mybatis:在Mapper接口中编写CRUD方法 提供Mapper接口对应的SQL映射文件以及方法对应的SQL语句
*
*
* 基于Mybatis Plus 让XXXMapper继承BaseMapper接口即可
* BaseMapper<T> : 泛型指定的就是当前Mapper解耦所操作的实体类对象
*/ public interface EmployeeMapper extends BaseMapper<Employee> {
}
然后我们可以通过这个EmployeeMapper类进行数据的增删改的操作也可以 通过services类继承之后再进行间接操作
我现在测试方法中进行操作:
@Test
public void testCommonInsert(){ //初始化employee对象
Employee employee = new Employee(); employee.setLastName("test");
employee.setEmail("mp@caicai.com");
employee.setGender(1);
// employee.setAge(20); //插入数据库 insert会对实体类的属性进行非空判断 只有非空才会出现在sql语句中
Integer result = employeeMapper.insert(employee); //通过点进去的源码可以看到是有一个返回值的 这个返回值是int就是我们队数据库的影响的条数 // employeeMapper.insertAllColumn 插入的时候如果值没有信息设置为null字符插入 而insert现在集合了这个默认的功能
System.out.println("result"+result); //我们可以通过对象.getId()来获取对象表中数据的主键值
employee.getId();
}
插入:insert
这个就相当于我们的python的orm操作信息,都是通过特定的语句可以直接进行数据的操作
mapper对象.insert(对象);
insert插入的是一个对象 然后返回的是一个插入条数 数字
//初始化employee对象
Employee employee = new Employee(); employee.setLastName("test");
employee.setEmail("mp@caicai.com");
employee.setGender(1);
employee.setAge(20); //插入数据库 insert会对实体类的属性进行非空判断 只有非空才会出现在sql语句中
Integer result = employeeMapper.insert(employee); //通过点进去的源码可以看到是有一个返回值的 这个返回值是int就是我们队数据库的影响的条数 // employeeMapper.insertAllColumn 插入的时候如果值没有信息设置为null字符插入 而insert现在集合了这个默认的功能
System.out.println("result"+result); // result 1
插入的时候只能放在最后插入 哪怕指定已经存在的id插入也不会修改,会自动在后面插入
@Test
public void testUpdate(){ Employee employee = new Employee();
employee.setLastName("insert_one");
employee.setId(7); // 只可以当做插入不可以当做修改 如果指定已经有的id插入 也会放在后面依次插入 Integer result = employeeMapper.insert(employee);
if (result >= 1){
System.out.println("插入成功"+result);
}else{
System.out.println("插入失败");
} }
getId() :获取对象表中的主键值
//我们可以通过对象.getId()来获取对象表中数据的主键值
employee.getId();获取employee 对象的主键值
updateById(); 修改信息 指定主键id去修改 不然就会修改失败 报错,哪怕把一整个对象更新进去也要指定这个对象的主键id
Mapper对象.updateById(更新对象); 更新的时候就要知道和python一样我们先设置值 然后再更新到数据库中
@Test
public void testUpdate(){
Employee employee = new Employee(); employee.setId(5); // 指定修改的主键id信息
employee.setLastName("222");
// employee.setEmail("eqeq"); //updatebyid如果全部更新 就直接把对象放进去 如果针对选择更新 那就获取这个更新的主键id然后进行更新 Integer result = employeeMapper.updateById(employee);
System.out.println("result:"+result); //必须要 }
根据条件修改:update()
update(对象,条件构造器)
QueryWrapper<Server> queryWrapper = new QueryWrapper<>();
queryWrapper.eq("id",name); //条件
serverMapper.update(server,queryWrapper);
修改:
Employee employee = new Employee();
employee.setId(7);
employee.setEmail("111111");
// employee.setLastName("update_two");
// Integer result = employeeMapper.updateById(employee); UpdateWrapper updateWrapper = new UpdateWrapper();
updateWrapper.eq("id", 7);
// Integer result = employeeMapper.update (employee,new UpdateWrapper().set("name", "buiob")); employeeMapper.update(employee, updateWrapper);
查询操作:
selectById(); 通过主键查询
selectBatchIds() 通过主键list查询 返回的也是list集合 selectList();根据判断条件查询 selectOne() 构造查询条件 返回的是一个对象
selectById();
Mapper对象.selectById(要查询的主键id);
@Test
public void testcommonSelect(){ //获取主键是3的数据对象
Employee employee = employeeMapper.selectById(3); //根据主键来查找到这个主键对应的数据 获取的是一个对象
System.out.println("employee对象:"+employee);
}
selectOne(); 和selectMap差不多都是按照条件然后查询 但是返回值不同
构构造查询条件 () 内传递的是对象
@Test
public void selectOne(){ // Employee employee = new Employee();
// employee.setEmail("tree.com");
Employee employee1 = employeeMapper.selectOne(new QueryWrapper<Employee>().eq("email","three.com"));
System.out.println("selevtOne:"+ employee1); //selevtOne:Employee(id=2, lastName=three, email=three.com, gender=1, age=30, salary=null) }
查询多个信息 selectBatchIds() 返回的是list集合
/**
* 通过多个id获取
*/
@Test
public void getlist(){ //返回的是查询的对象信息
List<Integer> idlist = new ArrayList<>();
idlist.add(1);
idlist.add(3); List<Employee> employees = employeeMapper.selectBatchIds(idlist);
System.out.println("employees:"+employees); //返回的就是查询到的3条信息
}
构造条件查询:selectByMap()返回的list集合 里面必须是map对象
/** selectByMap 条件查询
* 通过Map封装条件查询
*/
@Test
public void getMap(){
//通过Map封装信息
Map<String,Object> columnMap = new HashMap<>();
columnMap.put("last_name","Tom"); //这里面写列名而不是对应的属性名
columnMap.put("gender",1); //查询last_name是Tom gender是1的数据库信息
List<Employee> employees = employeeMapper.selectByMap(columnMap);
System.out.println(employees); //就获取的查询的对象信息
// 结果封装成Map:Map:[Employee(id=2, lastName=three, email=three.com, gender=1, age=30, salary=null)]
}
@Test
public void selectMap(){
Map<String,Object> stringMap = new HashMap<>();
//设置条件查询
stringMap.put("email","three.com");//设置查询条件
List<Employee> employeeList = employeeMapper.selectByMap(stringMap); //查询email == tree.com
System.out.println("Map:"+employeeList); }
selectList(); 按照字段查询
@Test
public void selecList(){
// select 要查询的字段 只返回你设置的字段其他的都是null
List<Employee> employeeList = employeeMapper.selectList(new QueryWrapper<Employee>().select("email"));
System.out.println(employeeList); 返回的是每条记录的设置查询的字段 其余的不显示
}
相当于执行SELECT email FROM tbl_employee 这条sql语句
@Test
public void selectList(){
Employee employee = new Employee();
// where 条件查询和and添加和orderby使用
// SELECT age FROM tbl_employee WHERE email = ? AND age = ? ORDER BY id ASC
List<Employee> employeeList = employeeMapper.selectList(new QueryWrapper<Employee>().select("age").eq("email",employee.getEmail()) .eq("age",employee.getAge()).orderBy(true,true,"id")); System.out.println("employeeList:"+employeeList); }
相当于SQL语句SELECT age FROM tbl_employee WHERE email = ? AND age = ? ORDER BY id ASC
删除操作:delete
deleteById() 根据主键删除 deleteBatchIds() 根据主键列表删除
deleteMap() 根据条件删除 根据的是map中的条件
deleteById(): 根据主键删除
@Test
public void deleteBy(){
Integer result = employeeMapper.deleteById(4); //返回的是删除的条数 System.out.println("delete:"+ result);
}
deleteBatchIds() :根据主键列表删除
@Test
public void deleteByIds(){
List<Integer> idlist = new ArrayList<>();
idlist.add(3);
idlist.add(7);
idlist.add(12);
idlist.add(11);
Integer integer = employeeMapper.deleteBatchIds(idlist); //根据list集合进行删除
System.out.println("deletelist:"+integer);
}
deleteByMap() : 根据条件删除
@Test
public void deleteMap(){
Map<String, Object> columnMap = new HashMap<>();
columnMap.put("id",5); //根据id删除
Integer integer = employeeMapper.deleteByMap(columnMap);
System.out.println("deletemap"+integer);
}
@Test
public void deleteMap(){
Map<String,Object> columnMap = new HashMap<>();
columnMap.put("email",null); //删除email 和last_name都是null的信息
columnMap.put("last_name",null);
Integer integer = employeeMapper.deleteByMap(columnMap);
System.out.print("map:"+integer);
}
。
mybatis plus CRUD的更多相关文章
- MyBatis:CRUD功能
在前面已经自动生成了mapper和pojo,接下来我们实现mybatis的CRUD功能,先新建service.controller层的方法. 这里的sid是一个开源的id生成类,写完后,我们还需要在启 ...
- Mybatis的CRUD案例
一.Mybatis增删改查案例 上一节<Mybatis入门和简单Demo>讲了如何Mybatis的由来,工作流程和一个简单的插入案例,本节主要继上一讲完整的展示Mybatis的CRUD操作 ...
- 【MyBatis】MyBatis实现CRUD操作
1.实现基本CRUD功能 使用MyBatis对数据完整的操作,也就是CRUD功能的实现.根据之前的内容,要想实现CRUD,只需要进行映射文件的配置. 范例:修改EmpMapper.xml文件,实现CR ...
- SpringBoot 整合 Mybatis 进行CRUD测试开发
今天来和大家分享下 Spring Boot 整合 MyBatis 的 CRUD 测试方法开发.因为 MyBaits 有两种开发形式,一种基于注解,一种基于 xml . SpringBoot配置文件也有 ...
- 基于mybatis的CRUD
u 基于Mybatis的CRUD u 掌握MyBatis的结果类型-resultMap和resultType u 掌握MyBatis的参数类型 u 掌握#和$两种语法 1 基于myb ...
- 05 Mybatis的CRUD操作和Mybatis连接池
1.CRUD的含义 CRUD是指在做计算处理时的增加(Create).读取(Retrieve)(重新得到数据).更新(Update)和删除(Delete)几个单词的首字母简写.主要被用在描述软件系统中 ...
- 03 Mybatis:05.使用Mybatis完成CRUD
mybatis框架:共四天 明确:我们在实际开发中,都是越简便越好,所以都是采用不写dao实现类的方式.不管使用XML还是注解配置. 第二天:mybatis基本使用 mybatis的单表crud操作 ...
- mybatis(CRUD)
3.mybatis(CRUD) 有了mybatis,我们要对数据库进行增删改查只需要操作接口和mapper.xml文件,然后进行测试就可以了. 实例代码如下: 接口 public interface ...
- MyBatis之CRUD
1 mybatis框架介绍 1.1回顾jdbc操作数据库的过程 1.2 mybatis开发步骤 A.提供一个SqlMapperConfig.xml(src目录下),该文件主要配置数据库连接,事务,二级 ...
- MyBatis Tutorial – CRUD Operations and Mapping Relationships – Part 1---- reference
http://www.javacodegeeks.com/2012/11/mybatis-tutorial-crud-operations-and-mapping-relationships-part ...
随机推荐
- 神他么奇怪NoClassDefFoundError
javaweb 项目,部署在Tomcat服务器 十分奇葩的问题 之前一直好好的,今天突然就给报错.代码没动过.真是奇葩.创建User对象报NoClassDefFoundError, User类是一个普 ...
- 记C函数指针的“小坑”
今天遇到一个C函数指针的小坑,索性记下来. 我在a.c 文件里面,引用b.c 文件的函数声明作为指针引用 比如在a.c生命一个函数指针 typedef void (*free)(void *val) ...
- excel cannot access the file there are several possible reasons
original link Microsoft Office Excel cannot access the file ‘c:\file.xlsx’. There are several possib ...
- [JSOI2016]无界单词
题目 题意:求\(\rm border\)长度为\(0\)的\(n\)位\(0,1\)字符串个数,并求字典序第\(k\)小的那一个. 首先是计数,正向不是很好算,考虑正难则反:设\(f_i\)表示长度 ...
- VIM编辑器使用及插件配置
1.VIM的三种模式: 普通模式.插入模式.命令行模式2.三种模式的转换: 2.1进入普通模式 ①打开VIM默认为普通模式 ②处于插入模式/命令行模式时,按ESC进入普通模式 2.2进入插入模式: A ...
- 想实现网页滚动一定距离底部弹出div
<script type="text/javascript"> $(window).scroll(function () { if ($(this).scrollTop ...
- (playbook)ubuntu下ansible安装docker
--- - hosts: test sudo: yes vars: apt_packages_ca: - apt-transport-https - ca-certificates tasks: - ...
- [几何]计算不规则多边形的面积、中心、重心(Android,转)
转自:[几何]计算不规则多边形的面积.中心.重心 最近项目用到:在不规则多边形的中心点加一个图标.(e.g: xx地区发生暴雪,暴雪区域是多边形,给多边形中心加一个暴雪的图标) 之前的设计是,计算不规 ...
- curl分析请求的各个部分耗时情况
curl 命令提供了 -w 参数,解释如下 -w, --write-out Make curl display information on stdout after a completed tran ...
- c++后台开发面试常见知识点总结(三)操作系统
静态链接库和动态链接库的区别 一个进程可以通过调用waitpid函数来等待它的子进程终止或者停止 Debug和Release的区别 临界区互斥量信号量事件进程互斥与同步 进程有哪几种状态,状态转换图, ...