假设数据库表中有一个字段is_deleted类型为tinyint,0表示未删除,1表示已删除。java
实体类对应代码以下:spring
public class User { @LogicDelete private Byte isDeleted; }
在执行dao.del(user);时会触发UPDATE语句,将is_deleted字段更新为1。sql
若是is_deleted类型为char(1),f表示未删除,t表示已删除。数据库
@LogicDelete(notDeleteValue = "f", deleteValue = "t") private String isDeleted;
@LogicDelete提供两个属性springboot
假设1表示未删除,2表示已删除,@LogicDelete的设置方法以下:@LogicDelete(notDeleteValue = “1”, deleteValue = “2”)。若是每一个实体类都要这样设置的话会很麻烦,easymybatis提供了全局配置mybatis
# 未删除数据库保存的值,默认为0 mybatis.logic-not-delete-value=1 # 删除后数据库保存的值,默认为1 mybatis.logic-delete-value=2
<!-- 替换org.mybatis.spring.SqlSessionFactoryBean --> <bean id="sqlSessionFactory" class="net.oschina.durcframework.easymybatis.ext.SqlSessionFactoryBeanExt"> <property name="dataSource" ref="dataSource" /> <property name="configLocation"> <value>classpath:mybatis/mybatisConfig.xml</value> </property> <property name="mapperLocations"> <list> <value>classpath:mybatis/mapper/*.xml</value> </list> </property> <!-- 如下是附加属性 --> <!-- dao所在的包名,跟MapperScannerConfigurer的basePackage一致 多个用;隔开 --> <property name="basePackage" value="com.myapp.dao" /> <property name="config"> <bean class="net.oschina.durcframework.easymybatis.EasymybatisConfig"> <property name="logicNotDeleteValue" value="1"/> <property name="logicDeleteValue" value="2"/> </bean> </property> </bean>