📄 xmlpackages.java
字号:
package com.icbcsdc.ddlexp.pub.xml.nodeinfo;
import java.io.InputStream;
import java.sql.CallableStatement;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import com.icbcsdc.ddlexp.pub.staticLog.Logger;
import com.icbcsdc.ddlexp.pub.connectionpool.JDBCCnn;
import com.icbcsdc.ddlexp.pub.connectionpool.JDBCPool;
import com.icbcsdc.ddlexp.pub.connectionpool.JDBCPoolManager;
/**
* @author zhangyc
*
* To change this generated comment edit the template variable "typecomment":
* Window>Preferences>Java>Templates.
* To enable and disable the creation of type comments go to
* Window>Preferences>Java>Code Generation.
*/
public class XMLPackages extends XMLNode {
public static String NAME="Packages";
//private String sqlPackages = "select name,line,text from DBA_SOURCE where type like 'PACKAGE' and owner=? order by name,line";
private String sqlPackages = "select name, MAX(LINE) from DBA_SOURCE where type= 'PACKAGE' and owner=? GROUP by name";
private String sqlPackagesWrapped="select name from DBA_SOURCE where type='PACKAGE' and line=1 and owner=? and text like '% wrapped%'";
String crComparedPackages="SELECT SRC_PACKAGE_NAME,ATTR_NAME,SRC_ATTR_VALUE,DST_PACKAGE_NAME FROM COMPARE_PACKAGES WHERE SRC_OWNER=? AND ATTR_NAME='MYSTYLE'";
String upComparedPackages="SELECT SRC_PACKAGE_NAME,ATTR_NAME,SRC_ATTR_VALUE,DST_ATTR_VALUE FROM COMPARE_PACKAGES WHERE SRC_OWNER=? AND ATTR_NAME<>'MYSTYLE'";
//String rsComparedPackageLines="SELECT SRC_LINE,ATTR_NAME,SRC_ATTR_VALUE,DST_ATTR_VALUE FROM COMPARE_PACKAGE_LINES WHERE SRC_OWNER=? AND SRC_PACKAGE_NAME=? AND ATTR_NAME<>'MYSTYLE'";
private String text = "";
private String packName = "";
private boolean wrapped = false;
/**
* Constructor for XMLManager.
*/
public XMLPackages() {
super();
this.name=NAME;
this.setParent(null);
}
/**
* @see com.icbcsdc.ddlexp.pub.xml.nodeinfo.XMLNode#getType()
*/
public int getType() {
return XMLNode.XML_PACKAGES;
}
/**从数据库中获取数据对象比较后的结果*/
public void refreshChangedProperties() throws Exception{
JDBCPool cnn=null;
//try {
//XMLManager.getInstance().
XMLDatabase db=this.getDatabase();
if(db!=null) cnn = db.getConnPool();
else return;
//先创建比较节点
PreparedStatement pStmt=cnn.prepareStatement(crComparedPackages);
pStmt.setString(1,this.getSchema().getName().toUpperCase());
ResultSet rsCrPackages=pStmt.executeQuery();
while(rsCrPackages.next()){
XMLPackage Package=null;
byte status=XMLNode.toCompareStatus(rsCrPackages.getString("SRC_ATTR_VALUE"));
if(status==XMLNode.SRC_NULL_DST_EXIST)
Package=new XMLPackage(rsCrPackages.getString("DST_PACKAGE_NAME"));
else
Package=new XMLPackage(rsCrPackages.getString("SRC_PACKAGE_NAME"));
Package.setCompareStatus(status);
this.addChild(Package);
}
rsCrPackages.close();
//再修改比较节点
pStmt=cnn.prepareStatement(upComparedPackages);
pStmt.setString(1,this.getSchema().getName().toUpperCase());
ResultSet rsUpPackages=pStmt.executeQuery();
while(rsUpPackages.next()){
XMLPackage Package1=(XMLPackage)this.getDirectChildren(XMLNode.XML_PACKAGE,rsUpPackages.getString("SRC_PACKAGE_NAME"));
Package1.putChangedProperty(rsUpPackages.getString("ATTR_NAME"),rsUpPackages.getString("SRC_ATTR_VALUE"),rsUpPackages.getString("DST_ATTR_VALUE"));
}
rsUpPackages.close();
pStmt.close();
}
/**从数据库中获取数据对象定义*/
public void refreshDDLInfo() throws Exception{
JDBCPool cnn=null;
//try {
XMLDatabase db=this.getDatabase();
if(db!=null)
cnn = db.getConnPool();
else return;
/**
if(db.getVersion() == XMLDatabase.VERSION_ORACLE8I){
String sqlGenDDL = "BEGIN GEN_PKG_DDL(?); END;";
CallableStatement cStmt = cnn.prepareCall(sqlGenDDL);
cStmt.setString(1,this.getSchema().name);
cStmt.execute();
}**/
//获取Package列表
PreparedStatement pStmt=cnn.prepareStatement(this.sqlPackages);
pStmt.setString(1,this.getParent().getParent().getName().toUpperCase());
ResultSet rsPackages=pStmt.executeQuery();
while(rsPackages.next()){
XMLPackage pack=new XMLPackage(rsPackages.getString(1).trim());
if(rsPackages.getInt(2)>XMLNode.MAX_SOURCE_LINES)
pack.setOverflow(true);
this.addChild(pack);
}
pStmt.close();
rsPackages.close();
PreparedStatement pStmt1=cnn.prepareStatement(this.sqlPackagesWrapped);
pStmt1.setString(1,this.getParent().getParent().getName().toUpperCase());
ResultSet rsPackagesWapped=pStmt1.executeQuery();
while(rsPackagesWapped.next()){
XMLPackage pack=(XMLPackage)this.getDirectChildren(XMLNode.XML_PACKAGE,rsPackagesWapped.getString(1).trim());
pack.setWrapped(true);
}
pStmt1.close();
rsPackagesWapped.close();
}
/**
* @see com.icbcsdc.ddlexp.pub.xml.nodeinfo.XMLNode#refresh()
*/
public void refresh() throws Exception{
refreshNodeNeedAccessDB();
super.refresh();
}
/**
* @see com.icbcsdc.ddlexp.pub.xml.nodeinfo.XMLNode#chkChildType(XMLNode)
*/
public boolean chkChildType(XMLNode node) {
if(node.getType()==XMLNode.XML_PACKAGE) return true;
return false;
}
/**
* @see com.icbcsdc.ddlexp.pub.xml.nodeinfo.XMLNode#getXmlStream()
public InputStream getXmlStream() {
return null;
}
*/
/**
* @see com.icbcsdc.ddlexp.pub.xml.nodeinfo.XMLNode#getSqlDDL()
*/
public String getSqlDDL() {
return null;
}
public static void main(String[] args) {
}
}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -