SQLAlchemy ORM - dodawanie obiektów
W poprzednich rozdziałach SQLAlchemy ORM nauczyliśmy się, jak deklarować mapowanie i tworzyć sesje. W tym rozdziale nauczymy się, jak dodawać obiekty do tabeli.
Zadeklarowaliśmy klasę Customer, która została zmapowana do tabeli klientów. Musimy zadeklarować obiekt tej klasy i na stałe dodać go do tablicy metodą add () obiektu sesji.
c1 = Sales(name = 'Ravi Kumar', address = 'Station Road Nanded', email = '[email protected]')
session.add(c1)
Zwróć uwagę, że ta transakcja jest w toku, dopóki ta sama nie zostanie opróżniona za pomocą metody commit ().
session.commit()
Poniżej znajduje się kompletny skrypt dodawania rekordu w tabeli klientów -
from sqlalchemy import Column, Integer, String
from sqlalchemy import create_engine
engine = create_engine('sqlite:///sales.db', echo = True)
from sqlalchemy.ext.declarative import declarative_base
Base = declarative_base()
class Customers(Base):
__tablename__ = 'customers'
id = Column(Integer, primary_key=True)
name = Column(String)
address = Column(String)
email = Column(String)
from sqlalchemy.orm import sessionmaker
Session = sessionmaker(bind = engine)
session = Session()
c1 = Customers(name = 'Ravi Kumar', address = 'Station Road Nanded', email = '[email protected]')
session.add(c1)
session.commit()
Aby dodać wiele rekordów, możemy użyć add_all() metoda klasy sesji.
session.add_all([
Customers(name = 'Komal Pande', address = 'Koti, Hyderabad', email = '[email protected]'),
Customers(name = 'Rajender Nath', address = 'Sector 40, Gurgaon', email = '[email protected]'),
Customers(name = 'S.M.Krishna', address = 'Budhwar Peth, Pune', email = '[email protected]')]
)
session.commit()
Widok tabeli SQLiteStudio pokazuje, że rekordy są trwale dodawane do tabeli klientów. Poniższy obraz przedstawia wynik -