⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 table.java

📁 hibernate-3.0.5 中文文档
💻 JAVA
📖 第 1 页 / 共 2 页
字号:
//$Id: Table.java,v 1.39 2005/05/23 00:48:08 oneovthafew Exp $package org.hibernate.mapping;import java.io.Serializable;import java.util.ArrayList;import java.util.HashMap;import java.util.Iterator;import java.util.List;import java.util.Map;import org.apache.commons.collections.SequencedHashMap;import org.hibernate.HibernateException;import org.hibernate.MappingException;import org.hibernate.dialect.Dialect;import org.hibernate.engine.Mapping;import org.hibernate.tool.hbm2ddl.ColumnMetadata;import org.hibernate.tool.hbm2ddl.TableMetadata;/** * A relational table * * @author Gavin King */public class Table implements RelationalModel, Serializable {	private String name;	private String schema;	private String catalog;	/**	 * contains all columns, including the primary key	 */	private Map columns = new SequencedHashMap();	private KeyValue idValue;	private PrimaryKey primaryKey;	private Map indexes = new HashMap();	private Map foreignKeys = new HashMap();	private Map uniqueKeys = new HashMap();	private final int uniqueInteger;	private boolean quoted;	private boolean schemaQuoted;	private static int tableCounter = 0;	private List checkConstraints = new ArrayList();	private String rowId;	private String subselect;	private boolean isAbstract;	private boolean hasDenormalizedTables = false;	private String comment;	static class ForeignKeyKey implements Serializable {		String referencedClassName;		List columns;		ForeignKeyKey(List columns, String referencedClassName) {			this.referencedClassName = referencedClassName;			this.columns = new ArrayList();			this.columns.addAll( columns );		}		public int hashCode() {			return columns.hashCode();		}		public boolean equals(Object other) {			ForeignKeyKey fkk = ( ForeignKeyKey ) other;			return fkk.columns.equals( columns ) &&					fkk.referencedClassName.equals( referencedClassName );		}	}	public Table() {		uniqueInteger = tableCounter++;	}		public Table(String name) {		this();		setName(name);	}	public String getQualifiedName(Dialect dialect, String defaultCatalog, String defaultSchema) {		if ( subselect != null ) return "( " + subselect + " )";		String quotedName = getQuotedName(dialect);		String usedSchema = schema == null ? defaultSchema : getQuotedSchema(dialect);		String usedCatalog = catalog == null ? defaultCatalog : catalog;		return Table.qualify( usedCatalog, usedSchema, quotedName, dialect.getSchemaSeparator() );	}	public static String qualify(String catalog, String schema, String table, char separator) {		StringBuffer qualifiedName = new StringBuffer();		if ( catalog != null ) {			qualifiedName.append( catalog );			qualifiedName.append( separator );			qualifiedName.append( schema != null ? schema : "" );			qualifiedName.append( separator );		}		else if ( schema != null ) {			qualifiedName.append( schema );			qualifiedName.append( separator );		}		qualifiedName.append( table );		return qualifiedName.toString();	}	public String getName() {		return name;	}	public String getQuotedName(Dialect dialect) {		return quoted ?				dialect.openQuote() + name + dialect.closeQuote() :				name;	}	public String getQuotedSchema(Dialect dialect) {		return schemaQuoted ?				dialect.openQuote() + schema + dialect.closeQuote() :				schema;	}		public void setName(String name) {		if ( name.charAt( 0 ) == '`' ) {			quoted = true;			this.name = name.substring( 1, name.length() - 1 );		}		else {			this.name = name;		}	}	/**	 * Return the column which is identified by column provided as argument.	 *	 * @param column column with atleast a name.	 * @return the underlying column or null if not inside this table. Note: the instance *can* be different than the input parameter, but the name will be the same.	 */	public Column getColumn(Column column) {		Column myColumn = ( Column ) columns.get( column.getName() );		if ( column.equals( myColumn ) ) {			return myColumn;		}		else {			return null;		}	}	public Column getColumn(int n) {		Iterator iter = columns.values().iterator();		for ( int i = 0; i < n - 1; i++ ) iter.next();		return ( Column ) iter.next();	}	public void addColumn(Column column) {		Column old = ( Column ) columns.get( column.getName() );		if ( old == null ) {			columns.put( column.getName(), column );			column.uniqueInteger = columns.size();		}		else {			column.uniqueInteger = old.uniqueInteger;		}	}	public int getColumnSpan() {		return columns.size();	}	public Iterator getColumnIterator() {		return columns.values().iterator();	}	public Iterator getIndexIterator() {		return indexes.values().iterator();	}	public Iterator getForeignKeyIterator() {		return foreignKeys.values().iterator();	}	public Iterator getUniqueKeyIterator() {		return uniqueKeys.values().iterator();	}	public Iterator sqlAlterStrings(Dialect dialect, Mapping p, TableMetadata tableInfo, String defaultCatalog, String defaultSchema)			throws HibernateException {		StringBuffer root = new StringBuffer( "alter table " )				.append( getQualifiedName( dialect, defaultCatalog, defaultSchema ) )				.append( ' ' )				.append( dialect.getAddColumnString() );		Iterator iter = getColumnIterator();		List results = new ArrayList();		while ( iter.hasNext() ) {			Column col = ( Column ) iter.next();			ColumnMetadata columnInfo = tableInfo.getColumnMetadata( col.getName() );			if ( columnInfo == null ) {				// the column doesnt exist at all.				StringBuffer alter = new StringBuffer( root.toString() )						.append( ' ' )						.append( col.getQuotedName( dialect ) )						.append( ' ' )						.append( col.getSqlType( dialect, p ) );								boolean useUniqueConstraint = col.isUnique() && 						dialect.supportsUnique() && 						( !col.isNullable() || dialect.supportsNotNullUnique() );				if ( useUniqueConstraint ) {					alter.append( " unique" );				}								if ( col.hasCheckConstraint() && dialect.supportsColumnCheck() ) {					alter.append( " check(" )							.append( col.getCheckConstraint() )							.append( ")" );				}				String columnComment = col.getComment();				if (columnComment!=null) alter.append( dialect.getColumnComment(columnComment) );				results.add( alter.toString() );			}		}		return results.iterator();	}		public boolean hasPrimaryKey() {		return getPrimaryKey()!=null;	}	public String sqlCreateString(Dialect dialect, Mapping p, String defaultCatalog, String defaultSchema) throws HibernateException {		StringBuffer buf = new StringBuffer( "create table " )				.append( getQualifiedName( dialect , defaultCatalog, defaultSchema ) )				.append( " (" );		boolean identityColumn = idValue != null && idValue.isIdentityColumn(dialect);		// Try to find out the name of the primary key to create it as identity if the IdentityGenerator is used		String pkname = null;		if ( hasPrimaryKey() && identityColumn ) {			pkname = ( ( Column ) getPrimaryKey().getColumnIterator().next() ).getQuotedName( dialect );		}		Iterator iter = getColumnIterator();		while ( iter.hasNext() ) {			Column col = ( Column ) iter.next();			buf.append( col.getQuotedName( dialect ) )					.append( ' ' );			if ( identityColumn && col.getQuotedName( dialect ).equals( pkname ) ) {				// to support dialects that have their own identity data type				if ( dialect.hasDataTypeInIdentityColumn() ) {					buf.append( col.getSqlType( dialect, p ) );				}				buf.append( ' ' )						.append( dialect.getIdentityColumnString( col.getSqlTypeCode( p ) ) );			}			else {				buf.append( col.getSqlType( dialect, p ) );				if ( col.isNullable() ) {					buf.append( dialect.getNullColumnString() );				}				else {					buf.append( " not null" );				}			}			boolean useUniqueConstraint = col.isUnique() && 					( !col.isNullable() || dialect.supportsNotNullUnique() );			if ( useUniqueConstraint ) {				if ( dialect.supportsUnique() ) {					buf.append( " unique" );				}				else {					UniqueKey uk = getOrCreateUniqueKey( col.getQuotedName( dialect ) + '_' );					uk.addColumn( col );				}			}						if ( col.hasCheckConstraint() && dialect.supportsColumnCheck() ) {				buf.append( " check (" )						.append( col.getCheckConstraint() )						.append( ")" );			}						String columnComment = col.getComment();			if (columnComment!=null) buf.append( dialect.getColumnComment(columnComment) );			if ( iter.hasNext() ) buf.append( ", " );		}		if ( hasPrimaryKey() ) {			buf.append( ", " )				.append( getPrimaryKey().sqlConstraintString( dialect ) );

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -