dcsimg
Login | Register   
RSS Feed
Download our iPhone app
TODAY'S HEADLINES  |   ARTICLE ARCHIVE  |   FORUMS  |   TIP BANK
Browse DevX
Sign up for e-mail newsletters from DevX

By submitting your information, you agree that devx.com may send you DevX offers via email, phone and text message, as well as email offers about other products and services that DevX believes may be of interest to you. DevX will process your information in accordance with the Quinstreet Privacy Policy.


Tip of the Day
Language: Databases
Expertise: Beginner
Feb 18, 2000

WEBINAR:

On-Demand

Application Security Testing: An Integral Part of DevOps


Dumping Tables

Question:
Using JDBC, how can I turn a database table into a series of SQL INSERT statements that can recreate the table?

Answer:
Dumping a database table into a set of insert statements is just a matter of selecting all of its rows and constructing insert statements based on their column values.

You can determine the number of columns in a table by accessing the ResultSetMetaData for a ResultSet with getMetaData() and then calling ResultSetMetaData.getColumnCount(). Getting the values of each row is just a matter of calling getString() with the column number as an argument. The following program demonstrates the approach:

import java.sql.*;


/***
 * This program accepts a table name, a JDBC driver name, and a database
 * connection URL as arguments.  The program connections to the database
 * and reads all the rows in the table, printing SQL INSERT statements
 * on standard output representing the data.
 ***/
public final class dump {
  public static String DUMP_QUERY = "SELECT * FROM ";

  public static final void main(String[] args) {
    Connection connection;
    Statement statement;
    ResultSet result;
    ResultSetMetaData metaData;
    String table, driver, url;
    StringBuffer buffer = new StringBuffer(8192);
    int columns;

    if(args.length < 3) {
      System.err.println("Usage: dump  ");
      return;
    }

    table  = args[0];
    driver = args[1];
    url    = args[2];

    System.setProperty("jdbc.drivers", driver);

    try {
      connection = DriverManager.getConnection(url);
      statement  = connection.createStatement();
      result = statement.executeQuery(DUMP_QUERY + table);
      metaData = result.getMetaData(); 
      columns = metaData.getColumnCount();

      while(result.next()) {
        buffer.setLength(0);
        buffer.append("INSERT INTO ");
        buffer.append(table);
        buffer.append(" VALUES (");

        for(int i = 1; i <= columns; i++) {
          String str;
          str = result.getString(i);
          if(str == null)
            buffer.append("NULL");
          else {
            buffer.append('\'');
            buffer.append(str);
            buffer.append('\'');
          }
          if(i < columns)
            buffer.append(", ");
          else
            buffer.append(");");
        }
        System.out.println(buffer.toString());
      }
    } catch(SQLException e) {
      e.printStackTrace();
      return;
    }
  }
}



														
DevX Pro
 
Submit a Tip Browse "Java" Tips Browse All Tips
Comment and Contribute

 

 

 

 

 


(Maximum characters: 1200). You have 1200 characters left.

 

 

Sitemap
Thanks for your registration, follow us on our social networks to keep up-to-date