Package org.exoplatform.services.database

Source Code of org.exoplatform.services.database.QueryBuilder

/*
* Copyright (C) 2009 eXo Platform SAS.
*
* This is free software; you can redistribute it and/or modify it
* under the terms of the GNU Lesser General Public License as
* published by the Free Software Foundation; either version 2.1 of
* the License, or (at your option) any later version.
*
* This software is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public
* License along with this software; if not, write to the Free
* Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
* 02110-1301 USA, or see the FSF site: http://www.fsf.org.
*/
package org.exoplatform.services.database;

import org.exoplatform.services.database.annotation.Query;
import org.exoplatform.services.database.annotation.Table;
import org.exoplatform.services.database.annotation.TableField;

import java.lang.reflect.Method;
import java.util.List;

/**
* Created by The eXo Platform SAS
* Author : Nhu Dinh Thuan nhudinhthuan@exoplatform.com Mar 30, 2007
*/
public class QueryBuilder
{

   private int databaseType = ExoDatasource.STANDARD_DB_TYPE;

   public QueryBuilder()
   {
   }

   public QueryBuilder(int dbType)
   {
      databaseType = dbType;
   }

   public <T extends DBObject> String createSelectQuery(Class<T> type, long id) throws Exception
   {
      Table table = type.getAnnotation(Table.class);
      TableField[] fields = table.field();

      StringBuilder query = new StringBuilder("SELECT ");
      for (int i = 0; i < fields.length; i++)
      {
         TableField field = fields[i];
         query.append(field.name());
         if (i != fields.length - 1)
            query.append(", ");
      }
      query.append(" FROM ").append(table.name());
      if (id > -1)
         query.append(" WHERE ID = ").append(id);
      return query.toString();
   }

   public <T extends DBObject> String createUpdateQuery(Class<T> type) throws Exception
   {
      Table table = type.getAnnotation(Table.class);
      TableField[] fields = table.field();

      StringBuilder query = new StringBuilder("UPDATE ").append(table.name()).append(" SET ");
      for (int i = 0; i < fields.length; i++)
      {
         TableField field = fields[i];
         query.append(field.name()).append(" = '$").append(field.name()).append('\'');
         if (i != fields.length - 1)
            query.append(", ");
         else
            query.append(" WHERE ID = $id");
      }
      return query.toString();
   }

   public <T extends DBObject> String createInsertQuery(Class<T> type) throws Exception
   {
      Table table = type.getAnnotation(Table.class);
      TableField[] fields = table.field();

      StringBuilder query = new StringBuilder("INSERT INTO ").append(table.name()).append("(ID, ");
      for (int i = 0; i < fields.length; i++)
      {
         TableField field = fields[i];
         query.append(field.name());
         if (i != fields.length - 1)
            query.append(", ");
         else
            query.append(") VALUES($id, ");
      }

      for (int i = 0; i < fields.length; i++)
      {
         query.append("'$").append(fields[i].name()).append('\'');
         if (i != fields.length - 1)
            query.append(", ");
         else
            query.append(")");
      }
      return query.toString();
   }

   public <T extends DBObject> String createUpdateQuery(Class<T> type, long id) throws Exception
   {
      Table table = type.getAnnotation(Table.class);
      TableField[] fields = table.field();

      StringBuilder query = new StringBuilder("UPDATE ").append(table.name()).append(" SET ");
      for (int i = 0; i < fields.length; i++)
      {
         TableField field = fields[i];
         query.append(field.name()).append(" = ?");
         if (i != fields.length - 1)
            query.append(", ");
         else
            query.append(" WHERE ID = ").append(id);
      }

      return query.toString();
   }

   public <T extends DBObject> String createInsertQuery(Class<T> clazz, long id) throws Exception
   {
      Table table = clazz.getAnnotation(Table.class);
      TableField[] fields = table.field();

      StringBuilder query = new StringBuilder("INSERT INTO ").append(table.name()).append("(ID, ");
      for (int i = 0; i < fields.length; i++)
      {
         TableField field = fields[i];
         query.append(field.name());
         if (i != fields.length - 1)
            query.append(", ");
      }
      query.append(") VALUES(").append(id).append(", ");

      for (int i = 0; i < fields.length; i++)
      {
         query.append("?");
         if (i != fields.length - 1)
            query.append(", ");
         else
            query.append(")");
      }
      return query.toString();
   }

   public <T extends DBObject> String createRemoveQuery(Class<T> type, long id) throws Exception
   {
      Table table = type.getAnnotation(Table.class);
      StringBuilder builder = new StringBuilder("DELETE FROM ");
      builder.append(table.name()).append(" WHERE ID = ").append(id).toString();
      return builder.toString();
   }

   public <T extends DAO<?>> String getQuery(Class<T> clazz, String name) throws Exception
   {
      Query query = clazz.getAnnotation(Query.class);
      String value = null;
      if (query != null && query.name().equals(name))
         value = getQuery(query);
      if (value != null)
         return value;
      List<Method> list = ReflectionUtil.getMethod(clazz, name);
      for (Method method : list)
      {
         query = method.getAnnotation(Query.class);
         if (query != null && query.name().equals(name))
            value = getQuery(query);
         if (value != null)
            return value;
      }
      return null;
   }

   private String getQuery(Query query)
   {
      switch (databaseType)
      {
         case ExoDatasource.STANDARD_DB_TYPE :
            return query.standardSQL();
         case ExoDatasource.HSQL_DB_TYPE :
            if (query.hsqlSQL().length() > 0)
               return query.hsqlSQL();
         case ExoDatasource.MYSQL_DB_TYPE :
            if (query.mysqlSQL().length() > 0)
               return query.mysqlSQL();
         case ExoDatasource.MSSQL_DB_TYPE :
            if (query.mssqlSQL().length() > 0)
               return query.mssqlSQL();
         case ExoDatasource.ORACLE_DB_TYPE :
            if (query.oracleSQL().length() > 0)
               return query.oracleSQL();
         case ExoDatasource.DB2_DB_TYPE :
            if (query.db2SQL().length() > 0)
               return query.db2SQL();
         case ExoDatasource.DERBY_DB_TYPE :
            if (query.derbySQL().length() > 0)
               return query.derbySQL();
         case ExoDatasource.POSTGRES_DB_TYPE :
            if (query.postgresSQL().length() > 0)
               return query.postgresSQL();
         case ExoDatasource.SYSBASE_DB_TYPE :
            if (query.sysbaseSQL().length() > 0)
               return query.sysbaseSQL();
         default :
            return query.standardSQL();
      }
   }

   public String mapDataToSql(String template, String[][] parameters) throws Exception
   {
      StringBuilder builder = new StringBuilder();
      int i = 0;
      int start = 0;
      while (i < template.length())
      {
         if (template.charAt(i) != '$')
         {
            i++;
            continue;
         }

         if (i > 0 && template.charAt(i - 1) == '\\')
         {
            builder.append(template.subSequence(start, i - 1));
            start = i;
            i++;
            continue;
         }

         if (i == template.length() - 1)
            break;

         int j = i + 1;
         while (j < template.length())
         {
            if (Character.isWhitespace(template.charAt(j)))
               break;
            if (template.charAt(j) == '\'' && template.charAt(j - 1) != '\\')
               break;
            if (template.charAt(j) == ',' && template.charAt(j - 1) != '\\')
               break;
            j++;
         }
         String name = template.substring(i + 1, j);
         start = replace(template, builder, parameters, name, start, i);
         i++;
      }
      if (start > 0 && start < template.length())
      {
         builder.append(template.subSequence(start, template.length()));
      }
      if (builder.length() < 1)
         return template.toString();
      return builder.toString();
   }

   private int replace(String template, StringBuilder builder, String[][] parameters, String name, int start,
      int current) throws Exception
   {
      for (int k = 0; k < parameters.length; k++)
      {
         if (!parameters[k][0].equals(name))
            continue;
         builder.append(template.subSequence(start, current)).append(parameters[k][1]);
         return current + 1 + name.length();
      }
      return start;
   }

   public String encode(CharSequence seq)
   {
      if (seq.length() < 1)
         return seq.toString();
      StringBuilder builder = new StringBuilder();
      int i = 0;
      int start = 0;
      while (i < seq.length())
      {
         if (seq.charAt(i) == '\'')
         {
            builder.append(seq.subSequence(start, i)).append("''");
            start = i + 1;
         }
         i++;
      }
      if (start > 0 && start < seq.length())
      {
         builder.append(seq.subSequence(start, seq.length()));
      }
      if (builder.length() < 1)
         return seq.toString();
      return builder.toString();
   }

}
TOP

Related Classes of org.exoplatform.services.database.QueryBuilder

TOP
Copyright © 2018 www.massapi.com. All rights reserved.
All source code are property of their respective owners. Java is a trademark of Sun Microsystems, Inc and owned by ORACLE Inc. Contact coftware#gmail.com.