使用CrudRepository从View获取数据

时间:2019-02-12 14:24:17

标签: java rest spring-boot spring-mvc spring-data-jpa

对于这个问题,我不是在寻找解决方案,而是在寻找一个可以使自己前进的方向,因此不会共享任何代码。

我正在准备一个REST API,并且在本地设置了postgresql数据库,该数据库具有2个表和这2个表中的一个视图。

通常,当我想从数据库中获取任何数据时,我会使用以下代码(为清楚起见):

DataRepository类:

"compilerOptions": {
  "noEmit": false
}

DataService类:

"exclude": [
  "node_modules"
]

DataController类:

public interface DataRepository extends CrudRepository<Data, String>{}

数据类:

@Service
public class DataService {
    @Autowired
    private DataRepository repo;
    public Data getData(String id){
        return repo.findById(id).orElse(null);
    }
}

现在,我想从视图中检索数据,那么应该采取什么方法?

我们应该使用相同的方法来创建Model,Service,Ctonroller和Repository类吗?

我们可以使用CrudRepository实现相同的功能吗?

我搜索了很多地方,但没有发现有用的东西。

让我知道是否有人对此有任何了解。

1 个答案:

答案 0 :(得分:2)

CrudRepository的读取方法在视图中应该可以正常工作。对于书写方法,视图需要可更新enter link description here

如果您只想读取而不是写入存储库,则可以通过复制ReadOnlyRepository的源代码并删除所有写入方法来创建CrudRepository

请注意,JPA仍将尝试保留对托管实体所做的更改。 为了避免这种情况并避免进行脏检查,如果您使用的是Hibernate,可以mark your entities as immutable