Sobes.tech
Back to questions
Junior — Middle
47

Имели ли опыт использования систем объектовно-реляционного отображения (ORM)

Companies where asked
Black Wall Group
Effective Mobile
GGSel

Answer from AI

sobes.tech AI

Да, опыт использования ORM в Python есть. ORM (Object-Relational Mapping) позволяет работать с базой данных через объекты, не используя напрямую SQL-запросы. Например, популярный ORM — SQLAlchemy. Он позволяет описывать таблицы как классы, а записи — как объекты этих классов.

Пример с SQLAlchemy:

from sqlalchemy import create_engine, Column, Integer, String
from sqlalchemy.ext.declarative import declarative_base
from sqlalchemy.orm import sessionmaker

Base = declarative_base()

class User(Base):
    __tablename__ = 'users'
    id = Column(Integer, primary_key=True)
    name = Column(String)

engine = create_engine('sqlite:///:memory:')
Base.metadata.create_all(engine)
Session = sessionmaker(bind=engine)
session = Session()

# Создаем нового пользователя
new_user = User(name='Иван')
session.add(new_user)
session.commit()

# Запрос пользователей
users = session.query(User).filter_by(name='Иван').all()
print(users)

ORM упрощает работу с данными, повышает читаемость и уменьшает количество ошибок, связанных с ручным написанием SQL.