|
|
|
@ -13,9 +13,6 @@ import com.platform.utils.Configs;
|
|
|
|
|
import com.platform.utils.FileOperateHelper;
|
|
|
|
|
|
|
|
|
|
public class OracleExtractHelper {
|
|
|
|
|
|
|
|
|
|
private OracleConnector oConnector;
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* 判断dblink是否已经存在
|
|
|
|
|
*
|
|
|
|
@ -26,15 +23,15 @@ public class OracleExtractHelper {
|
|
|
|
|
*/
|
|
|
|
|
private boolean hasSameNameDBLink(Connection conn, String linkName) {
|
|
|
|
|
boolean flag = false;
|
|
|
|
|
String sql = "SELECT * FROM ALL_DB_LINKS WHERE DB_LINK=" + linkName;
|
|
|
|
|
ResultSet rSet = oConnector.getSQLExecResultSet(conn, sql);
|
|
|
|
|
String sql = "SELECT * FROM ALL_DB_LINKS WHERE DB_LINK='" + linkName +"'";
|
|
|
|
|
ResultSet rSet = OracleConnector.getSQLExecResultSet(conn, sql);
|
|
|
|
|
try {
|
|
|
|
|
rSet.last();
|
|
|
|
|
if (rSet.getRow() > 0)
|
|
|
|
|
flag = true;
|
|
|
|
|
} catch (Exception e) {
|
|
|
|
|
// TODO Auto-generated catch block
|
|
|
|
|
e.printStackTrace();
|
|
|
|
|
Configs.CONSOLE_LOGGER.info(e.getMessage());
|
|
|
|
|
}
|
|
|
|
|
return flag;
|
|
|
|
|
}
|
|
|
|
@ -54,22 +51,22 @@ public class OracleExtractHelper {
|
|
|
|
|
+ oc.getUser()
|
|
|
|
|
+ " IDENTIFIED BY "
|
|
|
|
|
+ oc.getPassword()
|
|
|
|
|
+ " USING '(DESCRIPTION =(ADDRESS_LIST =(ADDRESS = (PROTOCOL = TCP)(HOST = "
|
|
|
|
|
+ " USING \'(DESCRIPTION =(ADDRESS_LIST =(ADDRESS = (PROTOCOL = TCP)(HOST = "
|
|
|
|
|
+ oc.getIp() + ")(PORT = " + oc.getPort()
|
|
|
|
|
+ ")))(CONNECT_DATA =(SERVICE_NAME =" + oc.getDatabaseName()
|
|
|
|
|
+ ")))';";
|
|
|
|
|
if (null != oc) {
|
|
|
|
|
if (hasSameNameDBLink(conn, linkName)) { // 如果dblink已经存在,先删除dblink,在创建dblink
|
|
|
|
|
String deleteSql = "DROP PUBLIC DATABASE LINK LinkTo"
|
|
|
|
|
+ ")))\'";
|
|
|
|
|
if (null != oc) {
|
|
|
|
|
if (hasSameNameDBLink(conn, linkName)) { // 如果dblink已经存在,先删除dblink,在创建dblink
|
|
|
|
|
String deleteSql = "DROP PUBLIC DATABASE LINK "
|
|
|
|
|
+ linkName;
|
|
|
|
|
FileOperateHelper
|
|
|
|
|
.fileWrite(
|
|
|
|
|
Configs.EXTRACT_LOG_LOCALTION + oc.getName(),
|
|
|
|
|
deleteSql+"\r\n");
|
|
|
|
|
if (oConnector.execOracleSQL(conn, deleteSql)) {
|
|
|
|
|
if (OracleConnector.execOracleSQL(conn, deleteSql)) {
|
|
|
|
|
FileOperateHelper.fileWrite(Configs.EXTRACT_LOG_LOCALTION
|
|
|
|
|
+ oc.getName(), sql+"\r\n");
|
|
|
|
|
oConnector.execOracleSQL(conn, sql);
|
|
|
|
|
OracleConnector.execOracleSQL(conn, sql);
|
|
|
|
|
} else {
|
|
|
|
|
Configs.CONSOLE_LOGGER.error("删除已有的DBLink失败,无法创建新的DBLink!");
|
|
|
|
|
FileOperateHelper.fileWrite(Configs.EXTRACT_LOG_LOCALTION
|
|
|
|
@ -78,7 +75,9 @@ public class OracleExtractHelper {
|
|
|
|
|
|
|
|
|
|
} else {
|
|
|
|
|
// 否则,创建dblink
|
|
|
|
|
oConnector.execOracleSQL(conn, sql);
|
|
|
|
|
System.out.println("dblin不存在");
|
|
|
|
|
OracleConnector.execOracleSQL(conn, sql);
|
|
|
|
|
Configs.CONSOLE_LOGGER.error("创建DBLink!");
|
|
|
|
|
FileOperateHelper.fileWrite(
|
|
|
|
|
Configs.EXTRACT_LOG_LOCALTION + oc.getName(), sql);
|
|
|
|
|
}
|
|
|
|
@ -95,7 +94,7 @@ public class OracleExtractHelper {
|
|
|
|
|
public boolean createTableSpace(Connection conn, GatherOracleInfo oc) {
|
|
|
|
|
String tmpSql = "select TABLESPACE_NAME from dba_tablespaces where TABLESPACE_NAME = '"
|
|
|
|
|
+ Configs.GATHER_TABLESPACE_NAME + "'";
|
|
|
|
|
if (oConnector.execOracleSQL(conn, tmpSql)) {
|
|
|
|
|
if (OracleConnector.execOracleSQL(conn, tmpSql)) {
|
|
|
|
|
FileOperateHelper
|
|
|
|
|
.fileWrite(
|
|
|
|
|
Configs.EXTRACT_LOG_LOCALTION + oc.getName(),
|
|
|
|
@ -110,7 +109,7 @@ public class OracleExtractHelper {
|
|
|
|
|
.fileWrite(
|
|
|
|
|
Configs.EXTRACT_LOG_LOCALTION + oc.getName(),
|
|
|
|
|
sql+"\r\n");
|
|
|
|
|
return oConnector.execOracleSQL(conn, sql);
|
|
|
|
|
return OracleConnector.execOracleSQL(conn, sql);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
@ -127,13 +126,13 @@ public class OracleExtractHelper {
|
|
|
|
|
+ Configs.GATHER_TABLE_PASSWORD;
|
|
|
|
|
String grantSql = "grant connect, resource, dba to " + strTUser;
|
|
|
|
|
|
|
|
|
|
oConnector.execOracleSQL(conn, sql);
|
|
|
|
|
OracleConnector.execOracleSQL(conn, sql);
|
|
|
|
|
FileOperateHelper
|
|
|
|
|
.fileWrite(
|
|
|
|
|
Configs.EXTRACT_LOG_LOCALTION + oc.getName(),
|
|
|
|
|
sql+"\r\n");
|
|
|
|
|
|
|
|
|
|
oConnector.execOracleSQL(conn, grantSql);
|
|
|
|
|
OracleConnector.execOracleSQL(conn, grantSql);
|
|
|
|
|
FileOperateHelper
|
|
|
|
|
.fileWrite(
|
|
|
|
|
Configs.EXTRACT_LOG_LOCALTION + oc.getName(),
|
|
|
|
@ -158,7 +157,7 @@ public class OracleExtractHelper {
|
|
|
|
|
+ " t WHERE t.TABLESPACE_NAME NOT IN ('SYSTEM','SYSAUX')"
|
|
|
|
|
+ " and t.owner||t.table_name not in (select owner||table_name from dba_tables@linkTo"
|
|
|
|
|
+ oc.getName() + " where 'data_type'='CLOB')";
|
|
|
|
|
ResultSet rsSet = oConnector.getSQLExecResultSet(conn, sql);
|
|
|
|
|
ResultSet rsSet = OracleConnector.getSQLExecResultSet(conn, sql);
|
|
|
|
|
FileOperateHelper
|
|
|
|
|
.fileWrite(
|
|
|
|
|
Configs.EXTRACT_LOG_LOCALTION + oc.getName(),
|
|
|
|
@ -166,7 +165,7 @@ public class OracleExtractHelper {
|
|
|
|
|
try {
|
|
|
|
|
while (rsSet.next()) {
|
|
|
|
|
String resultSql = rsSet.getString(0);
|
|
|
|
|
oConnector.execOracleSQL(conn, resultSql);
|
|
|
|
|
OracleConnector.execOracleSQL(conn, resultSql);
|
|
|
|
|
FileOperateHelper
|
|
|
|
|
.fileWrite(
|
|
|
|
|
Configs.EXTRACT_LOG_LOCALTION + oc.getName(),
|
|
|
|
|