Massimo ha scritto:
Manlio Perillo ha scritto:
[...]

In linea di massima quello che vuoi fare non mi sembra il modo migliore di procedere.

Perchè ti serve una cosa del genere?

Sto costruendo un "coso" per arrivare a fare cose tipo:

workspace = #inizializzazioni varie di dbms, session, etc.

oggetto = qualcosa(workspace)

oggetto.pk1=chiave1
oggetto.pk2=chiave2
oggetto.read()

ed a quel punto avere in "oggetto" i dati corrispondenti a quella pk nel dbms (se esistente).


Ma per fare questo non vedo perchè complicarsi la vita.

(In realtà il problema originale è che non riesco a fare l'update di un oggetto con SQLAlchemy, a meno che non sia caricato da session.query() e poi modificato).


Tieni conto che con SQLAlchemy non puoi modificare le primary key di un oggetto, tramite l'ORM.

Questo è un limite noto, c'è qualche discussione negli archivi della mailing list.

L'idea era di fare un oggetto nuovo, in ogni caso. Poi quando vengono inseriti i vari valori (controllo ridefinendo __setattr__) verifico se la chiave primaria sia completa, ed a quel punto tento di leggere il corrispondente oggetto dal dbms. Se non c'è non faccio nulla (l'oggetto è nuovo, e quindi quello già istanziato mi va bene com'è) ma se esiste invece di lavorare su un "nuovo" vorrei caricare i dati di quello esistente e, di li in avanti, casomai, modificarli fino al successivo .flush() (che in questo caso farà un update e non un insert).


Non sono proprio sicuro di capire la logica del tutto.
Quando vuoi salvare un oggetto, lo crei e quindi fai sess.save(obj) .
Se lo vuoi caricare fai sess.load(pk)

In genere le operazioni "crea nuovo" e "modifica esistente" sono ben separate, ma sembra esserci diversa gente per cui non è così (tanto che MySQL ha un INSERT OR UPDATE).

Ma non ne sto venendo fuori, non riesco a fare l'update ma solo l'inserimento di nuovi oggetti.


Se cambi la primary key, questo è normale.
Ma, di solito, la primary key non dovrebbe essere modificata;

[...]

In teoria quindi bastarebbe fare
self.__dict__.update(tmp.__dict__)

Si, giusto. Io avevo fatto stupidamente self.__dict__ = tmp.__dict__ scoprendo che non era la via giusta. Usando .__dict__.update() ho in effetti i dati che mi servono. Dovrei verificare però con oggetti complessi, con relazioni, come si comporterebbe... In ogni caso anche adesso il tentativo di .save_or_update() e .flush() non mi modifica i dati su disco... :(


Come controlli che i dati siano davvero aggiornati?

In questo momento sto avendo un problema analogo anche io, ma è sess.query che sembra non mi riporti lo stato aggiornato (mi è successo anche tempo fa ed avevo risolto).

Ma non tutto lo stato si trova nel dizionario, ci sono anche le property.
Così su due piedi non so dirti come fare a copiare tutto.

Già...


Un'altra soluzione è usare il pattern proxy.

class Proxy(object):
   def __init__(self, obj):
      self.obj = obj

   ...__setattr__/__getattr__

In questo caso ti basta modificare self.obj.



[...]
p.s. ho provato ad iscrivermi alla ml di SQLAlchemy, gestita da google, e ricevo i messaggi ma non riesco a spedirne. Qualcuno l'ha mai usata e mi può gentilmente suggerire "le basi"? Grazie ancora...

Google non ti manda i messaggi che tu hai spedito, come succede in questa mailing list, ad esempio.
Hai provavo a vedere dall'interfaccia web?

No, il problema è proprio che mi ritornano indietro i messaggi che spedisco. Ma ho usato il mio account, non uno di google... si potrà fare lostesso, io penso, no?


Sembra proprio di no.


Saluti  Manlio Perillo
_______________________________________________
Python mailing list
Python@lists.python.it
http://lists.python.it/mailman/listinfo/python

Rispondere a