org.springframework.data.cassandra.core.cql.generator.CreateTableCqlGenerator Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of spring-data-cassandra Show documentation
Show all versions of spring-data-cassandra Show documentation
Cassandra support for Spring Data
/*
* Copyright 2013-2018 the original author or authors.
*
* 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.springframework.data.cassandra.core.cql.generator;
import static org.springframework.data.cassandra.core.cql.PrimaryKeyType.*;
import java.util.ArrayList;
import java.util.List;
import java.util.Map;
import org.springframework.data.cassandra.core.cql.keyspace.ColumnSpecification;
import org.springframework.data.cassandra.core.cql.keyspace.CreateTableSpecification;
import org.springframework.data.cassandra.core.cql.keyspace.Option;
import org.springframework.data.cassandra.core.cql.keyspace.TableSpecification;
import org.springframework.util.StringUtils;
/**
* CQL generator for generating a {@code CREATE TABLE} statement.
*
* @author Matthew T. Adams
* @author Alex Shvid
* @author Mark Paluch
*/
public class CreateTableCqlGenerator extends TableOptionsCqlGenerator> {
public CreateTableCqlGenerator(CreateTableSpecification specification) {
super(specification);
}
public static String toCql(CreateTableSpecification specification) {
return new CreateTableCqlGenerator(specification).toCql();
}
/* (non-Javadoc)
* @see org.springframework.data.cassandra.core.cql.generator.TableOptionsCqlGenerator#spec()
*/
@Override
protected CreateTableSpecification spec() {
return (CreateTableSpecification) super.spec();
}
@Override
public StringBuilder toCql(StringBuilder cql) {
preambleCql(cql);
columnsAndOptionsCql(cql);
cql.append(";");
return cql;
}
private void preambleCql(StringBuilder cql) {
cql.append("CREATE TABLE ").append(spec().getIfNotExists() ? "IF NOT EXISTS " : "").append(spec().getName());
}
@SuppressWarnings("unchecked")
private void columnsAndOptionsCql(StringBuilder cql) {
// begin columns
cql.append(" (");
List partitionKeys = new ArrayList<>();
List clusterKeys = new ArrayList<>();
for (ColumnSpecification col : spec().getColumns()) {
col.toCql(cql).append(", ");
if (col.getKeyType() == PARTITIONED) {
partitionKeys.add(col);
} else if (col.getKeyType() == CLUSTERED) {
clusterKeys.add(col);
}
}
// begin primary key clause
cql.append("PRIMARY KEY (");
if (partitionKeys.size() > 1) {
// begin partition key clause
cql.append("(");
}
appendColumnNames(cql, partitionKeys);
if (partitionKeys.size() > 1) {
cql.append(")");
// end partition key clause
}
if (!clusterKeys.isEmpty()) {
cql.append(", ");
}
appendColumnNames(cql, clusterKeys);
cql.append(")");
// end primary key clause
cql.append(")");
// end columns
StringBuilder ordering = createOrderingClause(clusterKeys);
// begin options
// begin option clause
Map options = spec().getOptions();
if (!options.isEmpty() || StringUtils.hasText(ordering)) {
// option preamble
boolean first = true;
cql.append(" WITH ");
// end option preamble
if (StringUtils.hasText(ordering)) {
cql.append(ordering);
first = false;
}
if (!options.isEmpty()) {
for (String name : options.keySet()) {
// append AND if we're not on first option
if (first) {
first = false;
} else {
cql.append(" AND ");
}
// append =
cql.append(name);
Object value = options.get(name);
if (value == null) { // then assume string-only, valueless option like "COMPACT STORAGE"
continue;
}
cql.append(" = ");
if (value instanceof Map) {
optionValueMap((Map