개발(합니다)/Python

[Python] SQLAlchemy CRUD 사용하는 방법

otrodevym 2021. 11. 9. 00:00
반응형

SQLAlchemy를 사용하면서 CRUD 사용하는 방법에 대한 포스팅입니다.

Create

session.add('추가할 객체 이름')
session.commit()

ex) User를 DB에 추가
    tmpUser = User(name, fullname, password)
    session.add(tmpUser)
    session.commit()

Update

session.query('수정할 객체 타입').filter_by('수정할 객체 정보').update('수정 사항')
session.commit()

ex) 입력한 name, fullname, password가 모두 일치하는 User의 정보 수정
    session.query(User).filter_by(name = name, fullname = fullname, password = password).update({"name" : pname, "fullname" : pfullname, "password" : ppassword})
    session.commit()

DELETE

session.query('삭제할 객체 타입').filter_by('삭제할 객체 정보')
session.commit()

ex) 입력한 name, fullname, password가 모두 일치하는 User 삭제
    session.query(User).filter_by(name=name, fullname=fullname, password=password).delete()
    session.commit()

Select

obj = session.query('검색할 객체 타입').filter_by('검색 옵션')

ex) 입력한 name, fullname, password가 모두 일치하는 User 검색
    tmpUser = session.query(User).filter_by(name = name, fullname = fullname, password = password)
    print tmpUser

select는 다양한 방법으로 사용 가능합니다.

    def findByName(self, tableName, name):

        table = db.Table(tableName, metadata, autoload=True, autoload_with=DATABASES)
        query = db.select([table]).where(table.columns.name == name)
        result_data = connection.execute(query)
        return result_data.fetchall()

테이블 전체 조회하는 방법

    def get(self, tableName):

        table = db.Table(tableName, metadata, autoload=True, autoload_with=DATABASES)
        query = db.select([table])

        result_data = connection.execute(query)
        return result_data.fetchall()

 

반응형