标签:eem 操作 lam sys name lis false 插入 ase
MyBatis-Plus(简称 MP)是一个 MyBatis 的增强工具,在 MyBatis 的基础上只做增强不做改变,为简化开发、提高效率而生
安装:Maven+jdk8+spring4.0
1.引入maven依赖
<!-- mp依赖
mybatisPlus 会自动的维护Mybatis 以及MyBatis-spring相关的依赖
-->
<dependency>
<groupId>com.baomidou</groupId>
<artifactId>mybatis-plus</artifactId>
<version>3.0.3</version>
</dependency>
2.配置dataSource,实现继承BaseMapper,配置mapper文件包位置,然后就可使用内置的CRUD了
applicationContext.xml
在数据源等配置基础上添加如下配置
<!--
配置mybatis 扫描mapper接口的路径 mapper为EmployeeMapper所在包的位置
-->
<bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
<property name="basePackage" value="mapper"></property>
</bean>
3.
//Beans
@TableName("tbl_employee")//设置对象名和表明对应 public class Employee { //value指定与数据库列名一致,type指定主键策略为自增,即不用手动插入id @TableId(value = "id",type =IdType.AUTO) private Integer id ; @TableField("last_name")//设置驼峰命名和数据库命令对应,也可以在配置文件中进行全局配置。
//有说法称:my已经默认开启了这一对应关系,但是我的没有生效,所以又手动配置了 private String lastName; private String email ; private Integer gender; private Integer age ; //数据库中不存在的列,但存在类中,注解后不会注入到sql @TableField(exist = false) private Double salary ;
setter(){}
getter(){}
}
//Mapper
public interface EmployeeMapper extends BaseMapper<Employee> {
//不需要实现,这时候就可以调用baseMapper的增删改了
}
//Controller
//加载配置文件
private ApplicationContext ioc =new ClassPathXmlApplicationContext("applicationContext.xml");
private EmployeeMapper employeeMapper=
ioc.getBean("employeeMapper", EmployeeMapper.class);
@Test
public void testCommonInsert() {
//初始化Employee对象
Employee employee = new Employee();
employee.setLastName("MP");
employee.setEmail("mp@tom.com");
employee.setGender(1);
employee.setAge(18);
Integer result = employeeMapper.insert(employee);
System.out.println("result: " + result );
//获取当前数据在数据库中的主键值
Integer key = employee.getId();
System.out.println("key:" + key );
}
到此已经实现了通用CRUD的操作。
4.附一下BaseMapper的包含的方法
package com.baomidou.mybatisplus.core.mapper; import com.baomidou.mybatisplus.core.conditions.Wrapper; import com.baomidou.mybatisplus.core.metadata.IPage; import java.io.Serializable; import java.util.Collection; import java.util.List; import java.util.Map; import org.apache.ibatis.annotations.Param; public interface BaseMapper<T> { int insert(T var1); int deleteById(Serializable var1); int deleteByMap(@Param("cm") Map<String, Object> var1); int delete(@Param("ew") Wrapper<T> var1); int deleteBatchIds(@Param("coll") Collection<? extends Serializable> var1); int updateById(@Param("et") T var1); int update(@Param("et") T var1, @Param("ew") Wrapper<T> var2); T selectById(Serializable var1); List<T> selectBatchIds(@Param("coll") Collection<? extends Serializable> var1); List<T> selectByMap(@Param("cm") Map<String, Object> var1); T selectOne(@Param("ew") Wrapper<T> var1); Integer selectCount(@Param("ew") Wrapper<T> var1); List<T> selectList(@Param("ew") Wrapper<T> var1); List<Map<String, Object>> selectMaps(@Param("ew") Wrapper<T> var1); List<Object> selectObjs(@Param("ew") Wrapper<T> var1); IPage<T> selectPage(IPage<T> var1, @Param("ew") Wrapper<T> var2); IPage<Map<String, Object>> selectMapsPage(IPage<T> var1, @Param("ew") Wrapper<T> var2); }
标签:eem 操作 lam sys name lis false 插入 ase
原文地址:https://www.cnblogs.com/jin-nuo/p/9734599.html