Как вы получаете значения из всех столбцов, используя ResultSet.getBinaryStream() в jdbc?
Как мне написать таблицу ENTIRE для плоского файла с помощью jdbc? До сих пор я пытался сделать следующее:
Statement statement = connection.createStatement();
ResultSet result = statement.executeQuery("SELECT * FROM tablename");
BufferedInputStream buffer;
FileOutputStream out = new FileOutputStream("flatfile.txt");
while(result.next() )
{
buffer = new BufferedInputStream(result.getBinaryStream("????") );
byte[] buf = new byte[4 * 1024]; //4K buffer
int len;
while( (len = buffer.read(buf, 0, buf.length) ) != -1 )
{
out.write(buf, 0, len );
}
}
out.close();
"????" просто мой заполнитель. Я застрял на том, что передать в качестве аргумента.
Ответы
Ответ 1
Вы можете получить все имена столбцов и все данные из своей таблицы, используя приведенный ниже код.
Метод writeToFile будет содержать логику записи в файл (если это было недостаточно очевидно:))
ResultSetMetaData metadata = rs.getMetaData();
int columnCount = metadata.getColumnCount();
for (int i = 1; i <= columnCount; i++) {
writeToFile(metadata.getColumnName(i) + ", ");
}
System.out.println();
while (rs.next()) {
String row = "";
for (int i = 1; i <= columnCount; i++) {
row += rs.getString(i) + ", ";
}
System.out.println();
writeToFile(row);
}
Ответ 2
result.getBinaryStream("????")
будет возвращаться только для значения для этого столбца, как вы помещаете в качестве заполнителя.
Если вы хотите получить весь столбец, вам нужно использовать ResultSetMetaData
из ResultSet
ResultSetMetaData metadata = resultSet.getMetaData();
int columnCount = metadata.getColumnCount();
for (int i=1; i<=columnCount; i++)
{
String columnName = metadata.getColumnName(i);
System.out.println(columnName);
}
Ответ 3
Вот как я удаляю таблицу из JDBC-соединения, очень полезную для отладки, если вы хотите увидеть все строки, которые находятся в DB (например, HSQL), например:
public static void spitOutAllTableRows(String tableName, Connection conn) {
try {
System.out.println("current " + tableName + " is:");
try (PreparedStatement selectStmt = conn.prepareStatement(
"SELECT * from " + tableName, ResultSet.TYPE_SCROLL_INSENSITIVE, ResultSet.CONCUR_READ_ONLY);
ResultSet rs = selectStmt.executeQuery()) {
if (!rs.isBeforeFirst()) {
System.out.println("no rows found");
}
else {
while (rs.next()) {
for (int i = 1; i < rs.getMetaData().getColumnCount() + 1; i++) {
System.out.print(" " + rs.getMetaData().getColumnName(i) + "=" + rs.getObject(i));
}
System.out.println("");
}
}
}
}
catch (SQLException e) {
throw new RuntimeException(e);
}
}
вывод похож на
current <yourtablename> is:
ID=1 COLUMN1=abc COLUMN2=null
ID=2 COLUMN1=def COLUMN2=ghi
...