📄 xmlarraytypes.java
字号:
package com.icbcsdc.ddlexp.pub.xml.nodeinfo;
import java.io.InputStream;
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.JDBCException;
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 XMLArrayTypes extends XMLNode {
String sqlFunctions = "select type_name,upper_bound,elem_type_name from DBA_COLL_TYPES where coll_type='VARYING ARRAY' and owner=? order by type_name";
String crComparedSql="SELECT SRC_TYPE_NAME,ATTR_NAME,SRC_ATTR_VALUE FROM COMPARE_COLL_TYPES WHERE SRC_OWNER=? AND ATTR_NAME='MYSTYLE' AND SRC_TYPE_TYPE='ARRAY'";
String upComparedSql="SELECT SRC_TYPE_NAME,ATTR_NAME,SRC_ATTR_VALUE,DST_ATTR_VALUE FROM COMPARE_COLL_TYPES WHERE SRC_OWNER=? AND ATTR_NAME<>'MYSTYLE' AND SRC_TYPE_TYPE='ARRAY'";
public static String NAME="Array Types";
private String upperBound = "";
private String typeName = "";
private String elemType = "";
/**
* Constructor for XMLManager.
*/
public XMLArrayTypes() {
super();
this.name=NAME;
// this.setParent(null);
}
/**
* @see com.icbcsdc.ddlexp.pub.xml.nodeinfo.XMLNode#getType()
*/
public int getType() {
return XMLNode.XML_ARRAYTYPES;
}
/**
* @see com.icbcsdc.ddlexp.pub.xml.nodeinfo.XMLNode#refresh()
*/
public void refresh() throws Exception{
refreshNodeNeedAccessDB();
super.refresh();
}
/**
* 从数据库中获取数据对象比较后的结果
* */
public void refreshChangedProperties() throws Exception{
JDBCPool cnn=null;
//try {
XMLDatabase db=this.getDatabase();
if(JDBCPoolManager.getInstance().isDebug())
System.out.println(this.getClass().toString());
if(db!=null) cnn = db.getConnPool();
else return;
//先创建比较节点
PreparedStatement pStmt=cnn.prepareStatement(crComparedSql);
pStmt.setString(1,this.getSchema().name.toUpperCase());
ResultSet rsCrArrayTypes=pStmt.executeQuery();
while(rsCrArrayTypes.next()){
XMLArrayType ArrayType0=null;
byte status=XMLNode.toCompareStatus(rsCrArrayTypes.getString("SRC_ATTR_VALUE"));
if(status==XMLNode.SRC_NULL_DST_EXIST)
ArrayType0=new XMLArrayType(rsCrArrayTypes.getString("DST_TYPE_NAME"));
else
ArrayType0=new XMLArrayType(rsCrArrayTypes.getString("SRC_TYPE_NAME"));
ArrayType0.setCompareStatus(status);
this.addChild(ArrayType0);
}
rsCrArrayTypes.close();
//再修改比较节点
pStmt=cnn.prepareStatement(upComparedSql);
pStmt.setString(1,this.getSchema().name.toUpperCase());
ResultSet rsUpArrayTypes=pStmt.executeQuery();
while(rsUpArrayTypes.next()){
XMLArrayType ArrayType1=(XMLArrayType)this.getDirectChildren(XMLNode.XML_ARRAYTYPE,rsUpArrayTypes.getString("SRC_TYPE_NAME"));
ArrayType1.putChangedProperty(rsUpArrayTypes.getString("ATTR_NAME"),rsUpArrayTypes.getString("SRC_ATTR_VALUE"),rsUpArrayTypes.getString("DST_ATTR_VALUE"));
}
rsUpArrayTypes.close();
pStmt.close();
/**
} catch (Exception e) {
Logger.log(Logger.ERROR,e.getMessage());
}
**/
}
/**从数据库中获取数据对象定义*/
public void refreshDDLInfo() throws Exception{
JDBCPool cnn=null;
XMLDatabase db=this.getDatabase();
if(JDBCPoolManager.getInstance().isDebug())
System.out.println(this.getClass().toString());
if(db!=null)
cnn = db.getConnPool();
else return;
//获取Type列表
PreparedStatement pStmt=cnn.prepareStatement(this.sqlFunctions);
pStmt.setString(1,this.getParent().getParent().getName().toUpperCase());
ResultSet rsArrayTypes=pStmt.executeQuery();
while(rsArrayTypes.next()){
XMLArrayType type=new XMLArrayType(rsArrayTypes.getString(1),rsArrayTypes.getString(2),rsArrayTypes.getString(3));
type.setCompareStatus(ComparedNode.NO_COMPARED);
this.addChild(type);
}
pStmt.close();
rsArrayTypes.close();
}
/**
* @see com.icbcsdc.ddlexp.pub.xml.nodeinfo.XMLNode#chkChildType(XMLNode)
*/
public boolean chkChildType(XMLNode node) {
if(node.getType()==XMLNode.XML_ARRAYTYPE) 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 + -