All Downloads are FREE. Search and download functionalities are using the official Maven repository.

io.datarouter.client.mysql.ddl.domain.SqlColumn Maven / Gradle / Ivy

The newest version!
/*
 * Copyright © 2009 HotPads ([email protected])
 *
 * 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 io.datarouter.client.mysql.ddl.domain;

import java.util.Collection;
import java.util.Objects;
import java.util.Set;
import java.util.stream.Collectors;

import io.datarouter.gson.DatarouterGsons;

public class SqlColumn{

	private static final String NOT_NULL = " not null";
	private static final Set INTEGER_FIELD_TYPE_SET = Set.of(
			MysqlColumnType.BIGINT,
			MysqlColumnType.INT,
			MysqlColumnType.SMALLINT);

	private final String name;
	private final MysqlColumnType type;
	private Integer maxLength;
	private final Boolean nullable;
	private final Boolean autoIncrement;
	private final String defaultValue;

	//constructor that specifies the value to override the default value for the column
	public SqlColumn(
			String name,
			MysqlColumnType type,
			Integer maxLength,
			Boolean nullable,
			Boolean autoIncrement,
			String defaultValue){
		this.name = name;
		this.type = type;
		this.maxLength = maxLength;
		this.nullable = nullable;
		this.autoIncrement = autoIncrement;
		this.defaultValue = defaultValue;
	}

	public SqlColumn(String name, MysqlColumnType type, Integer maxLength, Boolean nullable, Boolean autoIncrement){
		this(name, type, maxLength, nullable, autoIncrement, null);
	}

	public SqlColumn(String name, MysqlColumnType type){
		this(name, type, null, true, false);
	}

	@Override
	public String toString(){
		return DatarouterGsons.withUnregisteredEnums().toJson(this);
	}

	@Override
	public SqlColumn clone(){
		return new SqlColumn(name, type, maxLength, nullable, autoIncrement, defaultValue);
	}

	@Override
	public boolean equals(Object otherObject){
		if(otherObject == this){
			return true;
		}
		if(!(otherObject instanceof SqlColumn other)){
			return false;
		}
		return Objects.equals(name, other.name)
				&& Objects.equals(type, other.type)
				&& Objects.equals(maxLength, other.maxLength)
				&& Objects.equals(nullable, other.nullable)
				&& Objects.equals(autoIncrement, other.autoIncrement)
				&& Objects.equals(defaultValue, other.defaultValue);
	}

	@Override
	public int hashCode(){
		return Objects.hash(name, type, maxLength, autoIncrement, defaultValue, nullable);
	}

	public String getName(){
		return name;
	}

	public MysqlColumnType getType(){
		return type;
	}

	public String getDefaultValue(){
		return defaultValue;
	}

	public Integer getMaxLength(){
		return maxLength;
	}

	public Boolean getNullable(){
		return nullable;
	}

	public final Boolean getAutoIncrement(){
		return autoIncrement;
	}

	public void setMaxLength(Integer length){
		this.maxLength = length;
	}

	public String getDefaultValueStatement(){
		String toReturn = "";
		if(!getNullable()){
			toReturn += NOT_NULL;
		}
		if(type.isDefaultValueSupported() && getDefaultValue() != null){
			toReturn += " default '" + getDefaultValue() + "'";
		}
		return toReturn;
	}

	public StringBuilder appendDataTypeDefinition(StringBuilder sb){
		sb.append(type.toString().toLowerCase());
		if(type.shouldSpecifyLength(maxLength)){
			sb.append("(").append(maxLength).append(")");
		}
		return sb;
	}

	public StringBuilder makeColumnDefinition(String prefix){
		StringBuilder sb = new StringBuilder(prefix).append(name).append(" ");
		appendDataTypeDefinition(sb);
		sb.append(getDefaultValueStatement());
		if(autoIncrement){
			sb.append(" auto_increment");
		}
		return sb;
	}

	public boolean isIntegerFieldType(){
		return INTEGER_FIELD_TYPE_SET.contains(type);
	}

	public record SqlColumnByName(
			SqlColumn sqlColumn){

		@Override
		public boolean equals(Object obj){
			return sqlColumn.getName().equals(((SqlColumnByName)obj).sqlColumn.getName());
		}

		@Override
		public int hashCode(){
			return sqlColumn.getName().hashCode();
		}

		public static Set wrap(Collection columns){
			return columns.stream()
					.map(SqlColumnByName::new)
					.collect(Collectors.toSet());
		}

	}

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy