我正在使用JDO的Datanucleus教程应用程序specifically this one。
无论哪种“继承策略”我尝试表格布局都是一样的。我想要两个表,一个用于PRODUCT,一个用于BOOK,但是使用下面的配置我只得到包含类Product和class Book的列的PRODUCT表。
<class name="Product" identity-type="sequence">
<inheritance strategy="complete-table"/>
<field name="name">
<column name="PRODUCT_NAME" length="100" jdbc-type="VARCHAR"/>
</field>
<field name="description">
<column length="255" jdbc-type="VARCHAR"/>
</field>
</class>
<class name="Book" identity-type="sequence">
<field name="author">
<column length="40" jdbc-type="VARCHAR"/>
</field>
<field name="isbn">
<column length="20" jdbc-type="CHAR"/>
</field>
<field name="publisher">
<column length="40" jdbc-type="VARCHAR"/>
</field>
</class>
目录结构与教程中的完全相同,build.xml也是如此。我已经尝试通过Ant任务和命令行生成模式。
我使用命令序列:
ant clean
ant compile
ant enhance
ant createschema
生成模式但不是因为Datanucleus文档表明应该使用继承策略“竞争表”。
如果重要的话,我的目标数据库是在Ubuntu 10.04上运行的PostgreSQL 8.4。
其他人遇到此问题并找到了解决方案吗?
答案 0 :(得分:0)
回答我自己的问题:
在datanucleus教程下载中,给出的build.xml文件有一个“createschema”目标,如:
<target name="createschema">
...
<schematool ...>
<fileset dir="${basedir}/target/classes">
<include name="**/*.class"/>
</fileset>
...
</schematool>
</target>
应该将其更改为包含所有.jdo文件,如下所示:
<target name="createschema">
...
<schematool ...>
<fileset dir="${basedir}/target/classes">
<include name="**/*.class"/>
<include name="**/*.jdo"/>
</fileset>
...
</schematool>
</target>
另外,package-hsql.orm文件需要重命名为package-hsql.jdo,其标题需要更改为:
<?xml version="1.0"?>
<!DOCTYPE jdo PUBLIC
"-//Sun Microsystems, Inc.//DTD Java Data Objects ORM Metadata 2.0//EN"
"http://java.sun.com/dtd/orm_2_0.dtd">
<jdo>
...
<jdo>
请注意,DOCTYPE和根元素已更改。根元素是“orm”并更改为“jdo”。
一旦我做了这些更改,模式生成工具就遵循“继承策略”指令。
答案 1 :(得分:0)
对于我的自定义应用程序,我有一个类似的问题,它在jdo文件的标题中进行更改后工作正常。我使用的是版本3.2.9。