Mein SQL

PHP ist schon toll. MySQL natürlich auch! Doch ist es nicht mühsam, wenn man eine Tabelle mit ~1000 Einträgen hat und merkt, dass man in einem Feld etwas vergessen hat wegzulassen?

Die “normale” Lösung wäre nun, ein PHP Skript zu schreiben, welches die Tabelle komplett runterlädt, denn Fehler mit PHP-Funktionen reparieren und denn wieder alles in die Tabelle einfügen. Nach mehrmaligem wiederholen von solch einer Prozedur wird man bald einmal nach einem besseren Weg suchen … und in SQL selbst finden!

Mein Problem:

Wie es ist:

Sean Connery::James Bond
Skinner::imdb:nm0000125
Ursula Andress::Honey Ryder
Skinner::imdb:nm0000266
Joseph Wiseman::Dr. No
Skinner::imdb:nm0936476
Jack Lord::Felix Leiter
Skinner::imdb:nm0520437

Wie es sein sollte:

Sean Connery::James Bond::imdb:nm0000125
Ursula Andress::Honey Ryder::imdb:nm0000266
Joseph Wiseman::Dr. No::imdb:nm0936476
Jack Lord::Felix Leiter::imdb:nm0520437

Meine Lösung in SQL:

Anzeigen (zur Kontrolle):

SELECT REPLACE([spalten_name],’[such_string]’,’[ersetz_string]’) FROM [tabelle];
z.B. SELECT REPLACE(actors,’nSkinner›,») FROM videodb_videodata;

Ersetzten (wenn Kontrolle OK):

UPDATE [tabelle] SET [spalten_name] = REPLACE([spalten_name],’[such_string]’,’[ersetz_string]’);
z.B. UPDATE videodb_videodata SET actors = REPLACE(actors,’nSkinner›,»);

Nun gut dieses Problem wäre gelöst! Doch Moment mal, da hab ich in jedem Feld noch einen Zeilenumbruch, welcher nicht dort sein sollte. Doch zum Glück besitzt SQL auch noch weitere praktische Funktionen!

Entfernen eines Zeichen am Schluss

Wie es ist:


Maxwell Shaw::Communications Foreman (uncredited)::imdb:nm0789871
Bob Simmons::James Bond in Gunbarrel Sequence (uncredited)::imdb:nm0799689
  

Wie es sein soll:


Maxwell Shaw::Communications Foreman (uncredited)::imdb:nm0789871
Bob Simmons::James Bond in Gunbarrel Sequence (uncredited)::imdb:nm0799689

   = nichts, soll nur Umbruch veranschaulichen

Lösung

Anzeigen (zur Kontrolle):

SELECT SUBSTR([spalten_name],[start_pos_beginnt_1],{[länge]}) FROM [tabelle];
z.B. SELECT SUBSTR(actors,1,LENGTH(actors)) FROM videodb_videodata;

Ersetzten (wenn Kontrolle OK):

UPDATE [tabelle] SET [spalten_name] = SUBSTR([spalten_name],[start_pos_beginnt_1],{[länge]});
z.B. UPDATE videodb_videodata SET actors = SUBSTR(actors,1,LENGTH(actors));

Nun für ein wenig mehr erfahrene Personen war dies nun wohl offensichtlich, aber vielleicht kann es ja au anderen von Nutzen sein.

Eine kurze Übersicht über die verschiedenen Befehle in SQL findet man hier (English).
Die Probleme sind aus dem Arbeiten mit VideoDB [1] [2] [3] und eigenen Update Skripts entstanden.

[1] http://www.videodb.net/blog/
[2] http://sourceforge.net/projects/videodb/
[3] http://www.splitbrain.org/projects/videodb

Kommentare [0]
Geschrieben am 26.07.2009 von admin in Computer, Web
TrackbackPermanent Link

Hinterlasse einen Kommentar