![](/img/trans.png)
[英]Null pointer exception in CriteriaQuery using spring boot and spring data JPA
[英]Spring Data JPA Null pointer Exception
在此處輸入圖像描述我是 Spring Boot Data JPA 存儲庫的新手。 這是我使用 JPA 的第一個應用程序。 我正在嘗試從數據庫獲取數據。 但是哪個返回NULL。
實體文件
import javax.persistence.*;
@Entity
@Table(name = "TASK_DETAILS")
public class TaskDetails {
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
@Column(name = "TASK_DETAILS_ID")
private long taskDetailsId;
@Column(name = "TASK_NAME")
private String TaskName;
@Column(name = "TASK_POLLING_TIME")
private int TaskTime;
@Column(name = "TASK_FILE")
private String TaskClassFile;
@Column(name = "TASK_STATUS")
private String TaskStatus;
public long getTaskDetailsId() {
return taskDetailsId;
}
public void setTaskDetailsId(long taskDetailsId) {
this.taskDetailsId = taskDetailsId;
}
public String getTaskName() {
return TaskName;
}
public void setTaskName(String taskName) {
TaskName = taskName;
}
public int getTaskTime() {
return TaskTime;
}
public void setTaskTime(int taskTime) {
TaskTime = taskTime;
}
public String getTaskClassFile() {
return TaskClassFile;
}
public void setTaskClassFile(String taskClassFile) {
TaskClassFile = taskClassFile;
}
public String getTaskStatus() {
return TaskStatus;
}
public void setTaskStatus(String taskStatus) {
TaskStatus = taskStatus;
}
}
存儲庫文件
import java.util.Collection;
import java.util.List;
import java.util.Optional;
@Repository
public interface TaskDetailsRepository extends JpaRepository<TaskDetails, String> {
TaskDetails findByTaskDetailsId(final long id);
}
我的主要方法
@Service
public class ImportAmazonData {
@Autowired
private TaskDetailsRepository taskDetailsRepositoryDAO;
public void getProductsFromAmazonStore(JobExecutionContext context) throws ClassNotFoundException {
final long taskID = (long) context.getJobDetail().getJobDataMap().get("taskId");
TaskDetails taskDetails = taskDetailsRepositoryDAO.findByTaskDetailsId(taskID);
System.out.println("Result : " + taskDetails.getTaskClassFile());
}
}
產品同步文件
import com.example.Schedular.AmazonSync.ImportAmazonData;
import org.quartz.Job;
import org.quartz.JobExecutionContext;
import org.quartz.JobExecutionException;
import org.springframework.stereotype.Component;
public class ProductSync implements Job {
@Autowired
private ImportAmazonData importAmazonData;
@Override
public void execute(JobExecutionContext context) throws JobExecutionException {
try {
importAmazonData.getProductsFromAmazonStore(context);
} catch (ClassNotFoundException e) {
e.printStackTrace();
}
}
}
在這里,我試圖通過 id 獲取 TaskDetails。 但是我的 taskDetailsRepositoryDAO 為空。 在這里我附上了我的錯誤日志。 請告訴我。 提前致謝。
錯誤日志
java.lang.NullPointerException: null
at com.example.Schedular.AmazonSync.ImportAmazonData.getProductsFromAmazonStore(ImportAmazonData.java:20) ~[classes/:na]
at com.example.Schedular.SyncData.ProductSync.execute(ProductSync.java:16) ~[classes/:na]
at org.quartz.core.JobRunShell.run(JobRunShell.java:202) ~[quartz-2.3.2.jar:na]
at org.quartz.simpl.SimpleThreadPool$WorkerThread.run(SimpleThreadPool.java:573) [quartz-2.3.2.jar:na]
在您的存儲庫文件中,即 TaskDetailsRepository 應如下所示:
import java.util.Collection;
import java.util.List;
import java.util.Optional;
@Repository
public interface TaskDetailsRepository extends JpaRepository<TaskDetails, Long> {
Optional<TaskDetails> findByTaskDetailsId(Long id);
}
在域類中使用包裝器而不是基元。
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
@Column(name = "TASK_DETAILS_ID")
private Long taskDetailsId;
如果您試圖根據特定值查找記錄,則指定該類型,即Long 。 如果您的方法要從數據庫返回單曲記錄,請始終使用 Optional。 這將幫助您解析 NullPointers。
這可能對你有幫助。
嘗試在你的 spring boot 主文件中添加這個(我認為它是 SchedularApplication)@EnableJpaRepositories("your jpa repository package name")
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.