AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken VARCHAR-Spalte durch CLOB ersetzen
Thema durchsuchen
Ansicht
Themen-Optionen

VARCHAR-Spalte durch CLOB ersetzen

Ein Thema von Jumpy · begonnen am 26. Sep 2014 · letzter Beitrag vom 26. Sep 2014
Antwort Antwort
Benutzerbild von DeddyH
DeddyH

Registriert seit: 17. Sep 2006
Ort: Barchfeld
27.660 Beiträge
 
Delphi 12 Athens
 
#1

AW: VARCHAR-Spalte durch CLOB ersetzen

  Alt 26. Sep 2014, 10:30
Erster Treffer bei Google (Suchbegriff "oracle change fieldtype varchar2 to clob"): https://asktom.oracle.com/pls/asktom/f?p=100:11:0:::11_QUESTION_ID:177008670034649168 6
Detlef
"Ich habe Angst vor dem Tag, an dem die Technologie unsere menschlichen Interaktionen übertrumpft. Die Welt wird eine Generation von Idioten bekommen." (Albert Einstein)
Dieser Tag ist längst gekommen
  Mit Zitat antworten Zitat
Jumpy

Registriert seit: 9. Dez 2010
Ort: Mönchengladbach
1.740 Beiträge
 
Delphi 6 Enterprise
 
#2

AW: VARCHAR-Spalte durch CLOB ersetzen

  Alt 26. Sep 2014, 10:41
Von so einer Seite hatte ich auch meine 2 Vorschläge her, wobei mir die Version aus einem der Kommentare in deinem Link auch sehr zusagt:

Code:
alter table t add y_copy varchar2(4000);
update t set y_copy = y;
update t set y = null;
commit;
alter table t modify y long;
alter table t modify y clob;
update t set y = y_copy;
alter table t drop column y_copy;
Mir ging es jetzt weniger darum wie es geht, als darum, ob irgendwas zu beachten ist oder was vllt. effektiver oder sicherer ist.

Datensätze ~500Tsd.
Ralph
  Mit Zitat antworten Zitat
jobo

Registriert seit: 29. Nov 2010
3.072 Beiträge
 
Delphi 2010 Enterprise
 
#3

AW: VARCHAR-Spalte durch CLOB ersetzen

  Alt 26. Sep 2014, 11:46
Die Links die hier gezeigt wurden sind schon relativ alt.
Mit 11g gibt es vielleicht andere Möglichkeiten.
Über Typ "long" zu gehen, halte ich für etwas fragwürdig.
Ein Thema bei dem ganzen Kram ist bspw. Zeichencodierung. Long ist eigentlich "abgekündigt" oder so. Kann sein, dass es mit ein Byte Codierung geht. Würde ich auf jeden Fall testen.
Dann hat man den physikalischen Teil, also wo landet die Blobspalte, in der Tabelle, extra Tablespace, .. das kann man aber auch unabhängig von der Konvertierung später noch verschieben/ändern.
Dann wäre noch die Frage, auf welchen Systemen das durchgeführt werden muss. Auf ganz vielen Kundensystem im Rahmen eines Upgrades? Oder nur einmalig in der "Hausdatenbank"? Kann das System dafür abgeklemmt werden oder soll es online bleiben? Für online Umstrukturierung gibt es extra Paketfunktionen.
Gruß, Jo
  Mit Zitat antworten Zitat
Dejan Vu
(Gast)

n/a Beiträge
 
#4

AW: VARCHAR-Spalte durch CLOB ersetzen

  Alt 26. Sep 2014, 12:16
SSMS verwendet lustigerweise den 'alter table' Befehl selbst nicht, wenn man im Designer einen Feldtyp ändert, sondern geht den Weg über eine temporäre Tabelle, pseudocode:
To change column X to datatype Y in Table T:
  1. create table T_tmp with column 'X' as 'Y'
  2. copy all fields from T to T_tmp
  3. drop table T
  4. rename T_tmp to T
  5. rebuild all indexes, constraints and stuff on T

Das scheint schneller zu gehen, als ein das alter table. Bei bestimmten Aktionen stimmt das auch.
Ich denke, wenn Du das in eine Transaktion packst, kannst Du einfach den ALTER-Befehl nehmen.
Code:
begin transaction
alter table bar alter column foo CLOB
select * from bar
rollback transaction
wenn Du mit dem Resultat zufrieden bist, machst Du aus dem rollback ein commit und führst das Skript nochmal aus. So mach ich das immer. Der Vorteil ist ja, das man -wenn das Teil abschmiert- das Rollback auch per Hand ausführen kann.
  Mit Zitat antworten Zitat
jobo

Registriert seit: 29. Nov 2010
3.072 Beiträge
 
Delphi 2010 Enterprise
 
#5

AW: VARCHAR-Spalte durch CLOB ersetzen

  Alt 26. Sep 2014, 12:23
DDL Statements (wie alter table ) sind in oracle immer automatisch mit einem impliziten commit(!) verbunden.
Also Vorsicht bitte an der Stelle.
Gruß, Jo
  Mit Zitat antworten Zitat
Jumpy

Registriert seit: 9. Dez 2010
Ort: Mönchengladbach
1.740 Beiträge
 
Delphi 6 Enterprise
 
#6

AW: VARCHAR-Spalte durch CLOB ersetzen

  Alt 26. Sep 2014, 13:28
Ist nur eine einmalige Sache in einer Hausdatenbank, an der ich das Samstag morgen durchziehen kann.
Ich werde mal berichten wie es war.
Ralph
  Mit Zitat antworten Zitat
Dejan Vu
(Gast)

n/a Beiträge
 
#7

AW: VARCHAR-Spalte durch CLOB ersetzen

  Alt 26. Sep 2014, 13:31
DDL Statements (wie alter table ) sind in oracle immer automatisch mit einem impliziten commit(!) verbunden.
Also Vorsicht bitte an der Stelle.
Und nested transactions ziehen hier nicht? Aua.
  Mit Zitat antworten Zitat
Elvis

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

AW: VARCHAR-Spalte durch CLOB ersetzen

  Alt 26. Sep 2014, 15:01
DDL Statements (wie alter table ) sind in oracle immer automatisch mit einem impliziten commit(!) verbunden.
Also Vorsicht bitte an der Stelle.
Und nested transactions ziehen hier nicht? Aua.
Doch, teilweise.
Lassen sich aber bei Locks außerhalb der autonomen Transkation selten für etwas sinnvolles nutzen.

Zum Thema: du kannst dir ein Update sparen.
Du kannst in einem Schritt die temp. Spalte besetzen und dein Feld auf null setzen. Bei 500k sollte es aber egal sein. Das sollte nicht lange dauern.
Code:
alter table t add "temp column" clob;
update t set "temp column" = y, y = null;
alter table t modify y long;
alter table t modify y clob;
update t set y = "temp column";
alter table t drop column "temp column";
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 10:29 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-2025 by Thomas Breitkreuz