[파이썬] `tkinter`에서 데이터베이스 연동

tkinterPython에서 GUI(Graphical User Interface)를 개발하기 위한 표준 라이브러리입니다. 이 라이브러리를 사용하여 사용자 인터페이스를 만들고 데이터베이스와 연동하는 것은 매우 유용합니다. 데이터베이스 연동을 통해 애플리케이션에서 데이터를 저장, 검색, 수정 및 삭제할 수 있습니다.

이 블로그 포스트에서는 tkinter에서 데이터베이스를 연동하는 방법에 대해 알아보겠습니다.

데이터베이스 연결

먼저, tkinter에서 데이터베이스를 연결하기 위해 DB-API 모듈을 사용합니다. 가장 일반적으로 사용되는 모듈은 sqlite3입니다. 이 모듈을 사용하여 SQLite 데이터베이스에 연결해 보겠습니다.

import tkinter as tk
import sqlite3

# 데이터베이스 연결
connection = sqlite3.connect("database.db")

# 커서 생성
cursor = connection.cursor()

# SQL 쿼리 실행
cursor.execute("SELECT * FROM users")

# 결과 가져오기
result = cursor.fetchall()

# 결과 출력
for row in result:
    print(row)

# 연결 종료
connection.close()

위의 예제에서는 database.db라는 SQLite 데이터베이스에 연결하고, users 테이블에서 모든 데이터를 검색한 후 결과를 출력합니다. 해당 코드를 실행하면 데이터베이스의 내용이 출력될 것입니다.

tkinter 애플리케이션에 데이터베이스 연동

이제 tkinter 애플리케이션과 데이터베이스를 연동해보겠습니다. 예를 들어, tkinter를 사용하여 간단한 주소록 애플리케이션을 만들어보겠습니다. 이 애플리케이션은 이름과 전화번호를 입력하여 주소록에 추가하고, 주소록의 내용을 출력하는 기능을 가집니다.

import tkinter as tk
import sqlite3

# 주소록 애플리케이션 클래스
class AddressBookApp(tk.Tk):
    def __init__(self):
        super().__init__()

        # 데이터베이스 연결
        self.connection = sqlite3.connect("database.db")
        self.cursor = self.connection.cursor()

        # GUI 요소 초기화
        self.title("주소록 애플리케이션")
        self.geometry("400x300")

        self.name_label = tk.Label(self, text="이름:")
        self.name_label.pack()

        self.name_entry = tk.Entry(self)
        self.name_entry.pack()

        self.phone_label = tk.Label(self, text="전화번호:")
        self.phone_label.pack()

        self.phone_entry = tk.Entry(self)
        self.phone_entry.pack()

        self.add_button = tk.Button(self, text="추가", command=self.add_contact)
        self.add_button.pack()

        self.show_button = tk.Button(self, text="주소록 보기", command=self.show_contacts)
        self.show_button.pack()

    # 주소록에 연락처 추가
    def add_contact(self):
        name = self.name_entry.get()
        phone = self.phone_entry.get()

        # 데이터베이스에 추가
        self.cursor.execute("INSERT INTO contacts (name, phone) VALUES (?, ?)", (name, phone))
        self.connection.commit()

        # 입력 필드 초기화
        self.name_entry.delete(0, tk.END)
        self.phone_entry.delete(0, tk.END)

    # 주소록 보기
    def show_contacts(self):
        # 데이터베이스에서 주소록 가져오기
        self.cursor.execute("SELECT * FROM contacts")
        contacts = self.cursor.fetchall()

        # 주소록 출력
        for contact in contacts:
            print(contact)

# 주소록 애플리케이션 실행
if __name__ == "__main__":
    app = AddressBookApp()
    app.mainloop()

위의 예제에서는 tkinterTk 클래스를 상속하는 AddressBookApp 클래스를 만들었습니다. 애플리케이션을 초기화하면서 데이터베이스에 연결하고, GUI 요소(레이블, 텍스트 필드, 버튼)를 생성합니다. 사용자가 이름과 전화번호를 입력하고 “추가” 버튼을 클릭하면, 입력된 데이터가 데이터베이스에 추가됩니다. “주소록 보기” 버튼을 클릭하면 데이터베이스의 내용이 출력됩니다.

이제 tkinter에서 데이터베이스를 연동하는 방법에 대해 알게 되었습니다. 데이터베이스 연동을 통해 간단한 애플리케이션을 개발하고, 데이터를 보다 효율적으로 관리할 수 있습니다.