一.ORM框架中的常见需求
ORM框架使用中的常见需求
- 后管系统做查询的时候,多个条件通过一个接口进行查询,带了哪个字段就加一段sql过滤,通过mybatis如何实现?
通过mybatis的dynamic sql是可以实现的,类似getEmpsByCondition,携带了哪个字段,查询条件就带上这个字段的值
似乎只能通过写mapper xml来做逻辑判断
spring data jpa是通过多个Predicate构造Specification创建where条件的,都是通过代码来控制逻辑的
2自动设置创建时间/更新时间
mybatis 也是使用metaObjectHandler来做?
还是通过拦截器来做?
还是只创建这两个字段,通过数据库语句来控制?
spring data jpa中有entityListener,可以不操作数据库,来实现此功能
3.字段自动加解密?
不知道如何实现自动
在mybatis中,查询出来之后做混淆处理
在spring data jpa中,使用entityManager查询出来之后做混淆处理 - 乐观锁功能
mybatis-plus提供了optimistic-lock plugin
spring data jpa也提供了@version注解来做 - 逻辑删除
mybatis-plus逻辑删除是放在DefaultSqlInjector中的
spring data jpa要自己写sql来实现逻辑删除