我可以在Spring Boot网络应用中编写自己的查询吗?

时间:2019-04-10 13:14:11

标签: postgresql hibernate spring-boot spring-data-jpa

我正在制作我的第一个springboot Web应用程序,并试图显示来自postgresql服务器的一些信息。当尝试从数据库中获取一些信息时,它将返回一个空列表。据我在控制台中看到的那样,它尝试使用错误的参数进行查询。

在我的数据库中,我有一个包含三个字段的表:“ userId”,“ firstName”和“ surName”。 据我了解,Hibernate尝试使用参数“ users0_.user_id”,“ users0_user_id”,“ users0_.sur_name”进行查询。

要解决此问题,我想编写自己的查询或解决当前查询。我该怎么做?

如您所见,我已经使用一些System.Out.print语句检查了查询结果。

第一个返回list.size()为0, 而第二个返回的值为null。

Console displaying what I think is the query info

这是UserController类中用于显示用户信息的函数。

    @RequestMapping("/users")
    public String getUsers(Model model) {
        List <users>users = (List<users>) userServ.listAll();
        System.out.print("THE SIZE WITH STRING CONCATINATION IS: " + users.size());
        model.addAttribute("users", users);
        System.out.print("THE NAME OF USER WITH INDEX =2 IS: " + userServ.getById(2).getFirstName());

        return "showUsers";
    }

用户的实体/域类:

@Entity
@Table(name="users")
public class users implements Serializable{


    @Id
     @GeneratedValue(strategy = GenerationType.AUTO)
    private long userId;
    private String firstName;
    private String surName;

    private long getId() { return userId; }
    public void setId(long id) {this.userId = id;}
    public String getFirstName() { return firstName; }
    public String getSurName() { return surName; }
    public void setSurname(String surName) {this.surName = surName; }


}

这是用于从数据库检索用户的存储库的接口:

import org.springframework.data.jpa.repository.config.EnableJpaRepositories;
import org.springframework.data.repository.CrudRepository;

import com.svein.models.users;

public interface UserRepository extends CrudRepository<users, Long> {

}

这是用户的服务类别:



@Service
public class UserServiceImp implements userService{

    @Autowired
    private UserRepository userRepo;

    @Override
    public List<users> listAll() {
        List<users> users = new ArrayList<>();
        userRepo.findAll().forEach(users::add);
        return users;
    }

    @Override
    public users getById(long id) {
        return userRepo.findById(id).orElseGet(users::new);
    }

    @Override
    public users saveOrUpdate(users user) {
        userRepo.save(user);
        return null;
    }

    @Override
    public void delete(Long id) {
        userRepo.deleteById(id);

    }


}

我希望调整或替换当前查询,但是代码可能还有其他问题。就像我说的那样,我还很陌生,但是我以为我没有写过一行SQL是很奇怪的,并且在另一个项目中THAT显示出从不同的DB检索正确信息的迹象。班级如何知道要查询什么?

1 个答案:

答案 0 :(得分:0)

您需要在要在UserRepository类中编写的查询函数之上添加@Query批注。 例如

<div><h3>Product1</h3></div>
<div><h3>Product2</h3></div>

或者在UserServiceImpl中,userRepo.findAll()应该可以工作。您不需要循环遍历每个用户并将其返回到列表。您应该只返回userRepo.findAll()。

以下url可以让您更多地了解如何编写自己的查询。

  

https://www.baeldung.com/spring-data-jpa-query