我有一个审计日志实体,在这个实体中,我有一个映射到另一个拥有字段审计类型的实体。我想使用JPA存储库实现后端过滤。我想通过REST GET方法返回包含传递给query param的AuditActionType的所有AuditLog<代码>审核操作类型是:登录
、注销
、创建用户
、更新用户
、删除用户
例子:
http://localhost:8086/audit/action?action=lo
应返回其审核操作包含“lo”的所有审核日志。因此,它将返回所有带有LOG\U IN和LOG\U OUT动作的审核日志。
在我的JPA存储库中,我创建了以下内容:
列出FindByaAction_actionIgnoreCaseContaining(AuditActionType动作);
但当我运行这个时,它会给我编译错误:
SED by:java.lang.IllegalStateException:无法忽略com.cgi.edu.bootcamp.scoringserver.model.enums.AuditActionType类型的情况,属性'action'必须引用字符串。
拜托谁能帮帮忙?
审计日志:
package com.cgi.edu.bootcamp.scoringserver.model;
import java.time.LocalDateTime;
import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.EnumType;
import javax.persistence.Enumerated;
import javax.persistence.GeneratedValue;
import javax.persistence.GenerationType;
import javax.persistence.Id;
import javax.persistence.JoinColumn;
import javax.persistence.ManyToOne;
import javax.persistence.SequenceGenerator;
import javax.persistence.Table;
@Entity
@Table(name = "AUDIT_LOG")
public class AuditLog {
@Id
@SequenceGenerator(name = "SEQ_audit", sequenceName = "SEQ_audit", allocationSize = 1)
@GeneratedValue(strategy = GenerationType.SEQUENCE, generator = "SEQ_audit")
@Column(name = "AL_ID", nullable = false)
private Long id;
@ManyToOne
@JoinColumn(referencedColumnName="U_ID", name="AL_U_ID")
private User user;
@ManyToOne
@JoinColumn(referencedColumnName="AA_ID", name="AL_ACTION")
private AuditAction action;
@Column(name = "AL_DESCRIPTION", length = 255)
private String description;
@Column(name = "AL_DATE")
private LocalDateTime date;
public Long getId() {
return id;
}
public void setId(Long id) {
this.id = id;
}
public User getUser() {
return user;
}
public void setUser(User user) {
this.user = user;
}
public AuditAction getAction() {
return action;
}
public void setAction(AuditAction action) {
this.action = action;
}
public String getDescription() {
return description;
}
public void setDescription(String description) {
this.description = description;
}
public LocalDateTime getDate() {
return date;
}
public void setDate(LocalDateTime date) {
this.date = date;
}
}
审核操作:
package com.cgi.edu.bootcamp.scoringserver.model;
import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.EnumType;
import javax.persistence.Enumerated;
import javax.persistence.GeneratedValue;
import javax.persistence.GenerationType;
import javax.persistence.Id;
import javax.persistence.SequenceGenerator;
import javax.persistence.Table;
import javax.validation.constraints.NotNull;
import com.cgi.edu.bootcamp.scoringserver.model.enums.AuditActionType;
@Entity
@Table(name = "AUDIT_ACTION")
public class AuditAction {
@Id
@SequenceGenerator(name = "SEQ_action", sequenceName = "SEQ_action", allocationSize = 1)
@GeneratedValue(strategy = GenerationType.SEQUENCE, generator = "SEQ_action")
@Column(name = "AA_ID", nullable = false)
private Long id;
@Enumerated(EnumType.STRING)
@NotNull(message = "Audit action can not be empty!")
@Column(name = "AA_NAME", nullable = false, unique = true)
private AuditActionType action;
public Long getId() {
return id;
}
public void setId(Long id) {
this.id = id;
}
public AuditActionType getAction() {
return action;
}
public void setAction(AuditActionType action) {
this.action = action;
}
}
AuditLogRepository:
package com.cgi.edu.bootcamp.scoringserver.dao;
import java.time.LocalDateTime;
import java.util.List;
import org.springframework.data.jpa.repository.JpaRepository;
import org.springframework.data.jpa.repository.Modifying;
import org.springframework.data.jpa.repository.Query;
import org.springframework.data.repository.query.Param;
import org.springframework.stereotype.Repository;
import com.cgi.edu.bootcamp.scoringserver.model.AuditLog;
import com.cgi.edu.bootcamp.scoringserver.model.User;
import com.cgi.edu.bootcamp.scoringserver.model.enums.AuditActionType;
@Repository
public interface AuditLogRepository extends JpaRepository<AuditLog, Long>{
List<AuditLog> findByAction_actionIgnoreCaseContaining(AuditActionType action);
}
AuditLogServiceImpl:
package com.cgi.edu.bootcamp.scoringserver.service;
import java.time.LocalDateTime;
import java.util.List;
import java.util.Optional;
import javax.transaction.Transactional;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import com.cgi.edu.bootcamp.scoringserver.dao.AuditLogRepository;
import com.cgi.edu.bootcamp.scoringserver.exception.ResourceNotFoundException;
import com.cgi.edu.bootcamp.scoringserver.model.AuditLog;
import com.cgi.edu.bootcamp.scoringserver.model.UserGroup;
import com.cgi.edu.bootcamp.scoringserver.model.enums.AuditActionType;
@Service
@Transactional
public class AuditLogServiceImpl implements AuditLogService {
@Autowired
private AuditLogRepository auditRepository;
@Override
public List<AuditLog> findByAction(AuditActionType action) {
return auditRepository.findByAction_actionIgnoreCaseContaining(action);
}
}
AuditLogRestController:
package com.cgi.edu.bootcamp.scoringserver.web;
import java.time.LocalDateTime;
import java.util.List;
import javax.validation.Valid;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.http.ResponseEntity;
import org.springframework.web.bind.annotation.DeleteMapping;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.PutMapping;
import org.springframework.web.bind.annotation.RequestBody;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.RestController;
import com.cgi.edu.bootcamp.scoringserver.model.AuditLog;
import com.cgi.edu.bootcamp.scoringserver.model.User;
import com.cgi.edu.bootcamp.scoringserver.model.enums.AuditActionType;
import com.cgi.edu.bootcamp.scoringserver.service.AuditLogService;
@RestController
@RequestMapping("/audit")
public class AuditLogRestController {
@Autowired
private AuditLogService auditLogService;
@GetMapping("/action")
public ResponseEntity<List<AuditLog>> getLogsByAction(@RequestParam("action") AuditActionType action){
return ResponseEntity.ok(auditLogService.findByAction(action));
}
}
将您的存储库方法更改为:
@Repository
public interface AuditLogRepository extends JpaRepository<AuditLog, Long>{
List<AuditLog> findByAction(AuditActionType action);
}
如果映射到控制器方法中的枚举值将成功,则无需更改存储库中的大小写大小。
好吧,如果您考虑一下,控制器如何将诸如“lo”之类的字符串转换为枚举?所以您需要从将参数转换为字符串开始。
@GetMapping("/action")
public ResponseEntity<List<AuditLog>> getLogsByAction(@RequestParam("action") String action){
return ResponseEntity.ok(auditLogService.findByAction(action));
}
然后相应地更改服务和存储库方法。
@Repository
public interface AuditLogRepository extends JpaRepository<AuditLog, Long>{
@Query("select a from AuditLog a where a.action like CONCAT('%', :action, '%')")
List<AuditLog> findByAction(String action);
}
是否有一种方法可以使用来完成这一任务,而不需要为每个Patamenter组合创建大量/语句?
如何在枚举的帮助下筛选我的“StorageManager”在其名为“items”的LinkedList中的项目?受此筛选器影响的项目需要复制到新的LinkedList中。我用buyNewItem()将项目添加到存储管理器列表中,但第二项任务需要帮助。 如果我忘记添加一些重要信息,请让我知道。 编辑:仅允许重新导入的是 导入java.util.数组; 导入java.util.LinkedList;
我一直有这样一个问题,即我无法使用querydsl对一个具有可为空外键的表进行正确的筛选。我把我的用例简化成一个非常简单的场景。 假设我们有两个实体,MyEntity和TimeRangeEntity。我的实体只有一个ID和一个TimeRangeEntity的外键。TimeRangeEntity只有开始时间、结束时间和ID。它们都从BaseEntity扩展,它只有带有@ID注释的ID。 我还编写了一
问题内容: 我有许多需要保留到数据库的简单对象类型。我正在使用Spring JPA来管理这种持久性。对于每种对象类型,我需要构建以下内容: 在我看来,有可能用三个基于泛型的类替换每种对象类型的多个类,从而节省了大量的样板代码。我不确定该怎么做,实际上,如果这是个好主意? 问题答案: 首先,我知道我们在这里提高了一些标准,但这已经比没有Spring Data JPA的帮助而编写的代码少得多。 其次,
我们正在使用Spring boot+Spring data JPA和Hibernate开发一个多租户web应用程序。 多租户是通过拥有一个组织表来实现的,该表作为外键连接到几乎每个表上。这意味着每个DB调用(Spring Data repository查询方法)都必须用组织ID进行检查。 谢谢你抽出时间。
问题内容: 我已经查看了与该问题相关的Stack Overflow上的其他问题,但是似乎没有一个问题能清楚地回答这个问题。 我们有一个名为sp_who2的系统存储过程,该过程为服务器上所有正在运行的进程返回信息的结果集。我想过滤存储过程返回的数据;从概念上讲,我可能会这样做: 但是,该方法不起作用。有什么好的做法可以实现查询存储过程的返回数据的目标,最好无需查看原始存储过程的代码并对其进行修改。