com.xqbase.util.db.DumpConsumer Maven / Gradle / Ivy
package com.xqbase.util.db;
import java.io.PrintStream;
import com.xqbase.util.Bytes;
import com.xqbase.util.function.Consumer;
public class DumpConsumer implements Consumer, AutoCloseable {
private static final int ROWS_PER_LINE = 256;
private int rows = 0, columns;
private PrintStream out;
private String selectSql, insertSql;
public DumpConsumer(PrintStream out, String table, String... columns) {
this.out = out;
this.columns = columns.length;
StringBuilder sb = new StringBuilder();
for (String column : columns) {
sb.append(", " + column);
}
String columns_ = sb.substring(2);
selectSql = "SELECT " + columns_ + " FROM " + table;
insertSql = "INSERT INTO " + table + " (" + columns_ + ") VALUES ";
out.println("TRUNCATE TABLE " + table + ";");
}
public String getSelectSql() {
return selectSql;
}
@Override
public void accept(Row row) {
if (rows % ROWS_PER_LINE == 0) {
if (rows > 0) {
out.println(";");
}
out.print(insertSql);
} else {
out.print(", ");
}
rows ++;
StringBuilder sb = new StringBuilder();
for (int i = 0; i < columns; i ++) {
Object o = row.get(i + 1);
if (o == null) {
sb.append(", NULL");
} else if (o instanceof String) {
sb.append(", '" + ((String) o).replace("\\", "\\\\").
replace("\'", "\\\'") + "'");
} else if (o instanceof byte[]) {
sb.append(", x'" + Bytes.toHexUpper((byte[]) o) + "'");
} else { // Number
sb.append(", " + o);
}
}
out.print("(" + sb.substring(2) + ")");
}
@Override
public void close() {
out.println(";");
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy