tutorials.de Buch-Aktion 05/2012
ERLEDIGT
NEIN
ANTWORTEN
2
ZUGRIFFE
836
EMPFEHLEN
  • An Twitter übertragen
  • An Facebook übertragen
AUF DIESES THEMA
ANTWORTEN
  1. #1
    danield24 danield24 ist offline Grünschnabel
    Registriert seit
    Aug 2009
    Beiträge
    3
    Hallo zusammen,

    ich habe ein Problem, wo ich trotz intensiver Suche im Internet und div. Büchern noch keine Lösung gefunden habe.

    Ich habe eine Oracle 10g, wo ich im XML-DB-Repository im Public-Ordner eine xml-Datei (Test.xml) abgelegt habe (per WebDAV). Die Test.xml wird im Windows-Explorer auch angezeigt und eine Abfrage mit "select count(*) from xdb.XDB$RESOURCE" zeigt mir auch an, dass ein Datensatz hinzugefügt wurde. Soweit so gut.

    Jetzt habe ich in der DB auch einige XML-Schemas registriert, wobei ein Schema (Testschema) zur Test.xml passt. Normalerweise erfolgt die Referenzierung automatisch beim Upload der Datei in das XML-DB-Repository, vorausgesetzt, es ist in der Test.xml ein entsprechender Eintrag "xsi:schemaLocation" enthalten, der auf das richtige Schema verweist. Da das bei meiner Datei nicht der Fall ist, muss ich sie "von Hand" mit dem Schema referenzieren um sie dann anschließend objektrelational zu speichern.
    Meine Tabelle, wo die Datei gespeichert werden soll, heißt "bmecatimport_new".

    Laut meinen Recherchen müsste es so funktionieren:
    insert into "bmecatimport_new"
    values (xmltype('hier kommt der XML-Text rein').createschemabasedxml('Testschema'));

    Jetzt kommt allerdings der Haken...
    Meine XML-Dateien sind z.T. sehr groß (bis 1GB) und enthalten einige Sonderzeichen (z.B. "&") welche bei den SQL-Statements zu Fehlern führen, da sie ja reservierte Zeichen sind.

    Daher kann ich die Datei auch nicht als Text in das Statement übergeben, sondern möchte z.B. per Pfad auf die Datei verweisen.

    Weiß jemand, wie das geht oder gibt es eine alternative Lösung für das importieren von großen XML-Dateien, die objektrelational mit Schemareferenzierung gespeichert werden sollen?


    Vielen Dank im voraus.


    MfG
    Daniel
    Geändert von danield24 (05.08.09 um 17:13 Uhr)
     

  2. #2
    dbwizard dbwizard ist offline Mitglied Brokat
    Registriert seit
    May 2007
    Ort
    Zürich
    Beiträge
    285
    Zitat Zitat von danield24 Beitrag anzeigen
    Hallo zusammen,



    Weiß jemand, wie das geht oder gibt es eine alternative Lösung für das importieren von großen XML-Dateien, die objektrelational mit Schemareferenzierung gespeichert werden sollen?


    Vielen Dank im voraus.


    MfG
    Daniel
    Hallo,

    Dies sollte dir helfen

    http://stanford.edu/dept/itss/docs/o...a.htm#BGBDDEDD



    Gruss
     

  3. #3
    danield24 danield24 ist offline Grünschnabel
    Registriert seit
    Aug 2009
    Beiträge
    3
    Vielen Dank erstmal für die Antwort. Die Seite hat mich zwar nicht richtig weitergebracht, aber ich bin dadurch schon etwas schlauer geworden.

    Ich habe nun eine Tabelle in meiner DB angelegt, die eine Spalte vom Typ "XMLTYPE" enthält und der Tabelle ist ein registriertes Schema zugewiesen. Da ich alles gern nachkontrollieren möchte, wollte ich mal fragen, ob jemand einen SQL-Befehl kennt, mit dem man einfach abfragen kann, ob und zu welchem Schema die Tabelle zugeordnet ist?

    Gruß Daniel
     

Ähnliche Themen

  1. Oracle - Sequences - Schema
    Von kaskagir im Forum Relationale Datenbanksysteme
    Antworten: 1
    Letzter Beitrag: 07.10.08, 02:00
  2. [Begriffserklärung] Repository (Oracle)
    Von Kerwin im Forum Relationale Datenbanksysteme
    Antworten: 2
    Letzter Beitrag: 06.07.07, 09:47
  3. Neues Schema in Oracle-DB erstellen
    Von AKST im Forum Relationale Datenbanksysteme
    Antworten: 5
    Letzter Beitrag: 17.10.04, 23:40
  4. Oracle - Tabelle von einem Schema in ein anderes Schema verschieben
    Von Plumpsi im Forum Relationale Datenbanksysteme
    Antworten: 0
    Letzter Beitrag: 15.09.04, 10:26
  5. Oracle - Schema umbenennen
    Von Plumpsi im Forum Relationale Datenbanksysteme
    Antworten: 2
    Letzter Beitrag: 14.09.04, 11:11

Stichworte