Android Open Source - spades Sql Helper






From Project

Back to project page spades.

License

The source code is released under:

Apache License

If you think the Android project spades listed in this page is inappropriate, such as containing malicious code/tools or violating the copyright, please email info at java2s dot com, thanks.

Java Source Code

/**
 * Copyright (C) 2013 Pau Picas Sans <pau.picas@gmail.com>
 *//from  ww w. j av a 2  s  .  c o m
 * 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 cat.picas.spades;

import static android.text.TextUtils.join;
import cat.picas.spades.query.NameMapper;
import android.text.TextUtils;

public class SqlHelper {

  private static final NameMapper sMapper = new NameMapper();

  public static String table(Table table) {
    return table.name + " AS " + sMapper.alias(table);
  }

  public static String column(Column col) {
    return sMapper.ref(col);
  }

  public static String expr(Column col, String exp) {
    return String.format("%s %s", sMapper.ref(col), exp);
  }

  public static String expr(String expr, Column... cols) {
    return String.format(expr, (Object[]) sMapper.refs(cols));
  }

  public static String and(Iterable<String> exprs) {
    return "(" + join(" AND ", exprs) + ")";
  }

  public static String and(String... exprs) {
    return "(" + join(" AND ", exprs) + ")";
  }

  public static String or(Iterable<String> exprs) {
    return "(" + join(" OR ", exprs) + ")";
  }

  public static String or(String... exprs) {
    return "(" + join(" OR ", exprs) + ")";
  }

  public static String createTable(String tableName, String... colDefs) {
    StringBuilder sql = new StringBuilder();
    sql.append("CREATE TABLE IF NOT EXISTS ").append(tableName).append("(\n");
    sql.append(TextUtils.join(",\n", colDefs));
    sql.append(")");

    return sql.toString();
  }

  public static String createIndex(String indexName, boolean unique, String tableName,
      String... colDefs) {
    StringBuilder sql = new StringBuilder();
    if (unique) {
      sql.append("CREATE UNIQUE INDEX IF NOT EXISTS ");
    } else {
      sql.append("CREATE INDEX IF NOT EXISTS ");
    }
    sql.append(indexName).append(" ON ").append(tableName).append("(\n");
    sql.append(TextUtils.join(",\n", colDefs));
    sql.append(")");

    return sql.toString();
  }

  public static String alterTableAddColumn(String tableName, String colDef) {
    StringBuilder sql = new StringBuilder();
    sql.append("ALTER TABLE ").append(tableName).append(" ");
    sql.append("ADD COLUMN ").append(colDef);

    return sql.toString();
  }

  public static String renameTable(String tableName, String newTableName) {
    StringBuilder sql = new StringBuilder();
    sql.append("ALTER TABLE ").append(tableName).append(" ");
    sql.append("RENAME TO ").append(newTableName);

    return sql.toString();
  }

  public static String dropTable(String tableName) {
    return "DROP TABLE IF EXISTS " + tableName;
  }

  public static String dropIndex(String indexName) {
    return "DROP INDEX IF EXISTS " + indexName;
  }

}




Java Source Code List

cat.picas.spades.AbstractEntity.java
cat.picas.spades.AutoEntityMapper.java
cat.picas.spades.ColumnBuilder.java
cat.picas.spades.Column.java
cat.picas.spades.CursorInfoBuilder.java
cat.picas.spades.CursorInfo.java
cat.picas.spades.Dao.java
cat.picas.spades.EntityMapper.java
cat.picas.spades.Entity.java
cat.picas.spades.RelatedChild.java
cat.picas.spades.RelatedList.java
cat.picas.spades.RelatedParent.java
cat.picas.spades.SqlHelper.java
cat.picas.spades.Table.java
cat.picas.spades.Tables.java
cat.picas.spades.fetch.ArrayListFetchStrategy.java
cat.picas.spades.fetch.FetchStrategy.java
cat.picas.spades.fetch.HashMapFetchStrategy.java
cat.picas.spades.map.BooleanMapper.java
cat.picas.spades.map.DateMapper.java
cat.picas.spades.map.DoubleMapper.java
cat.picas.spades.map.EnumMapper.java
cat.picas.spades.map.IntegerMapper.java
cat.picas.spades.map.LongMapper.java
cat.picas.spades.map.MappedFieldFactory.java
cat.picas.spades.map.MappedField.java
cat.picas.spades.map.RelatedParentMapper.java
cat.picas.spades.map.StringMapper.java
cat.picas.spades.map.ValueMapper.java
cat.picas.spades.query.ColumnSelector.java
cat.picas.spades.query.NameMapper.java
cat.picas.spades.query.Query.java
cat.picas.spades.query.SelectedColumn.java
cat.picas.spades.util.ReflectionUtils.java
cat.picas.spadessamples.AliasTableActivity.java
cat.picas.spadessamples.ArrayListActivity.java
cat.picas.spadessamples.CursorListActivity.java
cat.picas.spadessamples.MainActivity.java
cat.picas.spadessamples.PersonDetailActivity.java
cat.picas.spadessamples.adapter.CouplesCursorAdapter.java
cat.picas.spadessamples.adapter.PersonArrayAdapter.java
cat.picas.spadessamples.adapter.PersonCursorAdapter.java
cat.picas.spadessamples.model.ContactPointDao.java
cat.picas.spadessamples.model.ContactPoint.java
cat.picas.spadessamples.model.DatabaseHelper.java
cat.picas.spadessamples.model.FixturesHelper.java
cat.picas.spadessamples.model.PersonDao.java
cat.picas.spadessamples.model.Person.java
cat.picas.spadessamples.model.inheritance.HotelDao.java
cat.picas.spadessamples.model.inheritance.Hotel.java
cat.picas.spadessamples.model.inheritance.PlaceDao.java
cat.picas.spadessamples.model.inheritance.Place.java
cat.picas.spadessamples.model.inheritance.RestaurantDao.java
cat.picas.spadessamples.model.inheritance.Restaurant.java