<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="ko">
	<id>https://devcafe.co.kr/w/index.php?action=history&amp;feed=atom&amp;title=%ED%8C%8C%EC%9D%B4%EC%8D%AC_%EB%8D%B0%EC%BD%94%EB%A0%88%EC%9D%B4%ED%84%B0_decorater</id>
	<title>파이썬 데코레이터 decorater - 편집 역사</title>
	<link rel="self" type="application/atom+xml" href="https://devcafe.co.kr/w/index.php?action=history&amp;feed=atom&amp;title=%ED%8C%8C%EC%9D%B4%EC%8D%AC_%EB%8D%B0%EC%BD%94%EB%A0%88%EC%9D%B4%ED%84%B0_decorater"/>
	<link rel="alternate" type="text/html" href="https://devcafe.co.kr/w/index.php?title=%ED%8C%8C%EC%9D%B4%EC%8D%AC_%EB%8D%B0%EC%BD%94%EB%A0%88%EC%9D%B4%ED%84%B0_decorater&amp;action=history"/>
	<updated>2026-04-05T04:36:21Z</updated>
	<subtitle>이 문서의 편집 역사</subtitle>
	<generator>MediaWiki 1.42.1</generator>
	<entry>
		<id>https://devcafe.co.kr/w/index.php?title=%ED%8C%8C%EC%9D%B4%EC%8D%AC_%EB%8D%B0%EC%BD%94%EB%A0%88%EC%9D%B4%ED%84%B0_decorater&amp;diff=1853&amp;oldid=prev</id>
		<title>2025년 6월 23일 (월) 23:59에 Devcafe님의 편집</title>
		<link rel="alternate" type="text/html" href="https://devcafe.co.kr/w/index.php?title=%ED%8C%8C%EC%9D%B4%EC%8D%AC_%EB%8D%B0%EC%BD%94%EB%A0%88%EC%9D%B4%ED%84%B0_decorater&amp;diff=1853&amp;oldid=prev"/>
		<updated>2025-06-23T23:59:23Z</updated>

		<summary type="html">&lt;p&gt;&lt;/p&gt;
&lt;table style=&quot;background-color: #fff; color: #202122;&quot; data-mw=&quot;interface&quot;&gt;
				&lt;col class=&quot;diff-marker&quot; /&gt;
				&lt;col class=&quot;diff-content&quot; /&gt;
				&lt;col class=&quot;diff-marker&quot; /&gt;
				&lt;col class=&quot;diff-content&quot; /&gt;
				&lt;tr class=&quot;diff-title&quot; lang=&quot;ko&quot;&gt;
				&lt;td colspan=&quot;2&quot; style=&quot;background-color: #fff; color: #202122; text-align: center;&quot;&gt;← 이전 판&lt;/td&gt;
				&lt;td colspan=&quot;2&quot; style=&quot;background-color: #fff; color: #202122; text-align: center;&quot;&gt;2025년 6월 24일 (화) 08:59 판&lt;/td&gt;
				&lt;/tr&gt;&lt;tr&gt;&lt;td colspan=&quot;2&quot; class=&quot;diff-lineno&quot; id=&quot;mw-diff-left-l96&quot;&gt;96번째 줄:&lt;/td&gt;
&lt;td colspan=&quot;2&quot; class=&quot;diff-lineno&quot;&gt;96번째 줄:&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;== 관련글 ==&lt;/div&gt;&lt;/td&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;== 관련글 ==&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;* [[다중DB + 커넥션풀캐시 + 데코레이터]]&lt;/div&gt;&lt;/td&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;* [[다중DB + 커넥션풀캐시 + 데코레이터]]&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td colspan=&quot;2&quot; class=&quot;diff-side-deleted&quot;&gt;&lt;/td&gt;&lt;td class=&quot;diff-marker&quot; data-marker=&quot;+&quot;&gt;&lt;/td&gt;&lt;td style=&quot;color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #a3d3ff; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;&lt;ins style=&quot;font-weight: bold; text-decoration: none;&quot;&gt;&lt;/ins&gt;&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td colspan=&quot;2&quot; class=&quot;diff-side-deleted&quot;&gt;&lt;/td&gt;&lt;td class=&quot;diff-marker&quot; data-marker=&quot;+&quot;&gt;&lt;/td&gt;&lt;td style=&quot;color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #a3d3ff; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;&lt;ins style=&quot;font-weight: bold; text-decoration: none;&quot;&gt;[[category:python]]&lt;/ins&gt;&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;/table&gt;</summary>
		<author><name>Devcafe</name></author>
	</entry>
	<entry>
		<id>https://devcafe.co.kr/w/index.php?title=%ED%8C%8C%EC%9D%B4%EC%8D%AC_%EB%8D%B0%EC%BD%94%EB%A0%88%EC%9D%B4%ED%84%B0_decorater&amp;diff=1706&amp;oldid=prev</id>
		<title>Devcafe: /* 관련글 */</title>
		<link rel="alternate" type="text/html" href="https://devcafe.co.kr/w/index.php?title=%ED%8C%8C%EC%9D%B4%EC%8D%AC_%EB%8D%B0%EC%BD%94%EB%A0%88%EC%9D%B4%ED%84%B0_decorater&amp;diff=1706&amp;oldid=prev"/>
		<updated>2025-06-16T23:23:07Z</updated>

		<summary type="html">&lt;p&gt;&lt;span dir=&quot;auto&quot;&gt;&lt;span class=&quot;autocomment&quot;&gt;관련글&lt;/span&gt;&lt;/span&gt;&lt;/p&gt;
&lt;table style=&quot;background-color: #fff; color: #202122;&quot; data-mw=&quot;interface&quot;&gt;
				&lt;col class=&quot;diff-marker&quot; /&gt;
				&lt;col class=&quot;diff-content&quot; /&gt;
				&lt;col class=&quot;diff-marker&quot; /&gt;
				&lt;col class=&quot;diff-content&quot; /&gt;
				&lt;tr class=&quot;diff-title&quot; lang=&quot;ko&quot;&gt;
				&lt;td colspan=&quot;2&quot; style=&quot;background-color: #fff; color: #202122; text-align: center;&quot;&gt;← 이전 판&lt;/td&gt;
				&lt;td colspan=&quot;2&quot; style=&quot;background-color: #fff; color: #202122; text-align: center;&quot;&gt;2025년 6월 17일 (화) 08:23 판&lt;/td&gt;
				&lt;/tr&gt;&lt;tr&gt;&lt;td colspan=&quot;2&quot; class=&quot;diff-lineno&quot; id=&quot;mw-diff-left-l95&quot;&gt;95번째 줄:&lt;/td&gt;
&lt;td colspan=&quot;2&quot; class=&quot;diff-lineno&quot;&gt;95번째 줄:&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;br&gt;&lt;/td&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;br&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;== 관련글 ==&lt;/div&gt;&lt;/td&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;== 관련글 ==&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class=&quot;diff-marker&quot; data-marker=&quot;−&quot;&gt;&lt;/td&gt;&lt;td style=&quot;color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #ffe49c; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;* [[&lt;del style=&quot;font-weight: bold; text-decoration: none;&quot;&gt;다중디비 &lt;/del&gt;커넥션풀캐시 데코레이터]]&lt;/div&gt;&lt;/td&gt;&lt;td class=&quot;diff-marker&quot; data-marker=&quot;+&quot;&gt;&lt;/td&gt;&lt;td style=&quot;color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #a3d3ff; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;* [[&lt;ins style=&quot;font-weight: bold; text-decoration: none;&quot;&gt;다중DB + &lt;/ins&gt;커넥션풀캐시 &lt;ins style=&quot;font-weight: bold; text-decoration: none;&quot;&gt;+ &lt;/ins&gt;데코레이터]]&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;/table&gt;</summary>
		<author><name>Devcafe</name></author>
	</entry>
	<entry>
		<id>https://devcafe.co.kr/w/index.php?title=%ED%8C%8C%EC%9D%B4%EC%8D%AC_%EB%8D%B0%EC%BD%94%EB%A0%88%EC%9D%B4%ED%84%B0_decorater&amp;diff=1705&amp;oldid=prev</id>
		<title>2025년 6월 16일 (월) 23:22에 Devcafe님의 편집</title>
		<link rel="alternate" type="text/html" href="https://devcafe.co.kr/w/index.php?title=%ED%8C%8C%EC%9D%B4%EC%8D%AC_%EB%8D%B0%EC%BD%94%EB%A0%88%EC%9D%B4%ED%84%B0_decorater&amp;diff=1705&amp;oldid=prev"/>
		<updated>2025-06-16T23:22:36Z</updated>

		<summary type="html">&lt;p&gt;&lt;/p&gt;
&lt;table style=&quot;background-color: #fff; color: #202122;&quot; data-mw=&quot;interface&quot;&gt;
				&lt;col class=&quot;diff-marker&quot; /&gt;
				&lt;col class=&quot;diff-content&quot; /&gt;
				&lt;col class=&quot;diff-marker&quot; /&gt;
				&lt;col class=&quot;diff-content&quot; /&gt;
				&lt;tr class=&quot;diff-title&quot; lang=&quot;ko&quot;&gt;
				&lt;td colspan=&quot;2&quot; style=&quot;background-color: #fff; color: #202122; text-align: center;&quot;&gt;← 이전 판&lt;/td&gt;
				&lt;td colspan=&quot;2&quot; style=&quot;background-color: #fff; color: #202122; text-align: center;&quot;&gt;2025년 6월 17일 (화) 08:22 판&lt;/td&gt;
				&lt;/tr&gt;&lt;tr&gt;&lt;td colspan=&quot;2&quot; class=&quot;diff-lineno&quot; id=&quot;mw-diff-left-l93&quot;&gt;93번째 줄:&lt;/td&gt;
&lt;td colspan=&quot;2&quot; class=&quot;diff-lineno&quot;&gt;93번째 줄:&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;** 비동기 데코레이터 (async with)&lt;/div&gt;&lt;/td&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;** 비동기 데코레이터 (async with)&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;** JSON 설정 기반 자동 커넥션 선택&lt;/div&gt;&lt;/td&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;** JSON 설정 기반 자동 커넥션 선택&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td colspan=&quot;2&quot; class=&quot;diff-side-deleted&quot;&gt;&lt;/td&gt;&lt;td class=&quot;diff-marker&quot; data-marker=&quot;+&quot;&gt;&lt;/td&gt;&lt;td style=&quot;color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #a3d3ff; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;&lt;ins style=&quot;font-weight: bold; text-decoration: none;&quot;&gt;&lt;/ins&gt;&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td colspan=&quot;2&quot; class=&quot;diff-side-deleted&quot;&gt;&lt;/td&gt;&lt;td class=&quot;diff-marker&quot; data-marker=&quot;+&quot;&gt;&lt;/td&gt;&lt;td style=&quot;color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #a3d3ff; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;&lt;ins style=&quot;font-weight: bold; text-decoration: none;&quot;&gt;== 관련글 ==&lt;/ins&gt;&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td colspan=&quot;2&quot; class=&quot;diff-side-deleted&quot;&gt;&lt;/td&gt;&lt;td class=&quot;diff-marker&quot; data-marker=&quot;+&quot;&gt;&lt;/td&gt;&lt;td style=&quot;color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #a3d3ff; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;&lt;ins style=&quot;font-weight: bold; text-decoration: none;&quot;&gt;* [[다중디비 커넥션풀캐시 데코레이터]]&lt;/ins&gt;&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;/table&gt;</summary>
		<author><name>Devcafe</name></author>
	</entry>
	<entry>
		<id>https://devcafe.co.kr/w/index.php?title=%ED%8C%8C%EC%9D%B4%EC%8D%AC_%EB%8D%B0%EC%BD%94%EB%A0%88%EC%9D%B4%ED%84%B0_decorater&amp;diff=1704&amp;oldid=prev</id>
		<title>Devcafe: 새 문서: == 파이썬 데코레이터 == {{알림 |내용=데코레이터를 사용하여 데이터베이스(DB) 접속 * 반복적인 DB 연결/해제 로직을 깔끔하게 감싸는 데 유용합니다. }}  === 기본 구조 === # 데코레이터 함수: DB에 연결하고, wrapped 함수 실행 후 연결 해제 # 커넥션 객체: sqlite3, psycopg2, cx_Oracle, pymysql 등 사용 가능 #:* 활용 예시: 쿼리 실행 시 자동으로 연결, 종료를 처리  ----  === 예제 (SQLi...</title>
		<link rel="alternate" type="text/html" href="https://devcafe.co.kr/w/index.php?title=%ED%8C%8C%EC%9D%B4%EC%8D%AC_%EB%8D%B0%EC%BD%94%EB%A0%88%EC%9D%B4%ED%84%B0_decorater&amp;diff=1704&amp;oldid=prev"/>
		<updated>2025-06-16T23:16:00Z</updated>

		<summary type="html">&lt;p&gt;새 문서: == 파이썬 데코레이터 == {{알림 |내용=데코레이터를 사용하여 데이터베이스(DB) 접속 * 반복적인 DB 연결/해제 로직을 깔끔하게 감싸는 데 유용합니다. }}  === 기본 구조 === # 데코레이터 함수: DB에 연결하고, wrapped 함수 실행 후 연결 해제 # 커넥션 객체: sqlite3, psycopg2, cx_Oracle, pymysql 등 사용 가능 #:* 활용 예시: 쿼리 실행 시 자동으로 연결, 종료를 처리  ----  === 예제 (SQLi...&lt;/p&gt;
&lt;p&gt;&lt;b&gt;새 문서&lt;/b&gt;&lt;/p&gt;&lt;div&gt;== 파이썬 데코레이터 ==&lt;br /&gt;
{{알림&lt;br /&gt;
|내용=데코레이터를 사용하여 데이터베이스(DB) 접속&lt;br /&gt;
* 반복적인 DB 연결/해제 로직을 깔끔하게 감싸는 데 유용합니다.&lt;br /&gt;
}}&lt;br /&gt;
&lt;br /&gt;
=== 기본 구조 ===&lt;br /&gt;
# 데코레이터 함수: DB에 연결하고, wrapped 함수 실행 후 연결 해제&lt;br /&gt;
# 커넥션 객체: sqlite3, psycopg2, cx_Oracle, pymysql 등 사용 가능&lt;br /&gt;
#:* 활용 예시: 쿼리 실행 시 자동으로 연결, 종료를 처리&lt;br /&gt;
&lt;br /&gt;
----&lt;br /&gt;
&lt;br /&gt;
=== 예제 (SQLite 기준) ===&lt;br /&gt;
&amp;lt;source lang=python&amp;gt;&lt;br /&gt;
import sqlite3&lt;br /&gt;
from functools import wraps&lt;br /&gt;
&lt;br /&gt;
# 데코레이터 정의&lt;br /&gt;
def with_db_connection(func):&lt;br /&gt;
    @wraps(func)&lt;br /&gt;
    def wrapper(*args, **kwargs):&lt;br /&gt;
        conn = sqlite3.connect(&amp;quot;example.db&amp;quot;)  # 연결&lt;br /&gt;
        try:&lt;br /&gt;
            result = func(conn, *args, **kwargs)  # 함수에 conn 전달&lt;br /&gt;
            conn.commit()&lt;br /&gt;
            return result&lt;br /&gt;
        except Exception as e:&lt;br /&gt;
            conn.rollback()&lt;br /&gt;
            raise e&lt;br /&gt;
        finally:&lt;br /&gt;
            conn.close()  # 연결 종료&lt;br /&gt;
    return wrapper&lt;br /&gt;
&lt;br /&gt;
# 실제 사용&lt;br /&gt;
@with_db_connection&lt;br /&gt;
def create_table(conn):&lt;br /&gt;
    cursor = conn.cursor()&lt;br /&gt;
    cursor.execute(&amp;quot;&amp;quot;&amp;quot;&lt;br /&gt;
        CREATE TABLE IF NOT EXISTS users (&lt;br /&gt;
            id INTEGER PRIMARY KEY AUTOINCREMENT,&lt;br /&gt;
            name TEXT&lt;br /&gt;
        )&lt;br /&gt;
    &amp;quot;&amp;quot;&amp;quot;)&lt;br /&gt;
&lt;br /&gt;
@with_db_connection&lt;br /&gt;
def insert_user(conn, name):&lt;br /&gt;
    cursor = conn.cursor()&lt;br /&gt;
    cursor.execute(&amp;quot;INSERT INTO users (name) VALUES (?)&amp;quot;, (name,))&lt;br /&gt;
&lt;br /&gt;
@with_db_connection&lt;br /&gt;
def get_users(conn):&lt;br /&gt;
    cursor = conn.cursor()&lt;br /&gt;
    cursor.execute(&amp;quot;SELECT * FROM users&amp;quot;)&lt;br /&gt;
    return cursor.fetchall()&lt;br /&gt;
&lt;br /&gt;
# 함수 실행&lt;br /&gt;
create_table()&lt;br /&gt;
insert_user(&amp;quot;Alice&amp;quot;)&lt;br /&gt;
insert_user(&amp;quot;Bob&amp;quot;)&lt;br /&gt;
print(get_users())  # [(&amp;#039;1&amp;#039;, &amp;#039;Alice&amp;#039;), (&amp;#039;2&amp;#039;, &amp;#039;Bob&amp;#039;)]&lt;br /&gt;
&lt;br /&gt;
&amp;lt;/source&amp;gt;&lt;br /&gt;
&lt;br /&gt;
==== 장점 ====&lt;br /&gt;
* 중복되는 connect() / close() 코드 제거&lt;br /&gt;
* 트랜잭션 자동 처리 (commit, rollback)&lt;br /&gt;
* 커넥션 전달을 깔끔하게 통제 가능&lt;br /&gt;
----&lt;br /&gt;
&lt;br /&gt;
=== 다른 DB 예시 (psycopg2, cx_Oracle, pymysql) ===&lt;br /&gt;
&lt;br /&gt;
* 필요에 따라 아래처럼 응용 가능:&lt;br /&gt;
&amp;lt;source lang=python&amp;gt;&lt;br /&gt;
def with_pg_connection(func):&lt;br /&gt;
    @wraps(func)&lt;br /&gt;
    def wrapper(*args, **kwargs):&lt;br /&gt;
        conn = psycopg2.connect(&lt;br /&gt;
            host=&amp;quot;localhost&amp;quot;,&lt;br /&gt;
            database=&amp;quot;mydb&amp;quot;,&lt;br /&gt;
            user=&amp;quot;myuser&amp;quot;,&lt;br /&gt;
            password=&amp;quot;mypassword&amp;quot;&lt;br /&gt;
        )&lt;br /&gt;
        try:&lt;br /&gt;
            return func(conn, *args, **kwargs)&lt;br /&gt;
        finally:&lt;br /&gt;
            conn.close()&lt;br /&gt;
    return wrapper&lt;br /&gt;
&amp;lt;/source&amp;gt;&lt;br /&gt;
&lt;br /&gt;
* 추가적으로 필요하신 구조&lt;br /&gt;
** 커넥션 풀 연동 (cx_Oracle.SessionPool, psycopg2.pool)&lt;br /&gt;
** 비동기 데코레이터 (async with)&lt;br /&gt;
** JSON 설정 기반 자동 커넥션 선택&lt;/div&gt;</summary>
		<author><name>Devcafe</name></author>
	</entry>
</feed>