📄 xmltabcolumns.java
字号:
package com.icbcsdc.ddlexp.pub.xml.nodeinfo;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.util.ArrayList;
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 XMLTabColumns extends XMLNode {
public static final String NAME="Columns";
String crComparedTabColumns="SELECT SRC_COLUMN_NAME,ATTR_NAME,SRC_ATTR_VALUE,DST_COLUMN_NAME FROM COMPARE_TAB_COLUMNS WHERE SRC_OWNER=? AND SRC_TABLE_NAME=? AND ATTR_NAME='MYSTYLE'";
String upComparedTabColumns="SELECT SRC_COLUMN_NAME,ATTR_NAME,SRC_ATTR_VALUE,DST_ATTR_VALUE FROM COMPARE_TAB_COLUMNS WHERE SRC_OWNER=? AND SRC_TABLE_NAME=? AND ATTR_NAME<>'MYSTYLE'";
public XMLTabColumns(){
this.name=NAME;
}
/**
* @see com.icbcsdc.ddlexp.pub.xml.nodeinfo.XMLNode#getType()
*/
public int getType() {
return XMLNode.XML_TABCOLUMNS;
}
/**
* @see com.icbcsdc.ddlexp.pub.xml.nodeinfo.XMLNode#chkChildType(XMLNode)
*/
public boolean chkChildType(XMLNode node) {
if(node.getType()==XMLNode.XML_TABCOLUMN) return true;
return false;
}
/**
* @see com.icbcsdc.ddlexp.pub.xml.nodeinfo.XMLNode#getSqlDDL()
*/
public String getSqlDDL() {
return null;
}
public void refreshDDLInfo()throws Exception{
ArrayList list=((XMLTable)this.getParent()).getColumns();
for(int i=0;i<list.size();i++){
XMLTabColumn col=(XMLTabColumn)list.get(i);
this.addChild(col);
}
}
/**从数据库中获取数据对象比较后的结果*/
public void refreshChangedProperties()throws Exception{
JDBCPool cnn=null;
//try {
//XMLManager.getInstance().
XMLDatabase db=this.getDatabase();
if(db!=null) cnn = db.getConnPool();
else return;
//先创建比较节点
Logger.log(Logger.INFO,"refreshChangedProperties:"+this.crComparedTabColumns);
PreparedStatement pStmt=cnn.prepareStatement(crComparedTabColumns);
pStmt.setString(1,this.getSchema().getName().toUpperCase());
pStmt.setString(2,this.getParent().getName().toUpperCase());
ResultSet rsCrTabCols=pStmt.executeQuery();
while(rsCrTabCols.next()){
XMLTabColumn col=null;
byte status=XMLNode.toCompareStatus(rsCrTabCols.getString("SRC_ATTR_VALUE"));
if(status==XMLNode.SRC_NULL_DST_EXIST)
col=new XMLTabColumn(rsCrTabCols.getString("DST_COLUMN_NAME"));
else
col=new XMLTabColumn(rsCrTabCols.getString("SRC_COLUMN_NAME"));
Logger.log(Logger.INFO,col.getName()+"/"+col);
col.setCompareStatus(status);
Logger.log(Logger.INFO,col.getName()+"/"+col);
this.addChild(col);
}
rsCrTabCols.close();
//再修改比较节点
pStmt=cnn.prepareStatement(upComparedTabColumns);
pStmt.setString(1,this.getSchema().getName().toUpperCase());
pStmt.setString(2,this.getParent().getName().toUpperCase());
ResultSet rsUpTabColumns=pStmt.executeQuery();
while(rsUpTabColumns.next()){
XMLTabColumn col1=(XMLTabColumn)this.getDirectChildren(XMLNode.XML_TABCOLUMN,rsUpTabColumns.getString("SRC_COLUMN_NAME"));
col1.putChangedProperty(rsUpTabColumns.getString("ATTR_NAME"),rsUpTabColumns.getString("SRC_ATTR_VALUE"),rsUpTabColumns.getString("DST_ATTR_VALUE"));
}
rsUpTabColumns.close();
pStmt.close();
}
/**
* @see com.icbcsdc.ddlexp.pub.xml.nodeinfo.XMLNode#refresh()
*/
public void refresh() throws Exception{
refreshNodeNeedAccessDB();
super.refresh();
}
}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -