如何使用“ findBy”方法?

时间:2018-07-03 16:39:14

标签: java spring spring-data-jpa

我对编程还很陌生,所以请留意:)

我必须在Spring上从事一个项目,目前在如何使用findBy方法方面有些挣扎。

我想创建一个文件夹系统,在其中可以通过设置class Room < ApplicationRecord ROOM_TYPES = %w(Single Double Triple).freeze after_initialize :set_room_defaults def set_room_defaults set room_type = ROOM_TYPES[people_in_room.size - 1] end end

查看其他用户共享的每个文件夹

我接下来要做的是编辑“文件夹”的服务类,我想写这样的东西:

private boolean shared = true;

如何准确获取布尔值“ shared”设置为true的文件夹?

3 个答案:

答案 0 :(得分:2)

您可以添加此方法:

 List<Folder> findBySharedTrue();

在您的FolderRepository班上:

public interface FolderRepository extends CrudRepository<Folder, Integer> {
     List<Folder> findBySharedTrue();
}

它将使用实体shared中的字段Folder,仅返回shared字段等于true的文件夹。

答案 1 :(得分:0)

使用JPARepository代替CRUDRepository

实体

@Entity
public class Folder {
    @Id
    @GeneratedValue
    private Integer FolderID;
    @Column(unique = true)
    private String Foldername;
    private boolean geteilt = false;

    public Integer getFolderID() {
        return FolderID;
    }

    public void setFolderID(Integer folderID) {
        FolderID = folderID;
    }

    public String getFoldername() {
        return Foldername;
    }

    public void setFoldername(String foldername) {
        Foldername = foldername;
    }



    public boolean isGeteilt() {
        return geteilt;
    }

    public void setGeteilt(boolean geteilt) {
        this.geteilt = geteilt;
    }

}

存储库

public interface FolderRepository extends JpaRepository<Folder, Integer>{

    List<Folder> findByGeteilt(boolean shared);

}

测试

@RunWith(SpringRunner.class)
@DataJpaTest
public class FolderTest{

    @Autowired
    private TestEntityManager entityManager;

    @Autowired
    private FolderRepository folderrepo;


    @Test
    public void whenFindByshared() {

        // given

        Folder folder = new Folder();
        folder.setFolderID(1);
        folder.setFoldername("folder1");
        folder.setGeteilt(true);

        Folder folder1 = new Folder();
        folder1.setFolderID(2);
        folder1.setFoldername("folder2");
        folder1.setGeteilt(true);

        Folder folder2 = new Folder();
        folder2.setFolderID(1);
        folder2.setFoldername("folder3");
        folder2.setGeteilt(false);

        folderrepo.saveAndFlush(folder);
        folderrepo.saveAndFlush(folder1);
        folderrepo.saveAndFlush(folder2);

        // when

        List<Folder> sharedFolders =new ArrayList<>();
        sharedFolders = folderrepo.findByGeteilt(true);

        assertThat(sharedFolders.get(0).getFoldername())
          .isEqualTo(folder1.getFoldername());


    }

}

Resultat

test success

答案 2 :(得分:0)

根据我对“ findBy”方法的了解,如果您将布尔值设置为搜索条件,则该功能将可以工作(请参阅此网站的文档:https://seleniumhq.github.io/selenium/docs/api/java/org/openqa/selenium/support/FindBy.html)。

但是,您可以创建一个属性,该属性是布尔值的String变体(例如,为true / false保留字符串值)。在该实例中,findBy方法应该可以正常工作。

如果您不希望添加额外的组件,则可以尝试继承该类,然后重写该方法(创建超类),该方法还将检查布尔组件(可能会扩展功能?)。但是,我不确定您将如何实现它,这更是一个抽象的想法,而不是一个真正的建议