OPENJPA-1326:

Set schema names for Sybase when creating new indexes and primary keys.
Submitted By : BJ Reed

git-svn-id: https://svn.apache.org/repos/asf/openjpa/trunk@889772 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
Michael Dick 2009-12-11 19:08:01 +00:00
parent 4515e2f5da
commit 82aece9711
1 changed files with 29 additions and 0 deletions

View File

@ -23,6 +23,7 @@ import java.math.BigDecimal;
import java.math.BigInteger; import java.math.BigInteger;
import java.sql.Connection; import java.sql.Connection;
import java.sql.PreparedStatement; import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException; import java.sql.SQLException;
import java.sql.Types; import java.sql.Types;
import java.util.Arrays; import java.util.Arrays;
@ -30,6 +31,7 @@ import java.util.Arrays;
import org.apache.commons.lang.StringUtils; import org.apache.commons.lang.StringUtils;
import org.apache.openjpa.jdbc.schema.Column; import org.apache.openjpa.jdbc.schema.Column;
import org.apache.openjpa.jdbc.schema.ForeignKey; import org.apache.openjpa.jdbc.schema.ForeignKey;
import org.apache.openjpa.jdbc.schema.Index;
import org.apache.openjpa.jdbc.schema.PrimaryKey; import org.apache.openjpa.jdbc.schema.PrimaryKey;
import org.apache.openjpa.jdbc.schema.Table; import org.apache.openjpa.jdbc.schema.Table;
import org.apache.openjpa.jdbc.schema.Unique; import org.apache.openjpa.jdbc.schema.Unique;
@ -312,6 +314,33 @@ public class SybaseDictionary
return ConcreteClassGenerator.newInstance(sybaseConnectionImpl, conn); return ConcreteClassGenerator.newInstance(sybaseConnectionImpl, conn);
} }
/**
* Create a new primary key from the information in the schema metadata.
*/
protected PrimaryKey newPrimaryKey(ResultSet pkMeta)
throws SQLException {
PrimaryKey pk = new PrimaryKey();
pk.setSchemaName(pkMeta.getString("table_owner"));
pk.setTableName(pkMeta.getString("table_name"));
pk.setColumnName(pkMeta.getString("column_name"));
pk.setName(pkMeta.getString("index_name"));
return pk;
}
/**
* Create a new index from the information in the index metadata.
*/
protected Index newIndex(ResultSet idxMeta)
throws SQLException {
Index idx = new Index();
idx.setSchemaName(idxMeta.getString("table_owner"));
idx.setTableName(idxMeta.getString("table_name"));
idx.setColumnName(idxMeta.getString("column_name"));
idx.setName(idxMeta.getString("index_name"));
idx.setUnique(!idxMeta.getBoolean("non_unique"));
return idx;
}
/** /**
* Connection wrapper to cache the {@link Connection#getCatalog} result, * Connection wrapper to cache the {@link Connection#getCatalog} result,
* which takes a very long time with the Sybase Connection (and * which takes a very long time with the Sybase Connection (and