AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Delphi * in Stored Procedure [Interbase]
Thema durchsuchen
Ansicht
Themen-Optionen

* in Stored Procedure [Interbase]

Ein Thema von Hansa · begonnen am 6. Sep 2004 · letzter Beitrag vom 7. Sep 2004
Antwort Antwort
Robert_G
(Gast)

n/a Beiträge
 
#1

Re: * in Stored Procedure [Interbase]

  Alt 6. Sep 2004, 09:58
Zeig' mal den Code drumrum. Ein SELECT-Statement ist ja noch keine Prozedur.
Wenn du einen Haufe Daten in der Tabelle ändern willst: Deklariere es als Cursor, schiebe die Daten in Collections und mache etwas damit. Danach kannst du die per BULK DML ziemlich fix zurückschreiben:
SQL-Code:
create or replace procedure SenselessSample(pC in varchar2) is

  cursor curTabl8(iC in varchar2) is
    SELECT PK
          ,A
          ,B
    FROM Table8
    WHERE C = iC;

  type IntTab is table of integer;
  type ShortChrTab is table of varchar2(255);
  type LongChrTab is table of varchar2(2000);

  lPK IntTab;
  lA ShortChrTab;
  lB LongChrTab;

  i integer;
begin
  -- hole Daten
  open curTabl8(pC);
  fetch curTabl8 bulk collect
    INTO lPK, lA, lB;
  close curTabl8;

  -- mache was damit
  for i in lPK.first .. lPK.last loop
    lA(i) := lA(i) || ' miep!';
    lB(i) := lB(i) || ' ' || lA(i);
  end loop;

  -- schiebe sie per BULK DML zurück
  forall i in lPK.first .. lPK.last
    UPDATE Table8 u
    SET u.A = lA(i)
          ,u.B = lB(i)
    WHERE PK = lPK(i);

end;
  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 06:00 Uhr.
Powered by vBulletin® Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz