2013-03-02 11 views
17

Sto imparando sqlalchemy. Qui è il mio codice iniziale:SQLAlchemy - cosa è dichiarative_base

File: user.py

from sqlalchemy import Column,Integer,Sequence, String 
from sqlalchemy.ext.declarative import declarative_base 
Base = declarative_base() 
class User(Base): 
    __tablename__ = 'users' 
    id = Column(Integer,Sequence('user_seq'),primary_key=True) 
    username = Column(String(50),unique=True) 
    fullname = Column(String(150)) 
    password = Column(String(50)) 
    def __init__(self,name,fullname,password): 
    self.name = name 
    self.fullname = fullname 
    self.password = password 

main.py File

from sqlalchemy.orm import sessionmaker 
from sqlalchemy import create_engine 
from user import User 
from sqlalchemy.ext.declarative import declarative_base 
Base = declarative_base() 
if __name__ == '__main__': 
    engine = create_engine('mysql://root:[email protected]:3306/test',echo=True) 
    Base.metadata.create_all(engine, checkfirst=True) 
    Session = sessionmaker(bind=engine) 
    session = Session() 
    ed_user = User('ed', 'Ed Jones', 'edspassword') 
    session.add(ed_user) 
    session.commit() 

Ora quando corro main.py. Non creerà la tabella automaticamente & dammi un'eccezione su 'session.commit()'. Ora quando passo la riga 'Base = declarative_base()' al modulo diverso & usa la stessa variabile 'Base' in main.py & user.py. Crea tavolo.

La mia domanda è che cosa è 'declarative_base'?

+0

Qual è l'errore che si ottiene quando lo si fa nell'altro modo? –

risposta

19

declarative_base() è una funzione factory che costruisce una classe base per definizioni di classi dichiarative (che è assegnata alla variabile Base nell'esempio). Quello che hai creato in user.py è associato al modello User, mentre l'altro (in main.py) è una classe diversa e non sa nulla dei tuoi modelli, ecco perché la chiamata Base.metadata.create_all() non ha creato la tabella. È necessario importare Base da user.py

from user import User, Base 

invece di creare una nuova classe nel Base main.py.

+1

Ho creato un nuovo file e inserito le seguenti due righe
riga 1: da sqlalchemy.ext.declarative import declarative_base riga 2: Base = declarative_base()
Ho creato in questo modo perché sto creando più classi di modelli in file diversi. Nessuna ragione specifica dietro a questo, ho solo usato i bean in questo modo in java. Grazie per la risposta. – Aniruddha

+0

@Aniruddha Grazie per il suggerimento. Ho anche messo quelle 2 righe nel file '__init __. Py' del modulo &' dalla base di importazione mymodule' –