일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |
- GRU
- 선형대수
- Sort
- codingthematrix
- yarn
- 하이브
- scrapy
- 그래프이론
- C
- 파이썬
- effective python
- 딥러닝
- tensorflow
- LSTM
- 하둡2
- hive
- collections
- hadoop2
- C언어
- RNN
- 코딩더매트릭스
- python
- Java
- recursion
- NumPy
- 텐서플로
- graph
- 주식분석
- 알고리즘
- HelloWorld
- Today
- Total
EXCELSIOR
Python에서 SQLAlchemy로 MS-SQL 연동하기 본문
Java에서는 Mybatis를 통해 SQL 연동을 아주 간편하게 할 수 있다.
이런 것을 ORM이라고 하는데, ORM(Object Relation Mapping)이란 오브젝트와 RDB사이에 존재하는 개념과 접근방법, 성격의 차이 때문에 요구되는 불편한 작업을 제거해줘서 개발자가 오브젝트를 가지고 정보를 다루면 ORM프레임워크가 이를 RDB에 적절한 형태로 변환해 주거나 그 반대로 RDB에 저장되어 있는 정보를 오브젝트가 다루기 쉬운 형태로 변환해 주는 것을 말한다.
Python에도 Java처럼 ORM이 있을까 구글링해본 결과, SQLAlchemy라는게 있었다. 이번 포스팅에서는 SQLAlchemy를 통해 Python에서 MS-SQL을 연동해 보도록 하겠다.
(이글은 http://docs.sqlalchemy.org/en/latest/orm/tutorial.html 이 곳을 참고하여 작성함)
1. SQLAlchemy 설치
먼저, sqlalchemy를 사용하려면 sqlalchemy 패키지를 설치해야 한다. pip 명령어를 통해 설치하는 방법은 여기를 참고하면 된다.
pip install sqlalchemy
2. MS-SQL과 연동
sqlalchemy를 import하여 create_engine( )함수를 통해 MS-SQL과 접속한다. 다른 DB와의 연결은 아래의 링크를 참조하면 접속하는 방법이 나온다.
http://docs.sqlalchemy.org/en/rel_0_9/core/engines.html
아래의 코드에서 echo는 로그를 위한 플래그이다. 순수 SQL코드를 보여준다.
from sqlalchemy import create_engine engine = create_engine('mssql+pymssql://username:passwd@host/database', echo=True)
3. 매핑 선언
ORM을 사용할 때 처리할 데이터베이스의 테이블을 설명하고 핻아 테이블에 매핑(Mapping) 될 클래스를 정의하는 작업이 필요하다. 처리할 작업이 필요한 테이블에 대해서 Mapping 클래스를 생성해주면 된다.
sqlalchemy의 declarative_base( )를 사용하여 클래스를 생성한다. 클래스를 생성할 때는 '__tablename__'' 과 ''Primary key''가 반드시 필요하다.
아래의 코드의 __repr__( )함수는 선택사항이므로 작성을 굳이 안해줘도 된다.
from sqlalchemy.ext.declarative import declarative_base from sqlalchemy import Column, SMALLINT, BIGINT, String # 매핑 선언 Base = declarative_base() # Mapping 클래스 생성 class 테이블명(Base): # 식별하기 쉽게 테이블명으로 지정 __tablename__ = '테이블명' col1 = Column(SMALLINT) col2 = Column(BIGINT, primary_key=True) col3 = Column(String) col4 = Column(String) def __init__(self, col1, col2, col3, col4): self.col1 = col1 self.col2 = col2 self.col3 = col3 self.col4 = col4 def __repr__(self): return "<테이블명('%d', '%d', '%s', '%s')>" % (self.col1, self.col2, self.col3, self.col4)
4. 세션 생성
'Session'을 통해 데이터베이스를 다룰 수 있다. create_engine( )을 import 했던 같은 레벨에서 session을 생성하기 위한, sessionmaker를 import 할 수 있다.
from sqlalchemy.orm import sessionmaker # session 생성 Session = sessionmaker(bind=engine) session = Session()
5. 테스트
이제 제대로 연결이 되었는지 아래의 코드를 통해 테스트 해본다.
for row in session.query(클래스명=테이블명): # 클래스 명을 테이블 명으로 해서 동일함 print(row.col1)
'Python' 카테고리의 다른 글
Python에 KoNLPy 설치 및 예제 실행 (5) | 2016.12.06 |
---|---|
Python에 numpy 설치 및 실행 (0) | 2016.12.01 |