--- FM2SQL/Attic/Convert.java 2004/01/08 11:03:12 1.4
+++ FM2SQL/Attic/Convert.java 2004/01/15 13:32:09 1.11
@@ -36,7 +36,6 @@ class Convert
//System.out.println(new String(b,"UTF-8"));
} catch (UnsupportedEncodingException e)
{
- // TODO Auto-generated catch block
e.printStackTrace();
}*/
FileOutputStream file = null;
@@ -51,7 +50,6 @@ class Convert
file = new FileOutputStream("./log.txt");
} catch (FileNotFoundException e1)
{
- // TODO Auto-generated catch block
e1.printStackTrace();
}
PrintStream stream= new PrintStream(file);
@@ -61,7 +59,7 @@ class Convert
System.out.println("Finished!");
//convert("jdbc:fmpro:http://141.14.237.74:8050","jdbc:postgresql://erebos/test",null,null);
}
- public static void convertBatch(DBBean source,DBBean destination,Vector names,Vector layouts,Vector selects,Vector creates) throws Exception
+ public static void convertBatch(DBBean source,DBBean destination,Vector names,Vector layouts,Vector selects,Vector creates,int mode) throws Exception
{
/*FM2SQL.ProgressDialog dialog = new FM2SQL.ProgressDialog(FM2SQL.fmInstance);
dialog.setTitle("Conversion running ...");
@@ -139,7 +137,7 @@ class Convert
// System.out.println(beanDest.getTableNames(beanDest.getCatalogs().get(2).toString()));
stm = beanDest.getConnection().createStatement();
// System.exit(0);
- if(true)
+ if(mode==Convert.DataBase.CONVERT_MODE)
{
if(tables.indexOf(names.get(tbIndex))>=0)
{
@@ -307,7 +305,7 @@ class Convert
- public static void convert(String source,String destination,Vector names,Vector layouts,Vector selects,Vector creates) throws Exception
+ public static void convert(String source,String destination,Vector names,Vector layouts,Vector selects,Vector creates,int mode) throws Exception
{
FM2SQL.ProgressDialog dialog = new FM2SQL.ProgressDialog(FM2SQL.fmInstance);
dialog.setTitle("Conversion running ...");
@@ -377,7 +375,7 @@ class Convert
// System.out.println(beanDest.getTableNames(beanDest.getCatalogs().get(2).toString()));
stm = beanDest.getConnection().createStatement();
// System.exit(0);
- if(true)
+ if(mode==Convert.DataBase.CONVERT_MODE)
{
if(tables.indexOf(names.get(tbIndex))>=0)
{
@@ -627,6 +625,8 @@ class Convert
alterMe.delete(j, j);
length--;
}
+ else
+ alterMe.setCharAt(j,'_');
}
++j;
@@ -786,7 +786,9 @@ class Convert
Vector layouts = new Vector();
Vector selects = new Vector();
Vector creates = new Vector();
-
+ Vector ids = new Vector();
+ int mode = -1;
+
try
{
Node tempNode = root.find("convert/source", new int[] { 1, 1 });
@@ -801,12 +803,14 @@ class Convert
layouts = new Vector();
selects = new Vector();
creates = new Vector();
-
+ ids = new Vector();
// parse dataBase
Node node = root.find("convert/source/database/url", new int[] { 1, 1, i, 1 });
Node node1 = root.find("convert/source/database/user", new int[] { 1, 1, i, 1, 1 });
Node node2 = root.find("convert/source/database/password", new int[] { 1, 1, i, 1, 1 });
Node node3 = root.find("convert/source/database", new int[] { 1, 1, i});
+ Node nodeMode = root.find("convert/source/database/mode/", new int[] {1, 1, i, 1,1});
+
if(node3== null) throw new Error("parse error database tag missing");
if(node==null) throw new Error("parse error url tag missing");
if(node1==null) throw new Error("parse error user tag missing");
@@ -819,7 +823,19 @@ class Convert
System.out.println(node.name + " " + node.getCharacters());
System.out.println(node1.name + " " + node1.getCharacters());
System.out.println(node2.name + " " + node2.getCharacters());
-
+ String modeString = "";
+ if (nodeMode == null)
+ modeString = "convert";
+ else
+ modeString = nodeMode.getCharacters();
+ if (modeString.equals("convert"))
+ mode = DataBase.CONVERT_MODE;
+ else
+ if (modeString.equals("append"))
+ mode = DataBase.APPEND_MODE;
+ else
+ if (modeString.equals("update"))
+ mode = DataBase.UPDATE_MODE;
// if(node3!=null)
// System.out.println(node3.name);
@@ -843,11 +859,15 @@ class Convert
// if(node6==null) throw new Error("parse error create tag missing");
String name = (String)node4.attributes.get("name");
String layout = (String)node4.attributes.get("layout");
+ String id = (String)node4.attributes.get("id");
+ System.out.println("id was "+id);
if(name==null) throw new Error("parse error required table tag attribute name missing");
if(layout==null) layout ="";
+ if(id==null) id = "";
if(name.equals("")) throw new Error("parse error table tag attribute must not be empty");
tables.add(name);
layouts.add(layout);
+ ids.add(id);
String query = (node5==null) ? "":node5.getCharacters();
if(query.equals("")) System.err.println("Warning empty select tag or select tag missing !!");
query = (query.equals("")) ? "select * from "+database.getQC()+name+database.getQC():query;
@@ -857,7 +877,7 @@ class Convert
creates.add("");
}
- databases.add(new DataBase(database, tables, layouts, selects,creates));
+ databases.add(new DataBase(database, tables, layouts, selects,creates,ids,mode));
}
DBBean database = new DBBean();
// parse dataBase
@@ -874,7 +894,7 @@ class Convert
for (Iterator iter = databases.iterator(); iter.hasNext();)
{
DataBase db = (DataBase) iter.next();
- convertBatch(db.bean,database,db.tables,db.layouts,db.selects,db.creates);
+ convertBatch(db.bean,database,db.tables,db.layouts,db.selects,db.creates,mode);
}
// printContents(node3);
@@ -1003,7 +1023,9 @@ class Convert
Vector layouts = new Vector();
Vector selects = new Vector();
Vector creates = new Vector();
-
+ Vector ids = new Vector();
+
+ int mode = -1;
try
{
Node tempNode = root.find("convert/source", new int[] { 1, 1 });
@@ -1018,12 +1040,14 @@ class Convert
layouts = new Vector();
selects = new Vector();
creates = new Vector();
-
+ ids = new Vector();
// parse dataBase
Node node = root.find("convert/source/database/url", new int[] { 1, 1, i, 1 });
Node node1 = root.find("convert/source/database/user", new int[] { 1, 1, i, 1, 1 });
Node node2 = root.find("convert/source/database/password", new int[] { 1, 1, i, 1, 1 });
Node node3 = root.find("convert/source/database", new int[] { 1, 1, i});
+ Node nodeMode = root.find("convert/source/database/mode", new int[] { 1, 1, i, 1, 1 });
+
if(node3== null) throw new Error("parse error database tag missing");
if(node==null) throw new Error("parse error url tag missing");
if(node1==null) throw new Error("parse error user tag missing");
@@ -1036,7 +1060,21 @@ class Convert
System.out.println(node.name + " " + node.getCharacters());
System.out.println(node1.name + " " + node1.getCharacters());
System.out.println(node2.name + " " + node2.getCharacters());
-
+ String modeString = "";
+ if (nodeMode == null)
+ modeString = "convert";
+ else
+ modeString = nodeMode.getCharacters();
+ if (modeString.equals("convert"))
+ mode = DataBase.CONVERT_MODE;
+ else
+ if (modeString.equals("append"))
+ mode = DataBase.APPEND_MODE;
+ else
+ if (modeString.equals("update"))
+ mode = DataBase.UPDATE_MODE;
+
+
// if(node3!=null)
// System.out.println(node3.name);
@@ -1060,11 +1098,16 @@ class Convert
// if(node6==null) throw new Error("parse error create tag missing");
String name = (String)node4.attributes.get("name");
String layout = (String)node4.attributes.get("layout");
+ String id = (String)node4.attributes.get("id");
+ System.out.println("id was "+id);
+
if(name==null) throw new Error("parse error required table tag attribute name missing");
if(layout==null) layout ="";
+ if(id == null) id="";
if(name.equals("")) throw new Error("parse error table tag attribute must not be empty");
tables.add(name);
layouts.add(layout);
+ ids.add(id);
String query = (node5==null) ? "":node5.getCharacters();
if(query.equals("")) System.err.println("Warning empty select tag or select tag missing !!");
query = (query.equals("")) ? "select * from "+database.getQC()+name+database.getQC():query;
@@ -1074,7 +1117,7 @@ class Convert
creates.add("");
}
- databases.add(new DataBase(database, tables, layouts, selects,creates));
+ databases.add(new DataBase(database, tables, layouts, selects,creates,ids,mode));
}
DBBean database = new DBBean();
// parse dataBase
@@ -1087,7 +1130,7 @@ class Convert
System.out.println(url);
database.setURL(url.trim());
database.setUserAndPasswd(user.trim(), password.trim());
- databases.add(new DataBase(database,null,null,null,null));
+ databases.add(new DataBase(database,null,null,null,null,null,0));
//databases.add(database);
/* for (Iterator iter = databases.iterator(); iter.hasNext();)
{
@@ -1167,13 +1210,21 @@ public static class DataBase
Vector selects;
Vector layouts;
Vector tables;
- public DataBase(DBBean bean,Vector tables,Vector layouts,Vector selects,Vector creates)
+ Vector ids;
+ final static int CONVERT_MODE = 1;
+ final static int APPEND_MODE = 2;
+ final static int UPDATE_MODE = 3;
+ int mode = -1;
+
+ public DataBase(DBBean bean,Vector tables,Vector layouts,Vector selects,Vector creates,Vector ids,int mode)
{
this.bean = bean;
this.tables = tables;
this.layouts = layouts;
this.selects = selects;
this.creates = creates;
+ this.ids = ids;
+ this.mode = mode;
}
public void exportToXML(BufferedWriter buffr) throws Exception
{
@@ -1181,7 +1232,17 @@ public static class DataBase
buffr.write(" "+bean.url+"\n");
buffr.write(" "+bean.user+"\n");
buffr.write(" "+bean.passwd+"\n");
-
+ String modeString ="";
+ if (mode == CONVERT_MODE)
+ modeString = "convert";
+ else
+ if (mode == APPEND_MODE)
+ modeString = "append";
+ else
+ if (mode == UPDATE_MODE)
+ modeString = "update";
+
+ buffr.write(" "+ modeString+"\n");
int index = 0;
while(index\n");
+ buffr.write(" \n");
buffr.write(" \n");
if(!create.equals(""))
buffr.write(" "+create+" \n");