在Corda V3中,我们按照API Vault Query文档中的描述扩展了FungibleState
:
object CustomSchemaV1 : MappedSchema(schemaFamily = CustomSchema.javaClass, version = 1, mappedTypes = listOf(PersistentCustomState::class.java))
{
@Entity
@Table(name = "custom_states", indexes = arrayOf(Index(name = "custom_field_idx", columnList = "custom_field")))
class PersistentCustomState(
/** Custom attributes */
@Column(name = "custom_field")
var customField: String? = null,
/** FungibleState parent attributes */
@Transient
val _participants: Set<AbstractParty>,
@Transient
val _owner: AbstractParty,
@Transient
val _quantity: Long,
@Transient
val _issuerParty: AbstractParty,
@Transient
val _issuerRef: OpaqueBytes
) : CommonSchemaV1.FungibleState(_participants?.toMutableSet(), _owner, _quantity, _issuerParty, _issuerRef.bytes)}
使用这种模式,我们如何求和
_quantity
父字段(按custom_field
分组)?查看示例,我们尝试使用
QueryCriteria
:val sum = builder {
CustomSchemaV1.PersistentCustomState::_quantity.sum(
groupByColumns = listOf(
CustomSchemaV1.PersistentCustomState::customField
),
orderBy = Sort.Direction.ASC
)
}
return QueryCriteria.VaultCustomQueryCriteria(sum)
但这会引发错误:
Unable to locate Attribute with the the given name [_quantity] on this ManagedType [net.corda.core.schemas.PersistentState]
我们能够解决此问题,方法是删除
@Transient
注释,该注释也将quantity
保留在子类上,但是这导致在数据库中存储重复的值。 最佳答案
您是否考虑过尝试以下方法:
object CustomSchemaV1 : MappedSchema(schemaFamily = CustomSchema.javaClass, version = 1, mappedTypes = listOf(PersistentCustomState::class.java))
{
@Entity
@Table(name = "custom_states", indexes = arrayOf(Index(name = "custom_field_idx", columnList = "custom_field")))
class PersistentCustomState(
/** Custom attributes */
@Column(name = "custom_field")
var customField: String? = null,
/** FungibleState parent attributes */
participants: MutableSet<AbstractParty>?,
owner: AbstractParty,
quantity: Long,
issuerParty: AbstractParty,
issuerRef: OpaqueBytes
) : CommonSchemaV1.FungibleState(participants, owner, quantity, issuerParty, issuerRef.bytes)}
然后使用继承的
quantity
列? CommonSchemaV1.FungibleState
是MappedSuperclass
,因此其列将映射到子实体中。