com.objectsql.option.AbstractOptions Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of object-sql Show documentation
Show all versions of object-sql Show documentation
Lightweight Object SQL Relational Mapping (OSRM)
/*
* Copyright 2017 @objectsql.com
*
* 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.objectsql.option;
import com.objectsql.query.Query;
import com.objectsql.query.MultiQuery;
import com.objectsql.annotation.*;
import com.objectsql.exception.ORMException;
import com.objectsql.support.*;
import com.objectsql.query.IQuery;
import com.objectsql.query.QueryUtils;
import com.objectsql.utils.ORMUtils;
import javax.sql.rowset.serial.SerialClob;
import java.io.ByteArrayInputStream;
import java.io.UnsupportedEncodingException;
import java.math.BigDecimal;
import java.sql.*;
import java.util.*;
import java.util.Date;
public abstract class AbstractOptions implements Options{
public QueryInfo doQuery(IQuery query){
return doQuery(query, null);
}
public abstract boolean preSetParameter(PreparedStatement ps, Connection connection, String databaseType, int i, Pair pair) throws SQLException;
public boolean tableExists(Connection connection, String schema, RdTable rdTable) throws ORMException {
if(rdTable == null){
throw new ORMException("Table annotation(RdTable) is null.");
}
String tableName = getCaseSensitive(rdTable.name(), rdTable.sensitive());
return tableExists(connection, schema, tableName);
}
protected String getCoding(Pair pair){
String defaultCoding = "UTF-8";
if(pair == null){
return defaultCoding;
}
Map metadata = pair.getMetadata();
if(metadata != null && metadata.containsKey("coding")){
defaultCoding = (String) metadata.get("coding");
}
return defaultCoding;
}
public void setParameter(PreparedStatement ps, Connection connection, String databaseType, int i,Pair pair) throws SQLException {
Object obj = pair.getValue();
ColumnType columnType = pair.getColumnType();
DataType type = DataType.getDataType(pair.getType());
boolean hasSet = preSetParameter(ps, connection, databaseType, i, pair);
if(hasSet){
return;
}
switch (type) {
case BINARY:
if(obj != null) {
if(obj instanceof byte[]) {
ps.setBinaryStream(i + 1, new ByteArrayInputStream((byte[]) obj));
}else{
try {
ps.setBinaryStream(i + 1, new ByteArrayInputStream(obj.toString().getBytes(getCoding(pair))));
} catch (UnsupportedEncodingException e) {
e.printStackTrace();
}
}
}else{
ps.setBinaryStream(i + 1, null);
}
break;
case STRING:
if(columnType == ColumnType.BINARY){
if(obj != null) {
try {
ps.setBinaryStream(i + 1, new ByteArrayInputStream(obj.toString().getBytes(getCoding(pair))));
} catch (UnsupportedEncodingException e) {
e.printStackTrace();
}
}else{
ps.setBinaryStream(i + 1, null);
}
}else if(columnType == ColumnType.BLOB){
if(obj != null) {
try {
ps.setBlob(i + 1, new ByteArrayInputStream(obj.toString().getBytes(getCoding(pair))));
} catch (UnsupportedEncodingException e) {
e.printStackTrace();
}
}else{
ps.setBinaryStream(i + 1, null);
}
}else if(columnType == ColumnType.CLOB){
Clob clob = null;
if(obj != null) {
clob = new SerialClob(obj.toString().toCharArray());
}
ps.setClob(i + 1, clob);
}else {
if (obj != null && "".equals(obj.toString().trim())) {
obj = null;
}
ps.setString(i + 1, (String) obj);
}
break;
case DATE:
if(obj == null){
ps.setObject(i + 1, null);
}else {
if(columnType == ColumnType.LONG) {
if(obj instanceof Long){
ps.setLong(i + 1, (Long)obj);
}else {
ps.setLong(i + 1, ((Date) obj).getTime());
}
}else if(columnType == ColumnType.DATETIME) {
Date date = (Date)obj;
ps.setTimestamp(i+1, new Timestamp(date.getTime()));
}else if(columnType == ColumnType.DATE) {
Date date = (Date)obj;
ps.setDate(i+1, new java.sql.Date(date.getTime()));
}else if(columnType == ColumnType.TIME) {
Date date = (Date)obj;
ps.setTime(i+1, new java.sql.Time(date.getTime()));
}else if(columnType == ColumnType.YEAR) {
Date date = (Date)obj;
Calendar calendar = Calendar.getInstance();
calendar.setTime(date);
ps.setInt(i + 1, calendar.get(Calendar.YEAR));
}else{//timestamp
ps.setTimestamp(i + 1, new Timestamp(((Date) obj).getTime()));
}
}
break;
case DECIMAL:
if(obj == null) {
ps.setObject(i + 1, null);
}else{
BigDecimal decimal = (BigDecimal) obj;
Map metadata = pair.getMetadata();
int runningMode = BigDecimal.ROUND_UNNECESSARY;
int scale = decimal.scale();
if (metadata != null) {
Integer scaleValue = (Integer) metadata.get("scale");
int newScale = scale;
if (scaleValue != null) {//当scale为0时,才会使用 RdColumn中的scale, 不能使用上述 decimal中的scale, 有可能失去精度变成很大
newScale = scaleValue.intValue();
}
Integer mode = (Integer) metadata.get("runningMode");//优先级最高,比ORMUTils。runningMode高
if (mode != null && mode.intValue() > -1) {
runningMode = mode.intValue();
scale = newScale;
}else if(ORMUtils.getRunningMode() > -1){
runningMode = ORMUtils.getRunningMode();
scale = newScale;
}
}else{
if(ORMUtils.getRunningMode() > -1){
runningMode = ORMUtils.getRunningMode();
}
}
BigDecimal setScale = decimal.setScale(scale, runningMode);
ps.setBigDecimal(i + 1, setScale);
}
break;
case DOUBLE:
ps.setObject(i + 1, obj);
break;
default:
ps.setObject(i + 1, obj);
break;
}
}
@Override
public QueryInfo doQueryCount(IQuery query) {
QueryInfo info = new QueryInfo();
List values = new ArrayList();
StringBuffer sb = new StringBuffer();
sb.append("SELECT ");
String groups = groups(query, null);
if(query.isDistinct()){
sb.append(selectColumns(query, null, null, values));
}else {
if(!ORMUtils.isEmpty(groups)){
List groupSelect = query.getGroupCountSelectColumns();
if(groupSelect == null || groupSelect.isEmpty()){
sb.append(selectColumns(query, null, null, values));
}else{
sb.append(groupCountSelect(query));
}
}else {
sb.append(selectCount());
}
}
sb.append(" FROM ");
sb.append(tables(query, values, null));
if(query instanceof MultiQuery) {
sb.append(joins((MultiQuery)query, values));
}
sb.append(wheres(query, values, null));
sb.append(groups);
sb.append(havings(query, values, null));
info.setClazz(Integer.class);
if(query.isDistinct()) {
info.setSql("SELECT COUNT(*) FROM (" + sb.toString() + ") distinct_table_");
}else{
if(ORMUtils.isEmpty(groups)){
info.setSql(sb.toString());
}else {
info.setSql("SELECT COUNT(*) FROM (" + sb.toString() + ") group_table_");
}
}
info.setValues(values);
if (TextTransformType.LOWER == query.textTransformType()){
info.setSql(info.getSql().toLowerCase(Locale.ROOT));
}else if(TextTransformType.UPPER == query.textTransformType()){
info.setSql(info.getSql().toUpperCase(Locale.ROOT));
}
return info;
}
public String selectCount(){
return " COUNT(*) ";
}
public String selectColumns(IQuery query, String alias, Map asNames, List values){
if(asNames == null){
asNames = new HashMap();
}
StringBuffer sb = new StringBuffer();
if(query.isDistinct()) {
sb.append(" DISTINCT ");
}
List returnColumns = query.getFinalReturnColumns();
List temp = new ArrayList();
List allAlias = new ArrayList();
//List inColumn = new ArrayList();
boolean noAlias = false;
if(returnColumns.isEmpty()){
String all = null;
if(ORMUtils.isEmpty(alias)){
noAlias = true;
all = Column.ALL;
}else{
allAlias.add(alias);
all = alias + "." + Column.ALL;
}
temp.add(all);
}else{
for(Column column : returnColumns){
if(column.getQuery() != null){
QueryInfo queryInfo = doQuery(column.getQuery());
String tempSQL = null;
if(ORMUtils.isEmpty(column.getAsName())){
tempSQL = "(" + queryInfo.getSql() + ")";
}else {
tempSQL = "(" + queryInfo.getSql() + ") AS " + column.getAsName();
}
if(temp.contains(tempSQL)){
continue;
}
temp.add(tempSQL);
values.addAll(queryInfo.getValues());
}else{
if(column.getAlias() == null && !ORMUtils.isEmpty(alias)){
column.setAlias(alias);
}
//inColumn.add(column.getAlias() + "." + column.getName());
String tempSQL = parseColumn(column);
if(temp.contains(tempSQL)){
continue;
}
temp.add(tempSQL);
//column format id in(a,b,c), 导致编程 id in(A,B,C)
String fm = parseColumn(column);//.toUpperCase(Locale.ROOT);
String word = " AS ";
int index = fm.indexOf(word);
if(index > -1) {
String asName = fm.substring(index + word.length());
asNames.put(asName.trim(), fm.substring(0, index));
}
if(Column.ALL.equals(column.getName())){
if(!ORMUtils.isEmpty(column.getAlias()) && !allAlias.contains(column.getAlias())){
allAlias.add(column.getAlias());
}else{
noAlias = true;
}
}
}
}
}
// if(!noAlias) {
// List orders = query.getOrders();
// for (Order order : orders) {
// Column column = order.getColumn();
// if(column instanceof CaseColumn){
// //todo 从 CaseColumn获取列
// CaseColumn caseColumn = (CaseColumn) column;
// StringBuffer caseSql = new StringBuffer();
// Map conditionMap = caseColumn.getConditions();
// Set conditions = conditionMap.keySet();
// caseSql.append("CASE ");
// for(Condition condition :conditions){
// Object value = conditionMap.get(condition);
// caseSql.append("WHEN " + parseConditions(condition) + " THEN " + (value instanceof Number? value.toString() + " ":"'" + value.toString() +"' "));
// }
//
// Object eObject = caseColumn.getElseValue();
// caseSql.append("ELSE " + (eObject instanceof Number? eObject.toString():"'" + eObject.toString() +"'") + " END");
//
// //忽略 as name
// temp.add("(" + caseSql.toString() + ") " + order.getOrder());
// }else {
// if (!asNames.containsKey(column.getName().toUpperCase(Locale.ROOT))) {
// QueryUtils.setColumnAlias(column, alias);
// }
// if (!ORMUtils.isEmpty(column.getAlias()) && !allAlias.contains(column.getAlias())
// && !inColumn.contains(column.getAlias() + "." + column.getName())) {
// String orderStr = parseColumn(column);
// temp.add(orderStr);
// }
// }
// }
// }
sb.append(ORMUtils.join(temp, ","));
if(sb.length() == 0){
if(ORMUtils.isEmpty(alias)) {
sb.append(Column.ALL);
}else{
sb.append(alias + "." + Column.ALL);
}
}
return sb.toString();
}
public String groupCountSelect(IQuery query){
List otherColumns = query.getGroupCountSelectColumns();
List temp = new ArrayList();
for(Column column : otherColumns){
String sql = parseColumn(column);
if(!temp.contains(sql)) {
temp.add(sql);
}
}
return ORMUtils.join(temp, ",");
}
public String orders(IQuery query, String alias, Map asNames){
if (asNames == null){
asNames = new HashMap();
}
String result = "";
List orders = query.getOrders();
for(Order order : orders) {
Column column = order.getColumn();
if(ORMUtils.isEmpty(column.getAlias())){
String key = column.getName().toUpperCase(Locale.ROOT);
if(!asNames.containsKey(key)){
QueryUtils.setColumnAlias(order.getColumn(), alias);
}else{
column.setName(asNames.get(key));
}
}
}
//只能获取class,嵌套sql 无法获取
Map aliasClass = new HashMap();
if(query instanceof Query){
aliasClass.put(alias, ((Query)query).getTable());
}else if(query instanceof MultiQuery){
MultiQuery multiQuery = (MultiQuery) query;
List joins = multiQuery.getJoins();
for(Join join : joins){
String joinAlias = join.getAlias();
Object aliasObject = join.getTable();
if(aliasObject instanceof Class) {
aliasClass.put(joinAlias, (Class>)aliasObject);
}
}
Map table = multiQuery.getAliasTable();
for(String aliasName : table.keySet()){
Object aliasObject = table.get(aliasName);
if(aliasObject instanceof Class) {
aliasClass.put(aliasName, (Class>)aliasObject);
}
}
}
String orderString = getOrders(orders, aliasClass);
if (orderString != null && !"".equals(orderString)) {
result = " ORDER BY " + orderString;
}
return result;
}
private String getSchema(IQuery query){
if (!ORMUtils.isEmpty(query.schema())){
return query.schema() + ".";
}
return "";
}
public String tables(IQuery query, List values, String tableAlias){
if(query instanceof Query){//base query
String tableName = ORMUtils.getTableName(query.getTable());
if(tableAlias == null) {
return getSchema(query) + tableName;
}else{
return getSchema(query) + tableName + " " + tableAlias;
}
}else{
MultiQuery multiQuery = (MultiQuery)query;
List words = new ArrayList();
Map aliasMap = multiQuery.getAliasTable();
List aliasList = multiQuery.getAliasList();
for(String alias : aliasList) {
if(aliasMap.containsKey(alias)) {
Object object = aliasMap.get(alias);
if(object instanceof Class) {
String tn = ORMUtils.getTableName((Class) object);
words.add(getSchema(query) + tn + " " + alias);
}else if(object instanceof IQuery){
IQuery q = (IQuery)aliasMap.get(alias);
QueryInfo queryInfo = doQuery(q, q.getPageable());
words.add("(" + queryInfo.getSql() + ") " + alias);
values.addAll(queryInfo.getValues());
}else{
words.add(object.toString() + " " + alias);
}
}
}
return ORMUtils.join(words, ",");
}
}
public String wheres(IQuery query, List values, String tableAlias){
String result = "";
List conditions = query.getConditions();
QueryUtils.setConditionsAlias(conditions, tableAlias);
String whereCondition = getConditions(query, conditions, values);
if(whereCondition != null && !"".equals(whereCondition)){
result =" WHERE " + whereCondition;
}
return result;
}
public String groups(IQuery query, String alias){
String result = "";
List columns = query.getGroups();
QueryUtils.setColumnsAlias(columns, alias);
String groupString = getGroups(columns);
if(groupString != null && !"".equals(groupString)){
result =" GROUP BY " + groupString;
}
return result;
}
public String havings(IQuery query, List values, String alias){
String result = "";
List conditions = query.getHavings();
QueryUtils.setConditionsAlias(conditions, alias);
String havingString = getConditions(query, conditions, values);
if(havingString != null && !"".equals(havingString)){
result = " HAVING " + havingString;
}
return result;
}
public String joins(MultiQuery obj, List values){
List joins = obj.getJoins();
StringBuffer sb = new StringBuffer();
if(joins == null){
return sb.toString();
}
for(int i = 0; i < joins.size(); i++){
Join join = joins.get(i);
String tableName = null;
Object table = join.getTable();
if(table instanceof Class) {
tableName = ORMUtils.getTableName((Class)table);
}else if(table instanceof IQuery){
QueryInfo info = doQuery((IQuery)table, null);
tableName = "(" + info.getSql() + ") ";
values.addAll(info.getValues());
}else{// String.
tableName = join.getTable().toString();
}
switch (join.getType()){
case FULL_JOIN:
sb.append(" FULL JOIN ");
break;
case INNER_JOIN:
sb.append(" INNER JOIN ");
break;
case LEFT_JOIN:
sb.append(" LEFT JOIN ");
break;
case RIGHT_JOIN:
sb.append(" RIGHT JOIN ");
break;
}
String alias = join.getAlias();
if (table instanceof Class){
sb.append(getSchema(obj));
}
sb.append(tableName + " " + alias);
List temp = join.getConditions();
String cdt = getConditions(obj, temp, values);
if(cdt != null && !"".equals(cdt)) {
sb.append(" ON ");
sb.append(cdt);
}
}
return sb.toString();
}
protected String getForeignSQL(RdTable table, RdColumn rdColumn, RdForeignKey foreign) {
if(foreign == null){
return null;
}
String foreignKey = foreign.name();
String foreignTable = ORMUtils.getTableName(foreign.foreignTable());
String foreignColumn = ORMUtils.join(foreign.foreignColumns(), ",");
String column = ORMUtils.join(foreign.columns(), ",");
if (ORMUtils.isEmpty(column)){
column = rdColumn.name();
}
ORMUtils.whenEmpty(foreignKey, "Foreign Key Name Should Not Be Empty.");
ORMUtils.whenEmpty(foreignTable, "Foreign Table Should Not Be Empty.");
ORMUtils.whenEmpty(foreignColumn, "Foreign Column Should Not Be Empty.");
// constraint JOB_INST_EXEC_FK foreign key (JOB_INSTANCE_ID) references BATCH_JOB_INSTANCE(JOB_INSTANCE_ID)
return String.format("CONSTRAINT %s FOREIGN KEY (%s) REFERENCES %s(%s)", foreignKey, column, foreignTable, foreignColumn);
}
protected String getUniqueSQL(RdTable table, RdColumn rdColumn, RdUniqueKey uniqueKey) {
if(uniqueKey == null){
return null;
}
String uniqueName = uniqueKey.name();
String [] uniqueKeys = uniqueKey.columns();
String uniqueKeysStr = ORMUtils.join(uniqueKeys, ",");
if(ORMUtils.isEmpty(uniqueKeysStr)){
uniqueKeysStr = rdColumn.name();
}
return String.format("CONSTRAINT %s UNIQUE(%s)", uniqueName, uniqueKeysStr);
}
protected String columnComment(RdColumn rdColumn){
String comment = null;
if(!ORMUtils.isEmpty(rdColumn.title())){
comment = rdColumn.title();
if(!ORMUtils.isEmpty(rdColumn.description())){
comment += ";" + rdColumn.description();
}
}
return comment;
}
abstract String getColumnType(ColumnInfo info, RdColumn column);
public SQLPair parseExpression(Class clazz, Map clazzes, Expression expression){
SQLPair sqlPair = null;
if(expression == null){
return sqlPair;
}
if(expression.getLeft() == null){
if(expression.getValue() instanceof MultiQuery){
MultiQuery mq = (MultiQuery)expression.getValue();
QueryInfo qinfo = mq.doQuery();
if(expression.getType() == ExpressionType.CDT_EXISTS) {
sqlPair = new SQLPair("EXISTS(" + qinfo.getSql() + ")", qinfo.getValues());
}else if(expression.getType() == ExpressionType.CDT_NOT_EXISTS) {
sqlPair = new SQLPair("NOT EXISTS(" + qinfo.getSql() + ")", qinfo.getValues());
}
}
return sqlPair;
}
String conditionName = parseColumn(expression.getLeft());
switch (expression.getType()) {
case CDT_IS_NULL:
sqlPair = new SQLPair(" "+ conditionName + " IS NULL ");
break;
case CDT_IS_NOT_NULL:
sqlPair = new SQLPair(" "+ conditionName + " IS NOT NULL ");
break;
case CDT_IS_EMPTY:
sqlPair = new SQLPair(" "+ conditionName + " = '' ");
break;
case CDT_IS_NOT_EMPTY:
sqlPair = new SQLPair(" "+ conditionName + " != '' ");
break;
default:
break;
}
if(sqlPair != null){
return sqlPair;
}
Object conditionValue = expression.getValue();
boolean isTrim = ORMUtils.isTrim();
if(isTrim && (conditionValue instanceof String)){
conditionValue = ((String) conditionValue).trim();
}
if(conditionValue != null ) {
if (conditionValue instanceof Column) {
String valueSQL = parseColumn((Column) conditionValue);
if(expression.getType() == null){
sqlPair = new SQLPair(conditionName + " = " + valueSQL);
}else{
switch (expression.getType()) {
case CDT_EQUAL:
sqlPair = new SQLPair(" " + conditionName + " = " + valueSQL);
break;
case CDT_NOT_EQUAL:
sqlPair = new SQLPair(" " + conditionName + " != " + valueSQL);
break;
case CDT_MORE:
sqlPair = new SQLPair(" " + conditionName + " > " + valueSQL);
break;
case CDT_MORE_EQUAL:
sqlPair = new SQLPair(" " + conditionName + " >= " + valueSQL);
break;
case CDT_LESS:
sqlPair = new SQLPair(" " + conditionName + " < " + valueSQL);
break;
case CDT_LESS_EQUAL:
sqlPair = new SQLPair(" " + conditionName + " <= " + valueSQL);
break;
}
}
if(sqlPair != null){
return sqlPair;
}
}else if(conditionValue instanceof IQuery){
QueryInfo newQueryInfo = doQuery((IQuery)conditionValue);
String sql = null;
if(ExpressionType.CDT_IN == expression.getType()){
sql = String.format(" %s IN (%s) ", conditionName, newQueryInfo.getSql());
}else{
sql = String.format(" %s NOT IN (%s) ", conditionName, newQueryInfo.getSql());
}
if(sql != null) {
sqlPair = new SQLPair(sql, newQueryInfo.getValues());
return sqlPair;
}
}
}
if(!ORMUtils.isEmpty(conditionValue)){
Column column = expression.getLeft();
ColumnInfo columnInfo = null;
if(ORMUtils.isEmpty(column.getAlias()) && clazz != null){
Map pairMap = ORMUtils.getColumnColumnInfo(clazz);
columnInfo = pairMap.get(column.getName());
}else{
if(clazzes != null && clazzes.containsKey(column.getAlias())){
Object object = clazzes.get(column.getAlias());
if(object instanceof Class) {
Map pairMap = ORMUtils.getColumnColumnInfo((Class) object);
columnInfo = pairMap.get(column.getName());
}
}
}
switch (expression.getType()) {
case CDT_EQUAL:
sqlPair = new SQLPair(" " + conditionName + " = ?", new Pair(columnInfo, conditionValue));
break;
case CDT_NOT_EQUAL:
sqlPair = new SQLPair(" " + conditionName + " != ?", new Pair(columnInfo, conditionValue));
break;
case CDT_MORE:
sqlPair = new SQLPair(" "+ conditionName + " > ?", new Pair(columnInfo, conditionValue));
break;
case CDT_MORE_EQUAL:
sqlPair = new SQLPair(" "+ conditionName + " >= ?", new Pair(columnInfo, conditionValue));
break;
case CDT_LESS:
sqlPair = new SQLPair(" "+ conditionName + " < ?", new Pair(columnInfo, conditionValue));
break;
case CDT_LESS_EQUAL:
sqlPair = new SQLPair(" "+ conditionName + " <= ?", new Pair(columnInfo, conditionValue));
break;
case CDT_LIKE:
sqlPair = new SQLPair(" "+ conditionName + " LIKE ?", new Pair(columnInfo, "%" +conditionValue + "%"));
break;
case CDT_NOT_LIKE:
sqlPair = new SQLPair(" "+ conditionName + " NOT LIKE ?", new Pair(columnInfo, "%" +conditionValue + "%"));
break;
case CDT_END_WITH:
sqlPair = new SQLPair(" "+ conditionName + " LIKE ?", new Pair(columnInfo, "%" +conditionValue));
break;
case CDT_START_WITH:
sqlPair = new SQLPair(" "+ conditionName + " LIKE ?", new Pair(columnInfo, conditionValue + "%"));
break;
case CDT_NOT_END_WITH:
sqlPair = new SQLPair(" "+ conditionName + " NOT LIKE ?", new Pair(columnInfo, "%" +conditionValue));
break;
case CDT_NOT_START_WITH:
sqlPair = new SQLPair(" "+ conditionName + " NOT LIKE ?", new Pair(columnInfo, conditionValue + "%"));
break;
case CDT_BETWEEN:
List vs = new ArrayList();
StringBuffer btSql = new StringBuffer(" (" + conditionName + " BETWEEN ");
if(expression.getValue() instanceof Column){
btSql.append(parseColumn((Column) expression.getValue()));
}else{
btSql.append("?");
vs.add(new Pair(columnInfo, conditionValue));
}
btSql.append(" AND ");
if(expression.getAndValue() instanceof Column){
btSql.append(parseColumn((Column) expression.getAndValue()));
}else{
btSql.append("?");
Object andConditionValue = expression.getAndValue();
if(andConditionValue instanceof String){
if(isTrim){
andConditionValue = ((String) andConditionValue).trim();
}
}
vs.add(new Pair(columnInfo, andConditionValue));
}
btSql.append(")");
sqlPair = new SQLPair(btSql.toString(), vs);
break;
case CDT_IN:
case CDT_NOT_IN:
if(Collection.class.isAssignableFrom(conditionValue.getClass())){
List names = new ArrayList();
List values = new ArrayList();
Iterator iterator = ((Collection) conditionValue).iterator();
while (iterator.hasNext()){
Object obj = iterator.next();
if(obj != null){
if(isTrim && (obj instanceof String)){
String obj2 = ((String) obj).trim();
if(!"".equals(obj2)) {
names.add("?");
values.add(new Pair(columnInfo, obj));
}
}else{
names.add("?");
values.add(new Pair(columnInfo, obj));
}
}
}
if(!names.isEmpty()) {
if (expression.getType() == ExpressionType.CDT_IN) {
sqlPair = new SQLPair(" " + conditionName + " IN (" + ORMUtils.join(names, ",") + ")", values);
} else {
sqlPair = new SQLPair(" " + conditionName + " NOT IN (" + ORMUtils.join(names, ",") + ")", values);
}
}
}
break;
default:
break;
}
}
return sqlPair;
}
public String parseColumn(Column column){
if(column == null){
throw new ORMException("QUERY_SQL_COLUMN_IS_NULL this column is null");
}
StringBuffer sb = new StringBuffer();
if(column instanceof CaseColumn){
CaseColumn caseColumn = (CaseColumn) column;
StringBuffer caseSql = new StringBuffer();
Map conditionMap = caseColumn.getConditions();
Set conditions = conditionMap.keySet();
caseSql.append("CASE ");
for(Condition condition :conditions){
Object value = conditionMap.get(condition);
caseSql.append("WHEN " + parseConditions(condition) + " THEN " + parseCaseColumnValue(value) + " ");
}
Object eObject = caseColumn.getElseValue();
caseSql.append("ELSE " + parseCaseColumnValue(eObject) + " END");
if(ORMUtils.isEmpty(caseColumn.getFunction())){
sb.append("(" + caseSql.toString() + ")");
}else {
sb.append(caseColumn.getFunction() + "(" + caseSql.toString() + ")");
}
if(!ORMUtils.isEmpty(column.getAsName())){
sb.append(" AS " + column.getAsName());
}
return sb.toString();
}
if(column.getName() == null && ORMUtils.isEmpty(column.getAlias())){
throw new ORMException("QUERY_SQL_NAME_IS_NULL this column name is null.");
}
if(column.getName() == null && !ORMUtils.isEmpty(column.getAsName())){
sb.append("NULL AS " + column.getAsName());
return sb.toString();
}
if(!ORMUtils.isEmpty(column.getFunction())){
if(!ORMUtils.isEmpty(column.getType())){
String result = getColumnWithOperatorAndFunction(column);
sb.append(result);
}else{
sb.append(column.getFunction());
sb.append("(");
if(!ORMUtils.isEmpty(column.getAlias())){
sb.append(column.getAlias() + ".");
}
sb.append(column.getName());
sb.append(")");
}
}else{
if(!ORMUtils.isEmpty(column.getType())){
String result = getColumnWithOperator(column);
sb.append(result);
}else{
String aliasName = column.getName();
if(!ORMUtils.isEmpty(column.getAlias())){
aliasName = column.getAlias() + "." + aliasName;
}
if(ORMUtils.isEmpty(column.getFormat())){
sb.append(aliasName);
}else{
if(column.getValue() != null && column.getValue().getClass().isArray()){
Object [] objectList = (Object[])column.getValue();
List