
com.centit.support.database.ddl.OracleDDLOperations Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of centit-database Show documentation
Show all versions of centit-database Show documentation
数据库操作通用方法和函数,从以前的util包中分离出来,并且整合了部分sys-module中的函数
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