Many resources are needed to download a project. Please understand that we have to compensate our server costs. Thank you in advance. Project price only 1 $
You can buy this project and download/modify it how often you want.
/*
Copyright 2012, Brett Wooldridge
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
*/
package com.zaxxer.sansorm.internal;
import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.ResultSetMetaData;
import java.sql.SQLException;
import java.util.ArrayList;
import java.util.Collections;
import java.util.HashMap;
import java.util.LinkedHashMap;
import java.util.List;
import java.util.Map;
import java.util.Map.Entry;
import java.util.Set;
/**
* OrmReader
*/
// MULTIPLESTRINGS:OFF
public class OrmReader extends OrmBase
{
private static final int CACHE_SIZE = Integer.getInteger("com.zaxxer.sansorm.statementCacheSize", 500);
private static final Map fromClauseStmtCache;
static
{
fromClauseStmtCache = Collections.synchronizedMap(new LinkedHashMap(CACHE_SIZE) {
private static final long serialVersionUID = 6259942586093454872L;
@Override
protected boolean removeEldestEntry(java.util.Map.Entry eldest)
{
return this.size() > CACHE_SIZE;
}
});
}
public static List statementToList(PreparedStatement stmt, Class clazz, Object... args) throws SQLException
{
try
{
populateStatementParameters(stmt, args);
return resultSetToList(stmt.executeQuery(), clazz);
}
finally
{
stmt.close();
}
}
// COMPLEXITY:OFF
public static List resultSetToList(ResultSet resultSet, Class targetClass) throws SQLException
{
List list = new ArrayList();
if (!resultSet.next())
{
resultSet.close();
return list;
}
Introspected introspected = Introspector.getIntrospected(targetClass);
final boolean hasJoinColumns = introspected.hasSelfJoinColumn();
Map deferredSelfJoinFkMap = (hasJoinColumns ? new HashMap() : null);
Map