org.seasar.extension.jdbc.SelectClause Maven / Gradle / Ivy
The newest version!
/*
* Copyright 2004-2015 the Seasar Foundation and the Others.
*
* 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 org.seasar.extension.jdbc;
import java.util.Map;
import org.seasar.framework.util.CollectionsUtil;
/**
* select句を組み立てるクラスです。
*
* @author higa
*
*/
public class SelectClause {
/**
* SQLです。
*/
protected StringBuilder sql;
/**
* カラム名のエイリアスに使う序数です。
*/
protected int aliasIndex;
/**
* 修飾されたカラム名とSELECT句のエイリアス名とのマッピングです。
*/
protected Map columnAliases = CollectionsUtil.newHashMap(64);
/**
* {@link SelectClause}を作成します。
*
*/
public SelectClause() {
this(300);
}
/**
* {@link SelectClause}を作成します。
*
* @param capacity
* 初期容量
*/
public SelectClause(int capacity) {
sql = new StringBuilder(capacity);
}
/**
* SQLの長さを返します。
*
* @return SQLの長さ
*/
public int getLength() {
return sql.length();
}
/**
* SQLに変換します。
*
* @return SQL
*/
public String toSql() {
return sql.toString();
}
/**
* select句を追加します。
*
* @param tableAlias
* テーブル別名
* @param columnName
* カラム名
*/
public void addSql(String tableAlias, String columnName) {
if (sql.length() > 0) {
sql.append(", ");
}
String qname = tableAlias + '.' + columnName;
String columnAlias = "C" + (++aliasIndex) + "_";
columnAliases.put(qname, columnAlias);
sql.append(qname).append(" as ").append(columnAlias);
}
/**
* select句を追加します。
*
* @param selectItem
* セレクト項目
*/
public void addSql(String selectItem) {
if (sql.length() > 0) {
sql.append(", ");
}
sql.append(selectItem);
}
/**
* カラム名に対応するエイリアス名を返します。
*
* @param tableAlias
* テーブル別名
* @param columnName
* カラム名
* @return カラム名に対応するエイリアス名
*/
public String getColumnAlias(String tableAlias, String columnName) {
return getColumnAlias(tableAlias + '.' + columnName);
}
/**
* カラム名に対応するエイリアス名を返します。
*
* @param qname
* テーブル別名で修飾されたカラム名
* @return カラム名に対応するエイリアス名
*/
public String getColumnAlias(String qname) {
return columnAliases.get(qname);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy