首先我们的项目建立之后我们要建立一个实体类来对应我们的数据裤中的信息
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("插入失败"); } }