Wie kann ich aus diesem XML eine XMLTABLE-Funktion bauen?

ebruss17

Bekanntes Mitglied
Hallo Leute,

ich habe eine Datenbanktabelle erstellt:
Java:
CREATE TABLE "MGMT"."SYSTEM" 
(   "SYSTEM_ID" INTEGER NOT NULL GENERATED ALWAYS AS IDENTITY ( START WITH 1 INCREMENT BY 1 MINVALUE 1 MAXVALUE 2147483647 NO CYCLE CACHE 20),
        "NAME" VARCHAR(300) NOT NULL,
        "SERVICE" VARCHAR(200) NOT NULL,
        "VERSION" VARCHAR(150) NOT NULL,
        "CONFIGURATION" XML NOT NULL
    )

das in der Spalte "Configuration" hinterlegtes XML sieht so aus:

Java:
<?xml version="1.0" encoding="UTF-8"?>
<system xmlns:xi="http://www.w3.org/2001/XInclude" 
        xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" 
        xsi:noNamespaceSchemaLocation="SystemConfiguration.xsd" 
        xsi:schemaLocation="http://www.w3.org/XML/1998/namespace ../xinclude/xml.xsd [url=http://www.w3.org/2001/XInclude]XInclude[/url]        ../xinclude/xinclude.xsd ">
<components>
    <component>
        <name>FileNet</name>
        <version>5.2.1.0</version>
        <buildNumber>dap521.000.024</buildNumber>
    </component>
    <component>
        <name>CSS</name>
        <version>IQQD0055E The search server is stopped. It must be started for the tool to run.</version>
    </component>
    <component>
        <name>CSS</name>
        <version>2.1.0.0-1.1-4147.</version>
        <fixpack>FP5</fixpack>
    </component>
    <component>
        <name>TDS</name>
        <version>6.3.1.0</version>
    </component>
    <component>
        <name>ICN</name>
        <version>2.0.2</version>
    </component>
    <component>
        <name>CMIS</name>
        <version>IBM Content Management Interoperability Services for FileNet Content Manager (IBM CMIS) Version 2.0.2.3</version>
    </component>
    <component>
        <name>DB2</name>
        <version>DB2 v10.1.0.2</version>
    </component>
    <component>
        <name>WAS</name>
        <version>8.5.5.1</version>
    </component>
</components>
</system>

Nun möchte ich mittels der SQL-XML-Funktion das in der Spalte "Configuration" hinterlegtes XML mithilfe der XML-Table-Funktion transformieren:

Java:
try {

			connection = DriverManager.getConnection(url, user, password);

			selectKunden = connection
					.prepareStatement("SELECT X.NAME, X.VERSION, X.FIXPACK, X.BUILDNUMBER FROM MGMT.SYSTEM, XMLTABLE('$CONFIGURATION/system/components/component' COLUMNS NAME VARCHAR(30) PATH 'name', VERSION VARCHAR(120) PATH 'version', FIXPACK VARCHAR(30) PATH 'fixpack', BUILDNUMBER VARCHAR(20) PATH 'buildNumber') AS X WHERE MGMT.SYSTEM.SYSTEM_ID = ?");
			selectKunden.setInt(1, zahl);
		} catch (SQLException e) {
			e.printStackTrace();
		}

		try {

			resultSet = selectKunden.executeQuery();

		} catch (SQLException e) {
			e.printStackTrace();
		}
	%>

                <%

        while (resultSet.next()){

                %>
                
                    <%=resultSet %>
                    <%

}
                    %>
	
</body>
</html>

Bekomme ich nicht die Tabelle als Ausgabe, sondern das hier:

"com.ibm.db2.jcc.t4.i@a4f686db com.ibm.db2.jcc.t4.i@a4f686db com.ibm.db2.jcc.t4.i@a4f686db com.ibm.db2.jcc.t4.i@a4f686db com.ibm.db2.jcc.t4.i@a4f686db com.ibm.db2.jcc.t4.i@a4f686db com.ibm.db2.jcc.t4.i@a4f686db com.ibm.db2.jcc.t4.i@a4f686db "
 
Zuletzt bearbeitet:

Harry Kane

Top Contributor
Naja, was erwartest du? Für jeden Eintrag im result set gibtst du eine Stringrepräsentation des result set aus. Wenn ResultSet die toString() Methode nicht überschreibt, gibt es halt diesen etwas kryptischen Output.
Das ist in etwa so sinnlos wie das hier:
Java:
String[] werte = new String[]{"Eins","Zwei","Drei"};
for(String eintrag: werte){
    System.out.println(werte);
}
 

ebruss17

Bekanntes Mitglied
ich habe es jetzt wenigstens mit der Funktion XMLTABLE hinbekommen, die Spalten mit den jeweiligen Werten auf der JSP-Seite anzuzeigen und habe dafür eine SELECT-Anweisung gebastelt, wie im Folgenden Code zu sehen ist! Ich habe aber jetzt innerhalb den Spalten "FIXPACK" und "BUILDNUMBER" ab und zu NULL-Werte stehen, wenn diese keine Werte enthalten. Wie könnte ich diese innerhalb meines Codes denn abfangen, dass, wenn NULL-Werte innerhalb den beiden Spalten enthalten sind, diese leer sein sollen und nicht das Wort "NULL" da drinnstehen haben. Und die Werte für die "buildNumber" wird nicht ausgegeben. Habe ich da vielleicht im Code, wo die for-Schleifen sind, ne Klammer zu früh geschlossen? Ich wäre für die Unterstützung dankbar!!!

Java:
try {

            connection = DriverManager.getConnection(url, user, password);

            selectKunden = connection
                    .prepareStatement("SELECT X.NAME, X.VERSION, X.FIXPACK, X.BUILDNUMBER FROM MGMT.SYSTEM, XMLTABLE('$CONFIGURATION/system/components/component' COLUMNS NAME VARCHAR(30) PATH 'name', VERSION VARCHAR(120) PATH 'version', FIXPACK VARCHAR(30) PATH 'fixpack', BUILDNUMBER VARCHAR(50) PATH 'buildNumber') AS X WHERE MGMT.SYSTEM.SYSTEM_ID = ?");
            selectKunden.setInt(1, zahl);
        } catch (SQLException e) {
            e.printStackTrace();
        }

        try {

            resultSet = selectKunden.executeQuery();

        } catch (SQLException e) {
            e.printStackTrace();
        }
    %>
    <table border="1">
        <tr>
            <%
                ResultSetMetaData rsmd = null;

                rsmd = resultSet.getMetaData();

                int numberOfColumns = 0;
                numberOfColumns = rsmd.getColumnCount();

                for (int i = 1; i <= numberOfColumns; i++) {
            %>
            <th><%=rsmd.getColumnLabel(i)%></th>
            <%
                }
            %>
        </tr>

        <%
            while (resultSet.next()) {
        %>
        <tr>
            <%
                for (int i = 1; i <= numberOfColumns; i++) {
                        if (i != numberOfColumns) {
            %>

            <td><%=resultSet.getString(i)%></td>

            <%
                }
                    }
                }
            %>
        </tr>

    </table>
</body>
 

Harry Kane

Top Contributor
Wie könnte ich diese innerhalb meines Codes denn abfangen, dass, wenn NULL-Werte innerhalb den beiden Spalten enthalten sind, diese leer sein sollen und nicht das Wort "NULL" da drinnstehen haben.
In dem du den Wert abfragst, ob er null ist, und wenn ja, lässt du ein "" ausgeben.

Habe ich da vielleicht im Code, wo die for-Schleifen sind, ne Klammer zu früh geschlossen?
Nu geht es aber ans Eingemachte! Also wenn du an der semantischen Richtigkeit deines Codes zweifelst, solltest du vielleicht erstmal probieren, einen Algorithmus zu programmieren, der die Daten aus der DB ziehen kann und sauber in einem Array oder in einer ArrayList mit Datenobjekten abspeichert. Wenn das steht, dann kannst du drüber nachdenken, wie du diesen Algo am besten in eine JSP packst.
Du versuchts viel zu viel in einen Schritt zu packen, weisst offenbar nicht so richtig, was du tust, und wunderst dich dann über das Ergebnis.
Und zu deiner Frage: dein letztes </tr> steht etwas zu weit hinten. Von den drei geschweiften Klammern in Zeile 50-52 schließt die erste (in Zeile 50) den if-Block, der in Zeile 44 beginnt, die zweite in Zeile 51 die for-Schleife die in Zeile 43 beginnt, und die dritte die while-Schleife, in der du über deinen result set iterierst. Das </tr> steht nach der dritten "}", muss aber natürlich davor stehen.
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
Z MySQL in .jar: was ist an diesem Manifest falsch? Datenbankprogrammierung 5
B Wie kann ich eine Jtable mit Inhalt einer SQL Abfrage füllen Datenbankprogrammierung 14
I SaaS Applikation: pro Kunde eine Datenbank / Schema oder eine DB für alle Kunden? Datenbankprogrammierung 76
Zrebna PostgreSQL-Query in eine MicrosoftSQL-Query konvertieren - chatGPT hilft nur bedingt. Datenbankprogrammierung 3
T Spring MongoDB: Prüfen ob bereits eine Email existiert Datenbankprogrammierung 15
Zrebna Wie mittels Hibernate eine Join-Tabelle als eigene Java-Klasse erstellen? Datenbankprogrammierung 5
Zrebna Probleme bei Überführung von SQL-Code in eine HQL-Abfrage Datenbankprogrammierung 3
Zrebna Wie mittels PL/SQL eine Datenbankverbindung blockieren? Datenbankprogrammierung 6
berserkerdq2 Was genau muss ich bei date eingeben, wenn ich in Java eine Spalte definiere, die date ist? Datenbankprogrammierung 1
pkm PostgreSQL Kann mit mybatis einen Parameter für eine postgreSQL-Abfrage nicht übergeben. Datenbankprogrammierung 5
Kirby.exe Eine Tabelle updaten Datenbankprogrammierung 16
B Wie kopieren ich eine Spalte von einer Tabelle in eine andere Tabelle SQLite durch java code? Datenbankprogrammierung 26
Z Aus zwei bestehenden Table eine zusätzliche Gemeinsame machen (JavaFX) Datenbankprogrammierung 21
Avalon Attribute werden mit Unterstrich in eine MySQL Datenbank eingetragen Datenbankprogrammierung 10
pkm PostgreSQL Auf eine Spalte kann aus einem Teil der SQL-Aussage nicht zugegriffen werden Datenbankprogrammierung 3
F Mapping einer SQL Abfrage in eine Klasse Datenbankprogrammierung 4
H suche eine Login system Bibliothek für Java Datenbankprogrammierung 5
C Datenbank anlegen und über eine Website mit Daten füllen? Datenbankprogrammierung 25
G Eine Spalte in xampp als Typ array erstellen - ein array mit "insert" hinzufügen. Datenbankprogrammierung 3
F Create Table - Habe ich eine schwache Entität erzeugt ? Datenbankprogrammierung 4
Dimax MySQL Trigger für eine Spalte Datenbankprogrammierung 5
Dimax MySQL Maximale Datenlänge für eine Spalte einer Datenbank in java ermitteln Datenbankprogrammierung 15
D MySQL Eibinden des "mysql-connector" in eine fertige Jar Datenbankprogrammierung 3
P JSP - Daten aus 2 Tabellen in eine neue Tabelle einfügen Datenbankprogrammierung 1
P Daten in eine mySQL Datenbank einfügen Datenbankprogrammierung 4
S MySQL JTable zeigt nach Datenbankabfrage eine Spalte zu viel an Datenbankprogrammierung 0
Thallius MySQL Tabelle splitten aber wie eine abfragen? Datenbankprogrammierung 10
B MySQL Eine Art Sverweis Datenbankprogrammierung 27
O HSQLDB Eine Entität, mehrere Tabellen Datenbankprogrammierung 8
B SQL-Statement Prüfen ob eine Spalte einen Wert enthält Datenbankprogrammierung 2
X SQLite Erhalte bei Query INSERT INTO eine NullPointerException Datenbankprogrammierung 10
L0MiN Wie kann ich eine bestimmte Seite aus verschiedenen Excel-Tabellen in eine neue Exceldatei kopieren? Datenbankprogrammierung 1
N Wie in Java Zugriffe und Updates auf eine Datenbank regeln ? Datenbankprogrammierung 1
E Wie kann man mit einer ID-Spalte über eine Parameterübergabe auf eine Seite verweisen? Datenbankprogrammierung 17
A Eine MySQL Zeile mit JDBC löschen Datenbankprogrammierung 5
M Warum ist es suboptimal viele Indexe auf eine Datenbanktabelle zu setzen? Datenbankprogrammierung 4
L Datenmodell erstellen für eine Nutzertanalyse Datenbankprogrammierung 1
serjoscha MySQL Eine Instanz von eigenem DBWrapper -> Fehler durch mehrfachbenutzung möglich? Datenbankprogrammierung 2
S HSQLDB Verbieten eines update auf eine bestimmte reihe Datenbankprogrammierung 4
V HSQLDB Insert in eine Tabelle mit Autoincrement Datenbankprogrammierung 2
H Grosse Menge an Daten in eine Datenbank Datenbankprogrammierung 32
P MySQL eine richtige Datenbank für einen routenplaner erstellen Datenbankprogrammierung 2
D SQL Update auf eine Query möglich? Datenbankprogrammierung 4
S SqlObject - eine objektorientierte Art SQL-Statements zu schreiben. Datenbankprogrammierung 4
C Mit jsp über Java eine DB Abfrage durchführen --> java.lang.ClassNotFoundException Datenbankprogrammierung 4
K SQLite CSV-Datei einlesen in eine Datenbank Datenbankprogrammierung 7
E Datenbank Abfragen in eine GUI schreiben Datenbankprogrammierung 8
A Problem mit Eintragen von Daten in eine Datenbank mittels DAO Datenbankprogrammierung 4
L MySQL MySql in eine Application einbinden? Datenbankprogrammierung 18
R MySQL Voraussetzungen für eine erfolgreiche Datenbankanbindung mittels JDBC Datenbankprogrammierung 2
H Derby/JavaDB Eine verschlüsselte Derby-Datenbank wieder entschlüsseln Datenbankprogrammierung 4
D Was passiert bei absolut zeitgleichem Zugriff auf eine Tablerow Datenbankprogrammierung 7
I Belastet es das System zu sehr einen Timer jede 0.2 Sekunden eine DB Abfrage machen zu lassen? Datenbankprogrammierung 9
I Zugriff auf eine Datenbank auf dem Webserver Datenbankprogrammierung 2
F H2:Wie kann man insert eine Reihe "int" wert als blob in table? Datenbankprogrammierung 12
J mal wieder eine Frage zu parallelen Transaktionen.. Datenbankprogrammierung 2
Screen Ich suche eine SQLDatenbank ohne JDBC-Treiber Datenbankprogrammierung 12
H Derby/JavaDB SQLException wenn die Datenbank in eine Jar gepackt wurde. Datenbankprogrammierung 6
turmaline [Hibernate] @OneToMany - Eine referenzierte Tabelle abfragen Datenbankprogrammierung 11
S Werte aus Datenbank auslesen und in eine bestimmte Excelzelle eintragen Datenbankprogrammierung 2
T Wer kann mir eine Datenbank empfehlen Datenbankprogrammierung 13
DStrohma MS SQL Server 2005 + Java: Immer nur eine aktive Verbindung erlaubt? Datenbankprogrammierung 5
D MySQL Wie schreibe ich in eine Datenbank? Datenbankprogrammierung 8
J String[] in eine SQL-Anweisung implementieren Datenbankprogrammierung 13
Q Access Datenbank in eine Internetseite einbinden Datenbankprogrammierung 2
J Über einen Button eine SQL-DB aussuchen Datenbankprogrammierung 3
O eine Tabelle hat mehrere PrimKey mit dem selben Wert Datenbankprogrammierung 9
R Connection Problem für eine externe DB mit Java (JDBC) Datenbankprogrammierung 9
M Zugriff auf eine Access-Datenbank innerhalb eines jar-Files Datenbankprogrammierung 7
N Wie kann ich Zugriff auf eine MS Access DB (mit JDBC) über Netzwerk erreichen? Datenbankprogrammierung 7
G Wie sieht eine Datenbankverbindung mit jndi aus? Datenbankprogrammierung 3
T eine Datenbank updaten Datenbankprogrammierung 6
C Prüfen, ob eine MySQL-Tabelle bereits existiert Datenbankprogrammierung 7
E Wie auf eine MySql Datenbank zugreifen Datenbankprogrammierung 25
D Werte mit java programm in eine Datenbank einlesen Datenbankprogrammierung 7
T JPQL Query für eine Tabellenansicht Datenbankprogrammierung 2
B Wie persistiert man eine Tree-ähnliche Datenbankstruktur? Datenbankprogrammierung 2
M Aus einem Applet eine Datenbankverbindung starten? Datenbankprogrammierung 26
R Datenbankstruktur für eine renn simulation Datenbankprogrammierung 3
H Wie kann ich eine Datenbank Connection aus XML-Datei lesen! Datenbankprogrammierung 2
G Wie baut man eine Anwendung mit DB Zugriff Datenbankprogrammierung 3
S Als Rückgebewert eine Liste von Werten? Datenbankprogrammierung 3
A Auslesen von Werten aus der DB in eine csv-Datei Datenbankprogrammierung 4
O Oracle 11g wirft bei 90 % der installation eine Exception ? Datenbankprogrammierung 5
T Recordsets in eine JTable einlesen mit Netbeans 6.0 Datenbankprogrammierung 2
R Warum kommt eine Exception bei instanceof ? Datenbankprogrammierung 4
M Tabelle von einer Datenbank in eine Andere Datenbankprogrammierung 4
G Inhalt eine Clob Feldes zw. zwei DB's kopieren Datenbankprogrammierung 2
A Einlesen einer csv-Datei in eine H2-Datenbank Datenbankprogrammierung 3
A Kriterium für eine JList neu definieren Datenbankprogrammierung 3
A Probleme beim Schreiben in eine CSV-Datei aus einer H2-DB Datenbankprogrammierung 2
G Import einer csv-Datei in eine H2-Database Datenbankprogrammierung 12
J Warum ist es aufwendig eine Datenbankverbindung herzustellen Datenbankprogrammierung 3
M Mit Java .txt-Datei in eine Datenbank einlesen lassen Datenbankprogrammierung 33
S Zugriff auf eine große Datenmenge von MS Access per JDBC Datenbankprogrammierung 11
S von einer DB auf eine andere Zugreifen. Datenbankprogrammierung 2
W Wann ist eine Telefonnummer atomar ? Datenbankprogrammierung 3
D Dateien in eine OODB abspeichern Datenbankprogrammierung 3
A Eine einzelne Zeile schreibschützen im DataSet Datenbankprogrammierung 13
E 2 Tabellen anhand eine Spalte zusammenführen? Datenbankprogrammierung 5

Ähnliche Java Themen

Neue Themen


Oben