我知道spring数据存储库的实现:
创建一个像这样的接口:
public interface CountryRepository extends CrudRepository<Country, Long> {}
现在Country
是一个AbstractCatalog
,我的项目中有(很多)更多目录。
我想知道是否可以制作1个适用于所有目录的存储库:
public interface AbstractCatalogRepository extends CrudRepository<AbstractCatalog, Long> {}
现在,有了保存,我不会直接看到问题,但是如果我要搜索一个,AbstractCatalog我已经确定我会碰壁的,因为回购协议将不知道他必须选择哪种对象。
AbstractCatalog.class
@MappedSuperclass
public abstract class AbstractCatalog extends PersistentEntity {
/**
* The Constant serialVersionUID.
*/
private static final long serialVersionUID = 1L;
@Id
@GeneratedValue(strategy = GenerationType.AUTO)
private Integer id;
/**
* The code.
*/
@Column(unique = true, nullable = false, updatable = false)
private String code;
/**
* The description.
*/
@Column(nullable = false)
private String description;
/**
* The in use.
*/
@Column(name = "IN_USE", nullable = false, columnDefinition = "bit default 1")
private Boolean inUse = Boolean.TRUE;
// getters and setters
}
Country.class
@Entity
@Table(name = "tc_country")
@AttributeOverrides({
@AttributeOverride(name = "id", column =
@Column(name = "COUNTRY_SID")),
@AttributeOverride(name = "code", column =
@Column(name = "COUNTRY_CODE")),
@AttributeOverride(name = "description", column =
@Column(name = "COUNTRY_DESCRIPTION"))})
public class Country extends AbstractCatalog {
public static final int MAX_CODE_LENGTH = 11;
@Column(name = "GEONAMEID", nullable = true, unique = false)
private Long geonameid;
// getter and setter
}
有谁知道我如何只AbstractCatalog为名称和实现类的最小更改而为所有实现只创建1个Repo,而又不用一遍又一遍地创建相同的接口?
如果你没有在数据库侧使用表继承(例如,带有decriminator列的超类表),AFAIK,并且基于阅读JPA教程的知识,则无法做到这一点(即,@MappedSuperclass
仅对抽象类使用注释)
映射的超类不能查询,也不能在EntityManager或Query操作中使用。你必须在EntityManager或Query操作中使用映射的超类的实体子类。映射的超类不能成为实体关系的目标
注意,JPA存储库抽象在幕后使用EntityManager。我做了一个简单的测试,你将得到(对于Hibernate实现)“ IllegalArgumentException : not an entity AbstractClass
”
另一方面,如果确实使用表继承,则可以使用抽象类型。我知道你说过“只有很小的变化”(我想我的简短回答是我认为这是不可能的-可能是出于你猜测的原因),所以我想这个答案的其余部分是给其他打听者们的;- )
表继承策略的示例将是这样的(免责声明:这不是erd继承的正确可视化,但是MySQL Workbench不支持它,但是下面我将模型按照需要的方式进行了工程化,使其设计为MYSQL)。是)
哪里CountryCatalog
有对AbstractCatalog
表pk(id)的FK / PK参考。该AbstractCatalo
g表具有一个descriminatorColumn
,将用于确定超型出现与哪个子类型相关。
在如何编码方面,它看起来像
@Entity
@Inheritance(strategy = InheritanceType.JOINED)
@DiscriminatorColumn(name="descriminatorColumn")
@Table(name="AbstractCatalog")
public abstract class AbstractCatalog {
@Id
private long id;
...
}
@Entity
@Table(name = "CountryCatalog")
public class CountryCatalog extends AbstractCatalog {
// id is inherited
...
}
public interface AbstractCatalogRepository
extends JpaRepository<AbstractCatalog, Long> {
}
@Repository
public class CountryCatalogServiceImpl implements CountryCatalogService {
@Autowired
private AbstractCatalogRepository catalogRepository;
@Override
public List<CountryCatalog> findAll() {
return (List<CountryCatalog>)(List<?>)catalogRepository.findAll();
}
@Override
public CountryCatalog findOne(long id) {
return (CountryCatalog)catalogRepository.findOne(id);
}
}
如果你没有表继承,那么你要尝试执行的操作将无法正常工作。存储库的类类型必须是一个实体。如果你的表没有采用这种方式进行继承,则取决于你是否要更改表。不过,避免多个存储库可能会有点麻烦。
嗨,我正在尝试使用抽象类在 laravel 中实现存储库模式,以拥有一些我新手的基本功能。 我正在得到 分析错误:语法错误,意外'- 在AbstractRepository一行- AbstractRepository.php ReportRepositoryInterface.php ReportRepository.php ReportsController.php 有谁能开导一下吗?谢谢
对于spring boot、spring jpa、spring amqp,我有以下场景: 我的应用程序负责将数据复制到不同的数据库,但使用相同的实体,我必须存储/更新数据的数据库将在运行时根据即将到来的rabbit amqp数据决定。 我知道,使用spring jpa,我们可以拥有多个数据源,而使用@EnableJpaRepositories,我们可以通过如下方式指定基本包来选择repositor
我在PDI CE 7.0上运行勺子,并试图第一次设置我的数据库存储库。我可以使用SQL服务器作为我的数据库存储库,但我想知道我是否可以使用我的红移服务器作为我的数据库存储库。 当我测试我的数据库连接时,它运行正常。然而,当我尝试连接到存储库时,我会收到一条错误消息,说“您似乎没有连接到服务器。请检查您正在使用的路径,并确保服务器已启动并运行”(单击以查看错误消息) 我已经试着改变我的JDBC驱动程
问题内容: 有多少个数据库系统使用JSON进行存储或传输?我知道: CouchDB MongoDB DBSlayer 我记得我在SO用户的个人资料中看到了另一个供应商。该系统使用的是所谓的二进制JSON,但我不记得该产品的名称。 最近,似乎越来越多的DB项目正在将JSON用于持久性存储。其中一些甚至将HTTP用作传输层。 问题答案: MongoDb是使用二进制JSON存储格式的一种。我不知道是否还
我读过一些关于在存储库请求中使用空值的帖子,但它们都已经存在多年了。所以我问这个问题是为了了解问题的现状。 我想说的是: 我想要一个带有可选空值的JPA请求。我的存储库中的函数如下所示: 这样我就可以像这样省略过滤器中的参数:(@Query的一部分) 这只在我的参数不为NULL时有效。 请注意,我在这里使用的是原生查询。(JPA实现是Hibernate,DB是postgres) 提前感谢您的每一次
问题内容: 我对AngularJS应用有个主意,我很好奇AngularJS社区是否认为可以这样做。简而言之,我正在连接到数据API并将结果显示在页面上。 我创建了一个AngularJS服务,该服务在上创建了一个数据存储。我还有一个服务方法,可以使用从API端点返回的数据更新DataStore。如果我使用来从控制器内部请求“ products” API端点,则它将使用我的产品数据进行更新。 现在,在