AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Delphi Mit SQL Zeile kopieren ?
Thema durchsuchen
Ansicht
Themen-Optionen

Mit SQL Zeile kopieren ?

Ein Thema von HolgerCW · begonnen am 26. Apr 2007 · letzter Beitrag vom 26. Apr 2007
Antwort Antwort
HolgerCW

Registriert seit: 28. Nov 2006
Ort: Marl
1.207 Beiträge
 
Delphi XE7 Enterprise
 
#1

Mit SQL Zeile kopieren ?

  Alt 26. Apr 2007, 15:47
Datenbank: ORACLE • Version: 9 • Zugriff über: BDE
Hallo zusammen,

wie kann ich am einfachsten eine Zeile mit SQL kopieren?

Möchte in einer Tabelle die Zeile mit der ID 2, davon die Spalten 5 - 30 auf die Zeile mit der ID 5 kopieren.

Die Spalte ID heisst auch ID, nur die anderen Spalten haben ganz unterschiedliche Bezeichnungen.
Möchte halt nicht die ganze Zeile kopieren, sondern nur die Spalten 5 - 30 (In denen nur 1 oder NULL steht) der jeweiligen Spalte.

Hat das wer eine Lösung ?

Gruss

Holger
  Mit Zitat antworten Zitat
Elvis

Registriert seit: 25. Nov 2005
Ort: München
1.909 Beiträge
 
Delphi 2010 Professional
 
#2

Re: Mit SQL Zeile kopieren ?

  Alt 26. Apr 2007, 16:12
Astraktes Beispiel:
SQL-Code:
INSERT INTO Miep.Mööp(Feld1,Feld2)
  SELECT Feld1
        ,Feld2
  FROM Miep.Mööp
  WHERE PK = 1
Hier das Ganze nochmal generisch. Also Schema, Tabelle, PK-Spalte und den Ursprungs-PK rein und...
SQL-Code:
declare
  type TNameList is table of All_Tab_Columns.Column_Name%type;
  columnNames TNameList;
  sqlStatement clob;

  procedure AddToStatement(aClob in out nocopy clob
                          ,aText in VarChar) is
  begin
    if aText is not null then
      Dbms_Lob.WriteAppend(aClob, Length(aText), aText);
    end if;
  end;

  procedure AddColumnList(aClob in out nocopy clob
                         ,aColumnNames in TNameList) is
  begin
    for i in aColumnNames.first .. aColumnNames.last loop
      if i != aColumnNames.first then
        AddToStatement(aClob, ',');
      end if;
    
      AddToStatement(aClob, '"' || aColumnNames(i) || '"');
    end loop;
  end;
begin

  SELECT t.Column_Name bulk collect
  INTO columnNames
  FROM All_Tab_Columns t
  WHERE t.Owner = :Owner
  and t.Table_Name = :TableName
  and t.Column_Name != :PkColumn
  ORDER BY t.COLUMN_ID;

  if columnNames.Count > 0 then
    Dbms_Lob.CreateTemporary(sqlStatement, true);
  
    AddToStatement(sqlStatement, 'INSERT INTO "' || :Owner || '"."' || :TableName || '"(');
    AddColumnList(sqlStatement, columnNames);
    AddToStatement(sqlStatement, ') SELECT ');
    AddColumnList(sqlStatement, columnNames);
    AddToStatement(sqlStatement, ' FROM "' || :Owner || '"."' || :TableName || '"');
    AddToStatement(sqlStatement, ' WHERE "' || :PkColumn || '" = :Pk');
  
    execute immediate to_Char(sqlStatement)
      Using :PkValue;
  
    Dbms_Lob.FreeTemporary(sqlStatement);
  end if;
end;
Robert Giesecke
I’m a great believer in “Occam’s Razor,” the principle which says:
“If you say something complicated, I’ll slit your throat.”
  Mit Zitat antworten Zitat
Antwort Antwort


Forumregeln

Es ist dir nicht erlaubt, neue Themen zu verfassen.
Es ist dir nicht erlaubt, auf Beiträge zu antworten.
Es ist dir nicht erlaubt, Anhänge hochzuladen.
Es ist dir nicht erlaubt, deine Beiträge zu bearbeiten.

BB-Code ist an.
Smileys sind an.
[IMG] Code ist an.
HTML-Code ist aus.
Trackbacks are an
Pingbacks are an
Refbacks are aus

Gehe zu:

Impressum · AGB · Datenschutz · Nach oben
Alle Zeitangaben in WEZ +1. Es ist jetzt 21:15 Uhr.
Powered by vBulletin® Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz