Hallo, ich beisse mich derzeit durch Catalyst und Co und habe ein bisschen Probleme mit der etwas spärlichen Dokumentation.
Ich bin gerade auf ein Problem gestossen eine Methode augzurufen, die es mir erlaubt die Column-Namen eines Tables aus mysql zu bekommen. Für das Model in Catalyst benutze ich DBIx, die Tabellen sind in von DBIx::Class abgeleiteten Klassen.
Diese Klasse enthält die Methode 'columns' welche genau das obige ausführt.
In Catalyst wird die Ansteuerung von Objekten einer Webapplikation ja über ein Context-Object umgesetzt, wenn ich dieses aber aufrufe, um auf den Table zuzugreifen, bekomme ich ein DBIx::Class:ResultSet (Unterklasse von DBIx::Class) zurück und erhalte die Fehlermeldung:
DBIx::Class:ResultSet hat keine Methode "columns"
Zugriff auf den Table erfolgt so:
my $result = [$c->model('testDB::NameDesTable')->all];
Wobei 'testDB::NameDesTable' der Name der Tabelle ist und model() eine Catalyst-Methode, um das entsprechende Model-Objekt aufzurufen.
Anfang von NameDesTable.pm (Model der Tabelle):
package testDB::NameDesTable;
use base qw/DBIx::Class/;
Bei der Model-Definition wird aber eigentlich die DBIx::Class eingebunden, also scheint Catalyst von sich aus bei dem Zugriff auf eine Tabelle nur ein DBIx::Class:Resultset zurückzugeben.
Lange Rede, kurzer Sinn, gibt es irgendeine Möglichkeit (in Catalyst oder Perl allgemein) das ganze auf die Überklasse zu 'casten' bzw. die dahinterstehende Klasse zurückzubekommen, um deren Methoden verwenden zu können?
Danke für alle Anregungen, Ideen, Beschimpfungen!
[edit=betterworld]code-tags[/edit]\n\n
<!--EDIT|betterworld|1149236309-->