data:image/s3,"s3://crabby-images/02ace/02ace956f9868cf2a1a780bd2c0a517cd3a46077" alt="JAR search and dependency download from the Maven repository"
net.jmatrix.db.schema.DBMCLI Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of jsql Show documentation
Show all versions of jsql Show documentation
SQL Utilities including simple command line, schema management.
The newest version!
package net.jmatrix.db.schema;
import java.io.File;
import net.jmatrix.db.common.ArgParser;
import net.jmatrix.db.common.ConnectionInfo;
public class DBMCLI {
static final String usage=
"DBM -schema [options] \n"+
"\n"+
" Options: \n"+
" -update: update the schema. indempotent. "+
" Will not apply same version if already applied. \n"+
" -rollback : Rollback the version indicated. \n"+
" -reapply : rollback, then apply the same version.\n"+
"\n"+
" database.connnect.string: format: \n"+
" user/[email protected]";
/**
* Commands:
* updateall - updates schema to latest version on disk.
* rollback version - execute rollback files to previous version
* rollback all - execute rollbacks from current version to the beginning
* reapply version - execute rollback, then apply of version
*/
public static void main(String args[]) throws Exception {
ArgParser ap=new ArgParser(args);
if (args.length < 1) {
System.out.println(usage);
System.exit(1);
}
String last=ap.getLastArg();
ConnectionInfo ci=new ConnectionInfo(last);
ci.connect();
String schemaPath=ap.getStringArg("-schema");
if (schemaPath == null) {
System.out.println(usage);
System.exit(1);
}
DBM dbm=new DBM(ci, new File(schemaPath));
dbm.init();
//console.log("Versions\n"+dbm.listVersions());
if (ap.getBooleanArg("-reapply")) {
String version=ap.getStringArg("-reapply");
dbm.reapply(version);
} else if (ap.getBooleanArg("-update")) {
dbm.updateAll();
} else if (ap.getBooleanArg("-rollback")) {
String version=ap.getStringArg("-rollback");
dbm.rollback(version);
} else {
dbm.showDBHistory();
// System.out.println(usage);
// System.exit(1);
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy