java rs.metadata_java – 如何从Hibernate MetadataSources中发现完全限定的表列

本文介绍了如何通过实现Hibernate Integrator并使用MetadataSources,来详细获取实体与数据库表之间的映射关系,包括表名、列名和数据类型。通过示例代码展示了如何注册Integrator,并在测试用例中打印出实体属性对应的数据库表列信息。
摘要由CSDN通过智能技术生成

这是一个非常好的问题,所以我决定将

an article用于更详细地回答它.

org.hibernate.boot.Metadata是我们感兴趣的,因为它包含PersistentClass实体绑定.

首先,您需要创建一个Integrator来访问元数据:

public class MetadataExtractorIntegrator

implements org.hibernate.integrator.spi.Integrator {

public static final MetadataExtractorIntegrator INSTANCE =

new MetadataExtractorIntegrator();

private Database database;

private Metadata metadata;

public Database getDatabase() {

return database;

}

public Metadata getMetadata() {

return metadata;

}

@Override

public void integrate(

Metadata metadata,

SessionFactoryImplementor sessionFactory,

SessionFactoryServiceRegistry serviceRegistry) {

this.database = metadata.getDatabase();

this.metadata = metadata;

}

@Override

public void disintegrate(

SessionFactoryImplementor sessionFactory,

SessionFactoryServiceRegistry serviceRegistry) {

}

}

如果您使用JPA,您可以按如下方式注册:

Map configuration = new HashMap<>();

Integrator integrator = integrator();

if (integrator != null) {

configuration.put("hibernate.integrator_provider",

(IntegratorProvider) () -> Collections.singletonList(

MetadataExtractorIntegrator.INSTANCE

)

);

}

EntityManagerFactory entityManagerFactory = new EntityManagerFactoryBuilderImpl(

new PersistenceUnitInfoDescriptor(persistenceUnitInfo),

configuration

)

.build();

现在,在运行以下测试用例时:

Metadata metadata = MetadataExtractorIntegrator.INSTANCE.getMetadata();

for ( PersistentClass persistentClass : metadata.getEntityBindings()) {

Table table = persistentClass.getTable();

LOGGER.info( "Entity: {} is mapped to table: {}",

persistentClass.getClassName(),

table.getName()

);

for(Iterator propertyIterator = persistentClass.getPropertyIterator();

propertyIterator.hasNext(); ) {

Property property = (Property) propertyIterator.next();

for(Iterator columnIterator = property.getColumnIterator();

columnIterator.hasNext(); ) {

Column column = (Column) columnIterator.next();

LOGGER.info( "Property: {} is mapped on table column: {} of type: {}",

property.getName(),

column.getName(),

column.getSqlType()

);

}

}

}

反对以下实体:

9b37a1ae76fc60c7b6dc8f8f2f995684.png

我们得到以下输出:

Entity: com.vladmihalcea.book.hpjp.util.providers.entity.BlogEntityProvider$Tag is mapped to table: tag

Property: name is mapped on table column: name of type: varchar(255)

Property: version is mapped on table column: version of type: integer

Entity: com.vladmihalcea.book.hpjp.util.providers.entity.BlogEntityProvider$PostComment is mapped to table: post_comment

Property: post is mapped on table column: post_id of type: bigint

Property: review is mapped on table column: review of type: varchar(255)

Property: version is mapped on table column: version of type: integer

Entity: com.vladmihalcea.book.hpjp.util.providers.entity.BlogEntityProvider$Post is mapped to table: post

Property: title is mapped on table column: title of type: varchar(255)

Property: version is mapped on table column: version of type: integer

Entity: com.vladmihalcea.book.hpjp.util.providers.entity.BlogEntityProvider$PostDetails is mapped to table: post_details

Property: createdBy is mapped on table column: created_by of type: varchar(255)

Property: createdOn is mapped on table column: created_on of type: datetime(6)

Property: version is mapped on table column: version of type: integer

很酷,对吗?

您也可以查看此示例on GitHub.

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值