Преобразование таблицы в базе данных Oracle в файл XML - PullRequest
0 голосов
/ 12 апреля 2010

Мне нужно создать файл XML, учитывая таблицу / представление в базе данных. Фактическое требование: код должен получить имя таблицы / представления в качестве входного параметра, прочитать его схему, создать соответствующий файл XML с той же структурой, что и у таблицы / представления, и загрузить XML с данные таблицы / ракурса. Язык, предпочтительный здесь - JSP. Пожалуйста, дайте мне знать, как идти об этой идее.

Спасибо заранее, Гита

1 Ответ

0 голосов
/ 12 апреля 2010

Этот тип делает то, что вы хотите, за исключением того, что это не относится к Oracle. Он создает строку XML, а не документ XML.

Выдержка:

private String ExecQueryGetXml(java.sql.PreparedStatement stmt, String rootEltName, String rowEltName) {

  String result= "<none/>";
  String item;
  java.sql.ResultSet resultSet;
  java.sql.ResultSetMetaData metaData ;
  StringBuffer buf = new StringBuffer();
  int i;

  try {
    resultSet = stmt.executeQuery();
    metaData= resultSet.getMetaData();

    int numberOfColumns =  metaData.getColumnCount();
    String[] columnNames = new String[numberOfColumns];
    for( i = 0; i < numberOfColumns; i++) 
      columnNames[i] = metaData.getColumnLabel(i+1);

    try {
      if ((rootEltName!=null) && (!rootEltName.equals("")))
          buf.append('<').append(rootEltName).append('>').append('\n');

      // each row is an element, each field a sub-element
      while ( resultSet.next() ) {
        // open the row elt
        buf.append(' ').append('<').append(rowEltName).append(">\n");
        for( i= 0; i < numberOfColumns; i++) {
          item = resultSet.getString(i+1); 
          if(item==null)   continue;
          buf.append("  <").append(columnNames[i]).append('>');
          // check for CDATA required here? 
          buf.append(item);
          buf.append("</").append(columnNames[i]).append(">\n");
        }
        buf.append("\n </").append(rowEltName).append(">\n");
      }
      if ((rootEltName!=null) && (!rootEltName.equals("")))
          buf.append("</").append(rootEltName).append(">\n");
      result= buf.toString();
    } 
    catch(Exception e1) {
      System.err.print("\n\n----Exception (2): failed converting ResultSet to xml.\n");
      System.err.print(e1);
      result= "<error><message>Exception (2): " + e1.toString() + ". Failed converting ResultSet to xml.</message></error>\n";
    }
  }
  catch(Exception e2) {
    System.err.print("\n\n----Exception (3).\n");
    System.err.print("\n\n----query failed, or getMetaData failed.\n");
    System.err.print("\n\n---- Exc as string: \n" + e2);
    System.err.print("\n\n---- Exc via helper: \n" + 
                     ExceptionHelper.getStackTraceAsString(e2));

    result= "<error><message>Exception (3): " + e2 + ". query failed, or getMetaData() failed.</message></error>\n";
  }

  return result;
}
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...