我正在制作我的第一个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检索正确信息的迹象。班级如何知道要查询什么?
答案 0 :(得分:0)
您需要在要在UserRepository类中编写的查询函数之上添加@Query批注。 例如
<div><h3>Product1</h3></div>
<div><h3>Product2</h3></div>
或者在UserServiceImpl中,userRepo.findAll()应该可以工作。您不需要循环遍历每个用户并将其返回到列表。您应该只返回userRepo.findAll()。
以下url可以让您更多地了解如何编写自己的查询。