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

com.centit.support.database.ddl.OracleDDLOperations Maven / Gradle / Ivy

package com.centit.support.database.ddl;

import java.sql.Connection;
import java.util.ArrayList;
import java.util.List;

import com.centit.support.database.QueryUtils;
import com.centit.support.database.metadata.SimpleTableField;
import com.centit.support.database.metadata.TableField;

public class OracleDDLOperations extends GeneralDDLOperations implements DDLOperations {
	
	public OracleDDLOperations(){
		
	}
	
	public OracleDDLOperations(Connection conn) {
		super(conn);
	}
	
	@Override
	public String makeCreateSequenceSql(final String sequenceName){
		return "create sequence " + QueryUtils.cleanSqlStatement(sequenceName);
	}
	
	@Override
	public String makeAddColumnSql(final String tableCode, final TableField column){
		StringBuilder sbsql = new StringBuilder("alter table ");
		sbsql.append(tableCode);
		sbsql.append(" add ");
		appendColumnSQL(column,sbsql);
		return sbsql.toString();
	}
	
	@Override
	public List makeReconfigurationColumnSqls(final String tableCode, final String columnCode, final TableField column){
		List sqls = new ArrayList();
		SimpleTableField tempColumn = new SimpleTableField();
		tempColumn.setColumnName(columnCode+"_1");
		sqls.add(makeRenameColumnSql(tableCode, columnCode, tempColumn));
		sqls.add(makeAddColumnSql(tableCode, column));
		
		if("String".equals(column.getJavaType()))
			sqls.add("update "+tableCode+" set "+ column.getColumnName() + " = to_char(" + columnCode+")");
		if("Date".equals(column.getJavaType()))
			sqls.add("update "+tableCode+" set "+ column.getColumnName() + " = to_date(" + columnCode+")");
		if("Long".equals(column.getJavaType()) || "Double".equals(column.getJavaType()))
			sqls.add("update "+tableCode+" set "+ column.getColumnName() + " = to_number(" + columnCode+")");
		
		sqls.add(makeDropColumnSql(tableCode, columnCode+"_1"));
		return sqls;
	}
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy