我正在尝试使用Intellij Idea Ultimate中的JPA控制台来测试查询。该项目由JHipster 5.7.0生成,并使用带有Hazelcast的H2内存数据库。
生成的application-dev.yml:
...
datasource:
type: com.zaxxer.hikari.HikariDataSource
url: jdbc:h2:mem:appointmentservice;DB_CLOSE_DELAY=-1;DB_CLOSE_ON_EXIT=FALSE
username: appointmentservice
password:
hikari:
auto-commit: false
h2:
console:
enabled: true
jpa:
database-platform: io.github.jhipster.domain.util.FixedH2Dialect
database: H2
show-sql: false
properties:
hibernate.id.new_generator_mappings: true
hibernate.connection.provider_disables_autocommit: true
hibernate.cache.use_second_level_cache: true
hibernate.cache.use_query_cache: false
hibernate.generate_statistics: true
hibernate.cache.region.factory_class: com.hazelcast.hibernate.HazelcastCacheRegionFactory
hibernate.cache.hazelcast.instance_name: appointmentservice
hibernate.cache.use_minimal_puts: true
hibernate.cache.hazelcast.use_lite_member: true
...
我在资源目录中创建了以下 persistence.xml :
<?xml version="1.0" encoding="UTF-8"?>
<persistence version="2.0" xmlns="http://java.sun.com/xml/ns/persistence"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://java.sun.com/xml/ns/persistence http://java.sun.com/xml/ns/persistence/persistence_2_0.xsd">
<persistence-unit name="appointmentservice" transaction-type="RESOURCE_LOCAL">
<provider>org.hibernate.jpa.HibernatePersistenceProvider</provider>
<properties>
<property name="javax.persistence.jdbc.driver" value="org.h2.Driver"/>
<property name="hibernate.dialect" value="org.hibernate.dialect.H2Dialect"/>
<property name="javax.persistence.jdbc.url" value="jdbc:h2:mem:appointmentservice"/>
<property name="javax.persistence.jdbc.user" value="appointmentservice"/>
<property name="hibernate.id.new_generator_mappings" value="true"/>
<property name="hibernate.cache.use_second_level_cache" value="true"/>
<property name="hibernate.cache.use_query_cache" value="false"/>
<property name="hibernate.generate_statistics" value="true"/>
<property name="hibernate.cache.region.factory_class" value="com.hazelcast.hibernate.HazelcastCacheRegionFactory"/>
<property name="hibernate.cache.hazelcast.instance_name" value="appointmentservice"/>
<property name="hibernate.cache.use_minimal_puts" value="true"/>
<property name="hibernate.cache.hazelcast.use_lite_member" value="true"/>
</properties>
</persistence-unit>
</persistence>
问题: 单击约会服务时,将在Intellij持久性视图中显示所有实体。但是,当我右键单击它并打开JPA控制台时,所有查询都无法声明没有找到表。
例如
jpa-ql> select a from Address a
[2019-03-04 16:03:57] [42S02] Table "ADDRESS" not found; SQL statement:
[2019-03-04 16:03:57] select address0_.id as id1_1_, address0_.active as active2_1_, address0_.city as city3_1_, address0_.clientAccount_id as clientAc9_1_, address0_.country as country4_1_, address0_.institution_id as institu10_1_, address0_.location_id as locatio11_1_, address0_.jhi_number as jhi_numb5_1_, address0_.street as street6_1_, address0_.supplement as suppleme7_1_, address0_.zip as zip8_1_ from address address0_ [42102-197]
如果有人可以给我提示我做错了什么,或者有适合我的案例的persistence.xml文件示例,我将不胜感激。 预先感谢
编辑: 感谢您的所有答复! -我遵循@GaëlMarziou的建议,删除了persistence.xml,并使用tcp URL连接到Intellij中的数据源。现在,我可以在那里浏览表内容。 然后,我不得不在Intellij持久性视图中将数据源分配给entityManagerFactory。此外,我需要使用与application.yml中相同的NamingStrategie。
答案 0 :(得分:2)
JHipster使用TCP端口创建H2服务器(请参见h2TCPServer()
中的DatabaseConfiguration.java
方法),因此可以使用tcp JDBC URL从外部客户端访问内存数据库,该URL与在您的application.yml
中配置了一个。
外部客户端应使用jdbc:h2:tcp://localhost:18080/mem:appointmentservice
端口18080基于Web端口(例如8080)+ 10000(请参见h2TCPServer()
方法),并在应用程序启动时记录为“ H2数据库在端口xxxxx上可用”。
我个人使用DBeaver访问我的JHipster应用程序中的H2数据库。
根据Deinum先生的建议,您应该删除persistence.xml
。