Для всех, кто заинтересовался, я наконец-то получил его (ниже я изменил идентификаторы своего рабочего кода, чтобы он соответствовал оригинальному сообщению):
# imports
from sqlalchemy import create_engine, Table, Column, Integer, String, MetaData
from sqlalchemy.orm import mapper, sessionmaker
from Person import Person
# mysql database
engine = create_engine("mysql+mysqlconnector://root@localhost/dbpersonnes")
# metadata
metadata = MetaData()
# table
persons_table = Table("persons", metadata,
Column('col1', Integer, primary_key=True),
Column('col2', String(30), nullable=False),
Column("col3", String(30), nullable=False),
Column("col4", Integer, nullable=False)
)
# mapping
mapper(Person, persons_table, properties={
'id': persons_table.c.col1,
'firstname': persons_table.c.col2,
'name': persons_table.c.col3,
'age': persons_table.c.col4,
})
# session factory
Session = sessionmaker()
Session.configure(bind=engine)
# session
session = Session()
# insert
session.add(Personne(67, "x", "y", 10))
session.commit()
# query
personnes = session.query(Personne).all()
# logs
for personne in personnes:
print(personne)