java - Spring Data JPA 分页 - 从方法名称创建查询

标签 java spring jpa pagination spring-data-jpa

我在 User 和 PhoneNumber 之间有 OneToMany 关系。因此,一个用户可以拥有多个电话号码。

在前端,我必须仅提取登录用户的电话号码,或者如果用户是管理员,我必须显示所有用户的电话号码。我已经成功实现了这一部分,但我遇到的问题如下:在前端中,用户还有一个按“电话号码”的搜索框。因此,如果用户或管理员搜索 987(假设前 3 位数字),则应显示任何包含“987”并与其个人资料关联的电话号码。如果用户是管理员,我应该显示包含“987”的所有用户的所有号码。

出于分页目的,我使用 Spring 分页和排序存储库。到目前为止,我已经尝试过像这样的 SQL LIKE 通配符。

    public interface UserRepository extends JpaRepository<User, Integer> {
            //this is used for fetching phone numbers by userName, if user is admin I call findAll()
            Page<User> findByUserName(String userName, Pageable pageable);

            //this is used for fetching phone numbers by username by phoneNo LIKE
            Page<User> findByUserNameAndPhoneNumbersPhoneNoLike(String userName,String phoneNo, Pageable pageable);
    }

问题是 LIKE 似乎不起作用。无论如何,它都会返回与用户关联的所有电话号码,并且会忽略我传入的任何内容,因此“%987%”。因此,如果我有 2 个与用户 X 关联的电话号码(987123 和 321432),它将返回这两个电话号码,而不是仅返回“987123”。

有谁知道我如何查询这个但作为返回获取 Spring 可分页对象吗?我认为从方法名称创建查询不够强大,无法满足目的,但我仍然需要可分页对象,因为前端的所有其余实现、服务层都基于此。工作中有人建议我应该使用 JPA 标准,但我不知道如何做到这一点,因此作为返回我可以获得可分页对象

用户类别

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

        @Id @GeneratedValue(strategy=GenerationType.IDENTITY)
        private Integer id;

        @NotEmpty
        @Column(name="USER_ID", unique=true, nullable=false)
        private String userName;

        @OneToMany(fetch = FetchType.EAGER)
        @JoinColumn(name="USER_ID")
        private Set<PhoneNumer> phoneNumbers;

        @NotEmpty
        @JsonIgnore
        @ManyToMany(fetch = FetchType.LAZY)
        @JoinTable(name = "USER_USER_PROFILE",
                joinColumns = { @JoinColumn(name = "USER_ID") },
                inverseJoinColumns = { @JoinColumn(name = "USER_PROFILE_ID") })
        private Set<UserProfile> userProfiles = new HashSet<UserProfile>();
        //Getters and Setters

电话号码类

@Entity
@Table(name = "PHONE_NUMBER")
public class PhoneNumber {

    @Id
    @GeneratedValue(strategy = GenerationType.IDENTITY)
    @Column(name = "ID")
    private long id;

    @Column(name = "PHONE_NUMBER")
    private String phoneNo;
    //Getters and Setters

最佳答案

尝试包含关键字:

Containing
findByFirstnameContaining
… where x.firstname like ?1 (parameter bound wrapped in %)

Page<User> findByUserNameAndPhoneNumbersPhoneNoContaining(String userName,String phoneNo, Pageable pageable);

文档:https://docs.spring.io/spring-data/jpa/docs/current/reference/html/#repository-query-keywords

关于java - Spring Data JPA 分页 - 从方法名称创建查询,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/46121881/

相关文章:

javac : invalid target release: 13

java - JPanel 由于 componentResize 和长重绘命令而黑屏

java - 如何在启动 spring 时选择性地加载 bean

java - Hibernate 不承认持久的 getter/setter 属性

java - Spring @Transactional 方法不回滚

Java 9 整数到字符串转换

java - 写入字节数组时出现 IOException

java - JSON转换和应用程序兼容性问题

带有 CRUD 存储库的 MySql ANY_VALUE() 方法

java - 配置Hibernate和Spring的数据库开发环境