當前位置: 首頁>>代碼示例>>Java>>正文


Java JdbcUtils.lookupColumnName方法代碼示例

本文整理匯總了Java中org.springframework.jdbc.support.JdbcUtils.lookupColumnName方法的典型用法代碼示例。如果您正苦於以下問題:Java JdbcUtils.lookupColumnName方法的具體用法?Java JdbcUtils.lookupColumnName怎麽用?Java JdbcUtils.lookupColumnName使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在org.springframework.jdbc.support.JdbcUtils的用法示例。


在下文中一共展示了JdbcUtils.lookupColumnName方法的13個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: processRow

import org.springframework.jdbc.support.JdbcUtils; //導入方法依賴的package包/類
/**
 * Implementation of ResultSetCallbackHandler.
 * Work out column size if this is the first row, otherwise just count rows.
 * <p>Subclasses can perform custom extraction or processing
 * by overriding the {@code processRow(ResultSet, int)} method.
 * @see #processRow(java.sql.ResultSet, int)
 */
@Override
public final void processRow(ResultSet rs) throws SQLException {
	if (this.rowCount == 0) {
		ResultSetMetaData rsmd = rs.getMetaData();
		this.columnCount = rsmd.getColumnCount();
		this.columnTypes = new int[this.columnCount];
		this.columnNames = new String[this.columnCount];
		for (int i = 0; i < this.columnCount; i++) {
			this.columnTypes[i] = rsmd.getColumnType(i + 1);
			this.columnNames[i] = JdbcUtils.lookupColumnName(rsmd, i + 1);
		}
		// could also get column names
	}
	processRow(rs, this.rowCount++);
}
 
開發者ID:lamsfoundation,項目名稱:lams,代碼行數:23,代碼來源:RowCountCallbackHandler.java

示例2: mapRow

import org.springframework.jdbc.support.JdbcUtils; //導入方法依賴的package包/類
@Override
public T mapRow(ResultSet rs, int rowNum) throws SQLException {
    T mappedObject = this.entityMapper.createInstance();
    ResultSetMetaData rsmd = rs.getMetaData();
    int columnCount = rsmd.getColumnCount();
    Map<String, Class<?>> types = this.entityMapper.types();

    this.entityMapper.startMapping(mappedObject);
    for (int index = 1; index <= columnCount; index++) {
        String column = JdbcUtils.lookupColumnName(rsmd, index);
        Object value = JdbcUtils.getResultSetValue(rs, index, types.get(column));

        this.entityMapper.setValue(mappedObject, column, value);
    }
    this.entityMapper.finishMapping(mappedObject);
    return mappedObject;
}
 
開發者ID:cybozu,項目名稱:spring-data-jdbc-template,代碼行數:18,代碼來源:EntityRowMapper.java

示例3: mapRow

import org.springframework.jdbc.support.JdbcUtils; //導入方法依賴的package包/類
/**
 * <B>方法名稱:</B>映射行數據<BR>
 * <B>概要說明:</B><BR>
 * 
 * @param rs 結果集
 * @param row 行號
 * @return JSONObject 數據
 * @throws SQLException SQL異常錯誤
 * @see RowMapper#mapRow(ResultSet,
 *      int)
 */
public JSONObject mapRow(ResultSet rs, int row) throws SQLException {
    String key = null;
    Object obj = null;
    JSONObject json = new JSONObject();
    ResultSetMetaData rsmd = rs.getMetaData();
    int count = rsmd.getColumnCount();
    for (int i = 1; i <= count; i++) {
        key = JdbcUtils.lookupColumnName(rsmd, i);
        obj = JdbcUtils.getResultSetValue(rs, i);
        try {
            json.put(key, obj);
        }
        catch (JSONException e) {
        }
    }
    return json;
}
 
開發者ID:craware,項目名稱:webapp-tyust,代碼行數:29,代碼來源:JsonRowMapper.java

示例4: mapRow

import org.springframework.jdbc.support.JdbcUtils; //導入方法依賴的package包/類
@Override
public T mapRow(ResultSet rs, int rowNum) throws SQLException {
	Assert.state(this.mappedClass != null, "Mapped class was not specified");
	T bean = BeanUtils.instantiate(this.mappedClass);
	ResultSetMetaData rsmd = rs.getMetaData();
	int columnCount = rsmd.getColumnCount();
	for (int index = 1; index <= columnCount; index++) {
		String columnName = JdbcUtils.lookupColumnName(rsmd, index);
		// System.err.println("column:" + column);
		columnName = columnName.replaceAll(" ", "").toLowerCase();
		columnName = columnName.replace("_", "");

		Field field = this.mappedFields.get(columnName);

		// if (field == null) {
		// this.mappedFields.get(underscoreName(column));
		// }
		// System.out.println("column:" + column + " field:" + field);

		if (field == null && columnName.endsWith("s")) {
			// TODO images轉imageList的臨時實現?
			String column2 = columnName.substring(0, columnName.length() - 1) + "list";
			field = this.mappedFields.get(column2);
			// System.out.println("column2:" + column2 + " field:" + field);
		}

		if (field != null) {
			this.loadFieldValue(bean, rs, index, rsmd, columnName, field);
		}
	}
	return bean;
}
 
開發者ID:tanhaichao,項目名稱:leopard,代碼行數:33,代碼來源:LeopardBeanPropertyRowMapper.java

示例5: createFieldIndex

import org.springframework.jdbc.support.JdbcUtils; //導入方法依賴的package包/類
private Map<String, Integer> createFieldIndex(ResultSet rs) throws SQLException {
	ResultSetMetaData rsmd = rs.getMetaData();
	int columnCount = rsmd.getColumnCount();
	Map<String, Integer> fieldIndex = new LinkedHashMap<String, Integer>(columnCount);

	for (int i = 1; i <= columnCount; i++) {
		String field = JdbcUtils.lookupColumnName(rsmd, i);
		fieldIndex.put(field, Integer.valueOf(i));
	}

	return fieldIndex;
}
 
開發者ID:sogou-biztech,項目名稱:compass,代碼行數:13,代碼來源:AggregationResultSetExtractor.java

示例6: mapRow

import org.springframework.jdbc.support.JdbcUtils; //導入方法依賴的package包/類
@Override
public JsonNode mapRow(ResultSet rs, int rowNum) throws SQLException {
    ObjectNode objectNode = mapper.createObjectNode();
    ResultSetMetaData rsmd = rs.getMetaData();
    int columnCount = rsmd.getColumnCount();
    for (int index = 1; index <= columnCount; index++) {
        String column = JdbcUtils.lookupColumnName(rsmd, index);
        Object value = rs.getObject(column);
        column = this.snakeCaseToCamelCase(column);
        if (value == null) {
            objectNode.putNull(column);
        } else if (value instanceof Integer) {
            objectNode.put(column, (Integer) value);
        } else if (value instanceof String) {
            objectNode.put(column, (String) value);
        } else if (value instanceof Boolean) {
            objectNode.put(column, (Boolean) value);
        } else if (value instanceof Date) {
            objectNode.put(column, ((Date) value).getTime());
        } else if (value instanceof Long) {
            objectNode.put(column, (Long) value);
        } else if (value instanceof Double) {
            objectNode.put(column, (Double) value);
        } else if (value instanceof Float) {
            objectNode.put(column, (Float) value);
        } else if (value instanceof BigDecimal) {
            objectNode.put(column, (BigDecimal) value);
        } else if (value instanceof Byte) {
            objectNode.put(column, (Byte) value);
        } else if (value instanceof byte[]) {
            objectNode.put(column, (byte[]) value);
        } else {
            throw new IllegalArgumentException("Unmappable object type: " + value.getClass());
        }
    }
    return objectNode;
}
 
開發者ID:OHDSI,項目名稱:WebAPI,代碼行數:38,代碼來源:GenericRowMapper.java

示例7: processRow

import org.springframework.jdbc.support.JdbcUtils; //導入方法依賴的package包/類
/**
 * Implementation of ResultSetCallbackHandler.
 * Work out column size if this is the first row, otherwise just count rows.
 * <p>Subclasses can perform custom extraction or processing
 * by overriding the {@code processRow(ResultSet, int)} method.
 * @see #processRow(java.sql.ResultSet, int)
 */
public final void processRow(ResultSet rs) throws SQLException {
	if (this.rowCount == 0) {
		ResultSetMetaData rsmd = rs.getMetaData();
		this.columnCount = rsmd.getColumnCount();
		this.columnTypes = new int[this.columnCount];
		this.columnNames = new String[this.columnCount];
		for (int i = 0; i < this.columnCount; i++) {
			this.columnTypes[i] = rsmd.getColumnType(i + 1);
			this.columnNames[i] = JdbcUtils.lookupColumnName(rsmd, i + 1);
		}
		// could also get column names
	}
	processRow(rs, this.rowCount++);
}
 
開發者ID:deathspeeder,項目名稱:class-guard,代碼行數:22,代碼來源:RowCountCallbackHandler.java

示例8: mapRow

import org.springframework.jdbc.support.JdbcUtils; //導入方法依賴的package包/類
/**
 * {@inheritDoc}
 */
@Override
public T mapRow(ResultSet rs, int rowNumber) throws SQLException {
    Assert.state(this.mappedClass != null, "Mapped class was not specified");
    T mappedObject = BeanUtils.instantiate(this.mappedClass);
    BeanWrapper bw = PropertyAccessorFactory.forBeanPropertyAccess(mappedObject);

    ResultSetMetaData metaData = rs.getMetaData();
    int columnCount = metaData.getColumnCount();

    for (int index = 1; index <= columnCount; index++) {
        String column = JdbcUtils.lookupColumnName(metaData, index);

        String name = column.replaceAll(" ", "").toLowerCase();
        Object value = null;
        if (privateFields.containsKey(name)) {
            PropertyDescriptor pd = privateFields.get(name);
            value = getColumnValue(rs, index, pd.getPropertyType());
            if (logger.isDebugEnabled() && rowNumber == 0) {
                logger.debug("Mapping column '" + column + "' to property '" + pd.getName() + "' of type " + pd.getPropertyType());
            }
            // TODO: care about assign null to primitive field. See BeanPropertyRowMapper
            bw.setPropertyValue(pd.getName(), value);
        } else if (publicFields.containsKey(name)) {
            Field field = this.publicFields.get(name);
            value = getColumnValue(rs, index, field.getType());
            if (logger.isDebugEnabled() && rowNumber == 0) {
                logger.debug("Mapping column '" + column + "' to property '" + field.getName() + "' of type " + field.getType());
            }
            try {
                field.set(mappedObject, value);
            } catch (IllegalAccessException e) {
                throw new RuntimeException(e);
            }
        }
    }

    return mappedObject;
}
 
開發者ID:cero-t,項目名稱:sqltemplate,代碼行數:42,代碼來源:BeanMapper.java

示例9: mapRow

import org.springframework.jdbc.support.JdbcUtils; //導入方法依賴的package包/類
@Override
public Map<String, String> mapRow(ResultSet rs, int rowNum) throws SQLException {
    Map<String, String> object = new HashMap<String, String>();
    ResultSetMetaData metaData = rs.getMetaData();
    for (int i = 1; i <= metaData.getColumnCount(); i++) {
        String columnName = JdbcUtils.lookupColumnName(metaData, i);
        object.put(columnName, rs.getString(i));
    }
    return object;
}
 
開發者ID:PkayJava,項目名稱:pluggable,代碼行數:11,代碼來源:StringStringMapper.java

示例10: mapRow

import org.springframework.jdbc.support.JdbcUtils; //導入方法依賴的package包/類
/**
 * Extract the values for all columns in the current row.
 * <p>Utilizes public setters and result set metadata.
 * @see java.sql.ResultSetMetaData
 */
@Override
public T mapRow(ResultSet rs, int rowNumber) throws SQLException {
	Assert.state(this.mappedClass != null, "Mapped class was not specified");
	T mappedObject = BeanUtils.instantiate(this.mappedClass);
	BeanWrapper bw = PropertyAccessorFactory.forBeanPropertyAccess(mappedObject);
	initBeanWrapper(bw);

	ResultSetMetaData rsmd = rs.getMetaData();
	int columnCount = rsmd.getColumnCount();
	Set<String> populatedProperties = (isCheckFullyPopulated() ? new HashSet<String>() : null);

	for (int index = 1; index <= columnCount; index++) {
		String column = JdbcUtils.lookupColumnName(rsmd, index);
		PropertyDescriptor pd = this.mappedFields.get(column.replaceAll(" ", "").toLowerCase());
		if (pd != null) {
			try {
				Object value = getColumnValue(rs, index, pd);
				if (logger.isDebugEnabled() && rowNumber == 0) {
					logger.debug("Mapping column '" + column + "' to property '" +
							pd.getName() + "' of type " + pd.getPropertyType());
				}
				try {
					bw.setPropertyValue(pd.getName(), value);
				}
				catch (TypeMismatchException e) {
					if (value == null && primitivesDefaultedForNullValue) {
						logger.debug("Intercepted TypeMismatchException for row " + rowNumber +
								" and column '" + column + "' with value " + value +
								" when setting property '" + pd.getName() + "' of type " + pd.getPropertyType() +
								" on object: " + mappedObject);
					}
					else {
						throw e;
					}
				}
				if (populatedProperties != null) {
					populatedProperties.add(pd.getName());
				}
			}
			catch (NotWritablePropertyException ex) {
				throw new DataRetrievalFailureException(
						"Unable to map column " + column + " to property " + pd.getName(), ex);
			}
		}
	}

	if (populatedProperties != null && !populatedProperties.equals(this.mappedProperties)) {
		throw new InvalidDataAccessApiUsageException("Given ResultSet does not contain all fields " +
				"necessary to populate object of class [" + this.mappedClass + "]: " + this.mappedProperties);
	}

	return mappedObject;
}
 
開發者ID:lamsfoundation,項目名稱:lams,代碼行數:59,代碼來源:BeanPropertyRowMapper.java

示例11: mapRow

import org.springframework.jdbc.support.JdbcUtils; //導入方法依賴的package包/類
@Override
public T mapRow(ResultSet rs, int rowNumber) throws SQLException {
	Assert.state(this.mappedClass != null, "Mapped class was not specified");
	T mappedObject = BeanUtils.instantiate(this.mappedClass);
	BeanWrapper bw = PropertyAccessorFactory.forBeanPropertyAccess(mappedObject);

	ResultSetMetaData rsmd = rs.getMetaData();
	int columnCount = rsmd.getColumnCount();
	
	for (int index = 1; index <= columnCount; index++) {
		String column = JdbcUtils.lookupColumnName(rsmd, index);
		String dbFieldName = column.replaceAll(" ", "");
		FieldMapper fieldMapper = this.tableMapper.getFieldMapper(dbFieldName);
		PropertyDescriptor pd;
		if (fieldMapper != null && (pd=fieldMapper.getPropertyDescriptor()) != null ) {
			try {
				Object value = getColumnValue(rs, index, pd);
				if (logger.isDebugEnabled() && rowNumber == 0) {
					logger.debug("Mapping column '" + column + "' to property '" +pd.getName() + "' of type " + pd.getPropertyType());
				}
				try {
					bw.setPropertyValue(pd.getName(), value);
				}
				catch (TypeMismatchException e) {
					if (value == null) {
						logger.debug("Intercepted TypeMismatchException for row " + rowNumber +
								" and column '" + column + "' with value " + value +
								" when setting property '" + pd.getName() + "' of type " + pd.getPropertyType() +
								" on object: " + mappedObject);
					}
					else {
						throw e;
					}
				}
			}
			catch (NotWritablePropertyException ex) {
				throw new DataRetrievalFailureException("Unable to map column " + column + " to property " + pd.getName(), ex);
			}
		}
	}
	
	
	return mappedObject;
}
 
開發者ID:thinking-github,項目名稱:nbone,代碼行數:45,代碼來源:EntityPropertyRowMapper.java

示例12: mapRow

import org.springframework.jdbc.support.JdbcUtils; //導入方法依賴的package包/類
/**
 * Extract the values for all columns in the current row.
 * <p>Utilizes public setters and result set metadata.
 * @see java.sql.ResultSetMetaData
 */
public T mapRow(ResultSet rs, int rowNumber) throws SQLException {
	Assert.state(this.mappedClass != null, "Mapped class was not specified");
	T mappedObject = BeanUtils.instantiate(this.mappedClass);
	BeanWrapper bw = PropertyAccessorFactory.forBeanPropertyAccess(mappedObject);
	initBeanWrapper(bw);

	ResultSetMetaData rsmd = rs.getMetaData();
	int columnCount = rsmd.getColumnCount();
	Set<String> populatedProperties = (isCheckFullyPopulated() ? new HashSet<String>() : null);

	for (int index = 1; index <= columnCount; index++) {
		String column = JdbcUtils.lookupColumnName(rsmd, index);
		PropertyDescriptor pd = this.mappedFields.get(column.replaceAll(" ", "").toLowerCase());
		if (pd != null) {
			try {
				Object value = getColumnValue(rs, index, pd);
				if (logger.isDebugEnabled() && rowNumber == 0) {
					logger.debug("Mapping column '" + column + "' to property '" +
							pd.getName() + "' of type " + pd.getPropertyType());
				}
				try {
					bw.setPropertyValue(pd.getName(), value);
				}
				catch (TypeMismatchException e) {
					if (value == null && primitivesDefaultedForNullValue) {
						logger.debug("Intercepted TypeMismatchException for row " + rowNumber +
								" and column '" + column + "' with value " + value +
								" when setting property '" + pd.getName() + "' of type " + pd.getPropertyType() +
								" on object: " + mappedObject);
					}
					else {
						throw e;
					}
				}
				if (populatedProperties != null) {
					populatedProperties.add(pd.getName());
				}
			}
			catch (NotWritablePropertyException ex) {
				throw new DataRetrievalFailureException(
						"Unable to map column " + column + " to property " + pd.getName(), ex);
			}
		}
	}

	if (populatedProperties != null && !populatedProperties.equals(this.mappedProperties)) {
		throw new InvalidDataAccessApiUsageException("Given ResultSet does not contain all fields " +
				"necessary to populate object of class [" + this.mappedClass + "]: " + this.mappedProperties);
	}

	return mappedObject;
}
 
開發者ID:deathspeeder,項目名稱:class-guard,代碼行數:58,代碼來源:BeanPropertyRowMapper.java

示例13: mapRow2SubObj

import org.springframework.jdbc.support.JdbcUtils; //導入方法依賴的package包/類
/**
 * Extract the values for all columns in the current row.
 * <p>Utilizes public setters and result set metadata.
 * @see java.sql.ResultSetMetaData
 */
@SuppressWarnings("rawtypes")
public Object mapRow2SubObj(ResultSet rs, int rowNumber,Class subClz) throws SQLException {
	Assert.state(subClz != null, "Mapped class was not specified");
	Object mappedObject = BeanUtils.instantiate(subClz);
	BeanWrapper bw = PropertyAccessorFactory.forBeanPropertyAccess(mappedObject);
	initBeanWrapper(bw);
	
	ResultSetMetaData rsmd = rs.getMetaData();
	int columnCount = rsmd.getColumnCount();
	Set<String> populatedProperties = (isCheckFullyPopulated() ? new HashSet<String>() : null);
	
	for (int index = 1; index <= columnCount; index++) {
		String column = JdbcUtils.lookupColumnName(rsmd, index);
		PropertyDescriptor pd = this.subMappedFields.get(column.replaceAll(" ", "").toLowerCase());
		Class clz = this.subMappedFieldsSuperClz.get(column.replaceAll(" ", "").toLowerCase());
		if (pd != null&&clz==subClz) {
			try {
				Object value = getColumnValue(rs, index, pd);
				if (logger.isDebugEnabled() && rowNumber == 0) {
					//logger.debug("Mapping column '" + column + "' to property '" +
					//		pd.getName() + "' of type " + pd.getPropertyType());
				}
				try {
					bw.setPropertyValue(pd.getName(), value);
				}catch (TypeMismatchException e) {
					if (value == null && primitivesDefaultedForNullValue) {
						logger.debug("Intercepted TypeMismatchException for row " + rowNumber +
								" and column '" + column + "' with value " + value +
								" when setting property '" + pd.getName() + "' of type " + pd.getPropertyType() +
								" on object: " + mappedObject);
					}
					else {
						throw e;
					}
				}
				if (populatedProperties != null) {
					populatedProperties.add(pd.getName());
				}
			}
			catch (NotWritablePropertyException ex) {
				throw new DataRetrievalFailureException(
						"Unable to map column " + column + " to property " + pd.getName(), ex);
			}
		} 
	}
	
	if (populatedProperties != null && !populatedProperties.equals(this.subMappedProperties)) {
		throw new InvalidDataAccessApiUsageException("Given ResultSet does not contain all fields " +
				"necessary to populate object of class [" + subClz+ "]: " + this.subMappedProperties);
	}
	
	return mappedObject;
}
 
開發者ID:zhanggh,項目名稱:mtools,代碼行數:59,代碼來源:BeanPropRowMap.java


注:本文中的org.springframework.jdbc.support.JdbcUtils.lookupColumnName方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。