对于这个问题,我不是在寻找解决方案,而是在寻找一个可以使自己前进的方向,因此不会共享任何代码。
我正在准备一个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实现相同的功能吗?
我搜索了很多地方,但没有发现有用的东西。
让我知道是否有人对此有任何了解。
答案 0 :(得分:2)
CrudRepository
的读取方法在视图中应该可以正常工作。对于书写方法,视图需要可更新enter link description here。
如果您只想读取而不是写入存储库,则可以通过复制ReadOnlyRepository
的源代码并删除所有写入方法来创建CrudRepository
。
请注意,JPA仍将尝试保留对托管实体所做的更改。 为了避免这种情况并避免进行脏检查,如果您使用的是Hibernate,可以mark your entities as immutable。