当前位置: 首页 > 知识库问答 >
问题:

从hibernate实体生成数据库

毕浩渺
2023-03-14

我有生成Hibernate实体的mysql db,现在我需要从这些实体生成内存数据库进行测试。我在试图运行我的单元测试时遇到了这个错误。

/***主]o.h.发动机。jdbc。spi。SqlExceptionHelper:SQL错误:42102,SQLState:42S02 2016-02-16 18:10:47.864错误29758---[main]o.h.engine。jdbc。spi。SqlExceptionHelper:未找到表“tbl_所有_订单”;SQL语句:**/

看起来数据库创建失败了。

以下是我的测试属性文件内容:

db.driver: org.h2.Driver
db.url: jdbc:h2:mem:testdb;MODE=MySQL;DB_CLOSE_DELAY=-1;DB_CLOSE_ON_EXIT=FALSE;DATABASE_TO_UPPER=false
db.username: sa
db.password: 

hibernate.dialect: org.hibernate.dialect.H2Dialect
hibernate.show_sql: true
hibernate.format_sql: true
hibernate.hbm2ddl.auto: create
hibernate.archive.autodetection=class, hbm
entitymanager.packagesToScan: linda

共有2个答案

百里泓
2023-03-14

这是我的测试工作配置(src/test/resources文件夹中的database.properties)

# DB properties
db.driver=org.h2.Driver
db.url=jdbc:h2:mem:test;DB_CLOSE_DELAY=-1
db.username=sa
db.password=

# Hibernate Configuration
hibernate.dialect=org.hibernate.dialect.H2Dialect
hibernate.show_sql=true

# validate: validate the schema, makes no changes to the database.
# update: update the schema.
# create: creates the schema, destroying previous data.
# create-drop: drop the schema at the end of the session.
hibernate.hbm2ddl.auto=create
entitymanager.packages.to.scan=abcde

顺便说一句,你的单元测试不应该访问数据库。

弓胜泫
2023-03-14

这是我的h2测试示例。你可以稍微修改一下,看看它适合你的情况。主要需要手动创建db表,并让您的配置。包含数据库的xml。你可以创造。如果您正在使用spring,请手动创建sql文件并创建表,并让bean包含它。

一些est.java

@RunWith(SpringJUnit4ClassRunner.class)
@ContextConfiguration("testConfig.xml") // <-- this xml you need to include
public class PortDaoImplTest {

    private static final Logger log = Logger.getLogger(sysInfoDaoImplTest.class);

    @Autowired
    private sysInfoDaoImpl sysDao;

    @After
    public void tearDown(){
        portDao = null;
    }

    @Test
    public void testGetPort() {
        log.info("Testing getInfo(String id)...");
        SysInfo p = sysDao.getInfo("nysdin2039");
        assertNotNull(p);
    }

testConfig。xml

...xml header...                    

            <!--    h2 driver -->
        <bean id="test.dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource" lazy-init="false" >
            <property name="driverClassName" value="org.h2.Driver" />
            <property name="url" value="jdbc:h2:mem:test_mem;DB_CLOSE_DELAY=-1;MODE=ORACLE" />
        </bean>

        <!--    datasource file -->
        <jdbc:initialize-database data-source="test.dataSource">
            <!--        table list -->
            <jdbc:script location="com/yourPath/h2/schema.sql" />
            <jdbc:script location="com/yourPath/h2/test_data.sql" />

        </jdbc:initialize-database>

        <!--    bean def -->
        <bean id="sysInfoDao" class="com.mycompanyName.sysInfoDaoImpl" >
            <property name="log" ref="test.log" />
            <property name="dataSource" ref="test.dataSource" />
        </bean>

....

h2模式。sql文件

drop table IF EXISTS tbl_all_orders;
CREATE TABLE tbl_all_orders
(
  your_stuff_ID     NUMBER               NOT NULL,
  your_other_column_stuff                VARCHAR2(15)    DEFAULT 
);

...相应地添加约束或列。。。

测试数据。sql文件

INSERT into tbl_all_orders
   (your_column_names... , your_other_column_names...)
VALUES
   (1, 'values',...);
 类似资料:
  • 问题内容: 我正在尝试从现有的空数据库中生成symfony2中的实体(相当大,从头开始创建实体确实很痛苦)。不幸的是,我遇到了很大的问题。 当我尝试调用以下命令时(在Windows上如果发生任何更改): 我收到以下消息: 没有要处理的元数据类。 发布之前,我已经: 验证我的配置正常(我可以连接到数据库), 我的捆绑软件已创建,上面指定的路径有效 当我尝试转换为xml / yml时,与尝试生成注释映

  • 问题内容: Xcode 8更新: 在Xcode 8中,需要转到Core Data Model Editor并显示File Inspector。底部附近是代码生成的选项。选择快速。 编辑 :我找到了从核心数据实体生成Swift模型的解决方案: 在Xcode上: 编辑器 >创建NSManagedOjbect>单击按钮“下一步”>单击按钮“下一步”>选择“快速”语言>单击按钮“创建” 我使用Core D

  • 问题内容: 是否有可用于Eclipse或Netbeans或任何其他IDE的插件,可以通过直接从数据库中读取模式来帮助我生成hbm.xml。 编写这些XML似乎是不必要的时间浪费,因此应该自动进行。 问题答案: 对于NetBeans,请参阅在Web应用程序中使用hibernate。 对于Eclipse,请使用Hibernate Tools 插件。这是一个演示如何使用其 逆向工程 功能的教程。

  • 我是Hibernate的新手,并要求使用具有这些列的表的数据库 表:TBL _ product//库存项目列表< br >列:< br > key _ product < br > key _ category < br > fld _ product _ name < br > fld _ Inventory _ qty < br > fld _ unit _ price < br > fld

  • 我正在按照下面链接中的步骤生成Hibernate实体类。我被第一步搞砸了。找不到持久性工具窗口。即使在视图>工具窗口>持久性。

  • 问题内容: 我的要求是将巨大的XML值保存到数据库。 在分析了几个选项之后,我最终确定了从巨大的xml生成实体bean类,然后使用hibernate对其进行持久化的过程。 我不选择创建hbm文件,而是选择hibernate注释。这样,我将使用JAXB从XSD生成Java类,并手动添加hibernate注释。 是否有任何eclipse插件或util框架可以使用默认的hibernate注释从XSD生成