blob: 5e05eb697cbcbdca8259d8a1ef375c13ce0e884e [file] [log] [blame]
/*******************************************************************************
* Copyright (c) 1998, 2013 Oracle and/or its affiliates. All rights reserved.
* This program and the accompanying materials are made available under the
* terms of the Eclipse Public License v1.0 and Eclipse Distribution License v. 1.0
* which accompanies this distribution.
* The Eclipse Public License is available at http://www.eclipse.org/legal/epl-v10.html
* and the Eclipse Distribution License is available at
* http://www.eclipse.org/org/documents/edl-v10.php.
*
* Contributors:
* Oracle - initial API and implementation from Oracle TopLink
******************************************************************************/
package org.eclipse.persistence.testing.models.mapping;
import org.eclipse.persistence.tools.schemaframework.FieldDefinition;
import org.eclipse.persistence.tools.schemaframework.TableCreator;
import org.eclipse.persistence.tools.schemaframework.TableDefinition;
import org.eclipse.persistence.tools.schemaframework.ForeignKeyConstraint;
public class MultipleTableTestTableMaker extends TableCreator {
public MultipleTableTestTableMaker() {
setName("MultipleTableTestCase");
buildMUL2_EMPTable();
buildMUL2_EMP_INFOTable();
}
protected void buildMUL2_EMP_INFOTable() {
TableDefinition tabledefinition = new TableDefinition();
// SECTION: TABLE
tabledefinition.setName("MUL2_EMP_INFO");
// SECTION: FIELD
FieldDefinition field2 = new FieldDefinition();
field2.setName("INFO");
field2.setTypeName("VARCHAR");
field2.setSize(30);
field2.setShouldAllowNull(true);
field2.setIsPrimaryKey(false);
field2.setUnique(false);
field2.setIsIdentity(false);
tabledefinition.addField(field2);
// SECTION: FIELD
FieldDefinition field3 = new FieldDefinition();
field3.setName("EMP_NUM");
field3.setTypeName("NUMERIC");
field3.setSize(10);
field3.setShouldAllowNull(false);
field3.setIsPrimaryKey(true);
field3.setUnique(false);
field3.setIsIdentity(false);
tabledefinition.addField(field3);
ForeignKeyConstraint foreignKeyEMP_INFO_EMP = new ForeignKeyConstraint();
foreignKeyEMP_INFO_EMP.setName("EMP_INFO_EMP");
foreignKeyEMP_INFO_EMP.setTargetTable("MUL2_EMP");
foreignKeyEMP_INFO_EMP.addSourceField("EMP_NUM");
foreignKeyEMP_INFO_EMP.addTargetField("EMP_NUM");
tabledefinition.addForeignKeyConstraint(foreignKeyEMP_INFO_EMP);
addTableDefinition(tabledefinition);
}
protected void buildMUL2_EMPTable() {
TableDefinition tabledefinition = new TableDefinition();
// SECTION: TABLE
tabledefinition.setName("MUL2_EMP");
// SECTION: FIELD
FieldDefinition field1 = new FieldDefinition();
field1.setName("EMP_ID");
field1.setTypeName("NUMERIC");
field1.setSize(10);
field1.setShouldAllowNull(false);
field1.setIsPrimaryKey(true);
field1.setUnique(false);
field1.setIsIdentity(false);
tabledefinition.addField(field1);
// SECTION: FIELD
FieldDefinition field2 = new FieldDefinition();
field2.setName("EMP_NUM");
field2.setTypeName("NUMERIC");
field2.setSize(10);
field2.setShouldAllowNull(false);
field2.setIsPrimaryKey(true);
field2.setUnique(true);
field2.setIsIdentity(false);
tabledefinition.addField(field2);
// SECTION: FIELD
FieldDefinition field3 = new FieldDefinition();
field3.setName("FNAME");
field3.setTypeName("VARCHAR");
field3.setSize(30);
field3.setShouldAllowNull(true);
field3.setIsPrimaryKey(false);
field3.setUnique(false);
field3.setIsIdentity(false);
tabledefinition.addField(field3);
addTableDefinition(tabledefinition);
}
}