Spring Boot-自定义查询上的空指针

时间:2018-11-17 12:06:12

标签: java mongodb spring-boot

我正在做一个自定义查询,以检查给定的数据是否存在于mongodb数据库中。下面是我完成的代码。

 package com.royangular.royAngularProject.repositories;


import java.util.List;

import org.springframework.data.mongodb.repository.MongoRepository;
import org.springframework.data.mongodb.repository.Query;
import org.springframework.stereotype.Repository;

import com.royangular.royAngularProject.models.ContactUs;



@Repository
public interface ContactUsRepository extends MongoRepository<ContactUs, String> {

    @Query("{'name' : ?0}")//, contactEmail : ?0, phoneNumber : ?0}")
    public List<ContactUs> findBynameAndcontactEmailAndphoneNumber(String name);//, String contactEmail, String phoneNumber);

}

调用回购协议的类:

package com.royangular.royAngularProject.controllersContact;

import java.util.ArrayList;
import java.util.List;

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.data.mongodb.core.MongoTemplate;
import org.springframework.data.mongodb.core.query.Criteria;
import org.springframework.data.mongodb.core.query.Query;
import org.springframework.http.ResponseEntity;

import com.royangular.royAngularProject.models.ContactUs;
import com.royangular.royAngularProject.repositories.ContactUsRepository;

public class QueryDBCheck {

     @Autowired
     ContactUsRepository contactUsRepository;

     @Autowired
     MongoTemplate mongoTemplate ;

    public boolean queryDB (ContactUs contactus)
    {
        List<ContactUs> colleagues = new ArrayList<ContactUs>(); 

        if (contactUsRepository.findBynameAndcontactEmailAndphoneNumber(contactus.getName())==null)
        {
            return true;
        }
        else
        {
            colleagues = contactUsRepository.findBynameAndcontactEmailAndphoneNumber("dasdsad");//, contactus.getContactEmail(), contactus.getPhoneNumber());

        }


        if (colleagues.size()==0)
        {
            return true;
        }

        return false;

    }
}

我在contactUsRepository.findBynameAndcontactEmailAndphoneNumber(contactus.getName())处得到了一个空指针。请问我是什么问题以及如何解决这个问题。它阻止代码继续。抱歉,我是春季启动的mongodb新手。您还可以包括为什么要做什么以及如何做,以便社区中的每个人都可以学习。

1 个答案:

答案 0 :(得分:0)

  1. 从您的方法中删除Query注释。在这种特殊情况下,您不需要它。
  2. 在命名JPA查询时,请
  3. 使用 camelCase 表示法。 (请注意,方法名称中参数名称的首字母应大写)。

    @Repository
    public interface ContactUsRepository extends MongoRepository<ContactUs, String> {
    
        public List<ContactUs> findByNameAndContactEmailAndPhoneNumber(String name, String contactEmail, String phoneNumber);
    
    }