FileDocCategorySizeDatePackage
CharacterType.javaAPI DocHibernate 3.2.51615Wed Aug 10 15:23:56 BST 2005org.hibernate.type

CharacterType.java

//$Id: CharacterType.java 7825 2005-08-10 20:23:55Z oneovthafew $
package org.hibernate.type;

import java.io.Serializable;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Types;

import org.hibernate.MappingException;
import org.hibernate.dialect.Dialect;

/**
 * <tt>character</tt>: A type that maps an SQL CHAR(1) to a Java Character.
 * @author Gavin King
 */
public class CharacterType extends PrimitiveType implements DiscriminatorType {

	public Serializable getDefaultValue() {
		throw new UnsupportedOperationException("not a valid id type");
	}
	
	public Object get(ResultSet rs, String name) throws SQLException {
		String str = rs.getString(name);
		if (str==null) {
			return null;
		}
		else {
			return new Character( str.charAt(0) );
		}
	}

	public Class getPrimitiveClass() {
		return char.class;
	}

	public Class getReturnedClass() {
		return Character.class;
	}

	public void set(PreparedStatement st, Object value, int index) throws SQLException {
		st.setString( index, (value).toString() );
	}

	public int sqlType() {
		return Types.CHAR;
	}
	public String getName() { return "character"; }

	public String objectToSQLString(Object value, Dialect dialect) throws Exception {
		return '\'' + value.toString() + '\'';
	}

	public Object stringToObject(String xml) throws Exception {
		if ( xml.length() != 1 ) throw new MappingException("multiple or zero characters found parsing string");
		return new Character( xml.charAt(0) );
	}

	public Object fromStringValue(String xml) {
		return new Character( xml.charAt(0) );
	}

}