blob: d69a7b25aec3d4666648dbd5ceeb5ed936d8f61e [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.ForeignKeyConstraint;
import org.eclipse.persistence.tools.schemaframework.TableDefinition;
public class LegacyTableMaker extends org.eclipse.persistence.tools.schemaframework.TableCreator {
public LegacyTableMaker() {
setName("LegacyTestCase");
buildMUL_ADDRTable();
buildMUL_EMPTable();
buildMUL_CTRYTable();
}
protected void buildMUL_ADDRTable() {
TableDefinition tabledefinition = new TableDefinition();
// SECTION: TABLE
tabledefinition.setName("MUL_ADDR");
// SECTION: FIELD
FieldDefinition field = new FieldDefinition();
field.setName("CITY");
field.setTypeName("VARCHAR");
field.setSize(10);
field.setShouldAllowNull(true);
field.setIsPrimaryKey(false);
field.setUnique(false);
field.setIsIdentity(false);
tabledefinition.addField(field);
// SECTION: FIELD
FieldDefinition field1 = new FieldDefinition();
field1.setName("CNTRY_ID");
field1.setTypeName("NUMERIC");
field1.setSize(5);
field1.setShouldAllowNull(true);
field1.setIsPrimaryKey(false);
field1.setUnique(false);
field1.setIsIdentity(false);
tabledefinition.addField(field1);
// SECTION: FIELD
FieldDefinition field2 = new FieldDefinition();
field2.setName("PROVINCE");
field2.setTypeName("VARCHAR");
field2.setSize(10);
field2.setShouldAllowNull(true);
field2.setIsPrimaryKey(false);
field2.setUnique(false);
field2.setIsIdentity(false);
tabledefinition.addField(field2);
// SECTION: FIELD
FieldDefinition field3 = new FieldDefinition();
field3.setName("ADDR_ID");
field3.setTypeName("NUMERIC");
field3.setSize(10);
field3.setShouldAllowNull(false);
field3.setIsPrimaryKey(true);
field3.setUnique(false);
field3.setIsIdentity(false);
tabledefinition.addField(field3);
ForeignKeyConstraint foreignKeyADDRESS_COUNTRY = new ForeignKeyConstraint();
foreignKeyADDRESS_COUNTRY.setName("ADDRESS_COUNTRY");
foreignKeyADDRESS_COUNTRY.setTargetTable("MUL_CTRY");
foreignKeyADDRESS_COUNTRY.addSourceField("CNTRY_ID");
foreignKeyADDRESS_COUNTRY.addTargetField("CNTRY_ID");
tabledefinition.addForeignKeyConstraint(foreignKeyADDRESS_COUNTRY);
addTableDefinition(tabledefinition);
}
protected void buildMUL_CTRYTable() {
TableDefinition tabledefinition = new TableDefinition();
// SECTION: TABLE
tabledefinition.setName("MUL_CTRY");
// SECTION: FIELD
FieldDefinition field = new FieldDefinition();
field.setName("COUNTRY");
field.setTypeName("VARCHAR");
field.setSize(10);
field.setShouldAllowNull(true);
field.setIsPrimaryKey(false);
field.setUnique(false);
field.setIsIdentity(false);
tabledefinition.addField(field);
// SECTION: FIELD
FieldDefinition field1 = new FieldDefinition();
field1.setName("CNTRY_ID");
field1.setTypeName("NUMERIC");
field1.setSize(5);
field1.setShouldAllowNull(false);
field1.setIsPrimaryKey(true);
field1.setUnique(false);
field1.setIsIdentity(false);
tabledefinition.addField(field1);
addTableDefinition(tabledefinition);
}
protected void buildMUL_EMPTable() {
TableDefinition tabledefinition = new TableDefinition();
// SECTION: TABLE
tabledefinition.setName("MUL_EMP");
// SECTION: FIELD
FieldDefinition field = new FieldDefinition();
field.setName("FIRST_NAME");
field.setTypeName("VARCHAR");
field.setSize(10);
field.setShouldAllowNull(true);
field.setIsPrimaryKey(false);
field.setUnique(false);
field.setIsIdentity(false);
tabledefinition.addField(field);
// 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("LAST_NAME");
field2.setTypeName("VARCHAR");
field2.setSize(10);
field2.setShouldAllowNull(true);
field2.setIsPrimaryKey(false);
field2.setUnique(false);
field2.setIsIdentity(false);
tabledefinition.addField(field2);
// SECTION: FIELD
FieldDefinition field3 = new FieldDefinition();
field3.setName("SEX");
field3.setTypeName("VARCHAR");
field3.setSize(10);
field3.setShouldAllowNull(true);
field3.setIsPrimaryKey(false);
field3.setUnique(false);
field3.setIsIdentity(false);
tabledefinition.addField(field3);
// SECTION: FIELD
FieldDefinition field4 = new FieldDefinition();
field4.setName("ADDR_ID");
field4.setTypeName("NUMERIC");
field4.setSize(10);
field4.setShouldAllowNull(true);
field4.setIsPrimaryKey(false);
field4.setUnique(false);
field4.setIsIdentity(false);
tabledefinition.addField(field4);
addTableDefinition(tabledefinition);
ForeignKeyConstraint foreignKeyEMPLOYEE_ADDRESS = new ForeignKeyConstraint();
foreignKeyEMPLOYEE_ADDRESS.setName("EMPLOYEE_ADDRESS");
foreignKeyEMPLOYEE_ADDRESS.setTargetTable("MUL_ADDR");
foreignKeyEMPLOYEE_ADDRESS.addSourceField("ADDR_ID");
foreignKeyEMPLOYEE_ADDRESS.addTargetField("ADDR_ID");
tabledefinition.addForeignKeyConstraint(foreignKeyEMPLOYEE_ADDRESS);
}
}