Python-데이터베이스 및 SQL
Python 프로그래밍 언어에는 데이터베이스 프로그래밍을위한 강력한 기능이 있습니다. Python은 SQLite, MySQL, Oracle, Sybase, PostgreSQL 등과 같은 다양한 데이터베이스를 지원합니다. Python은 DDL (데이터 정의 언어), DML (데이터 조작 언어) 및 데이터 쿼리 문도 지원합니다. 데이터베이스 인터페이스의 Python 표준은 Python DB-API입니다. 대부분의 Python 데이터베이스 인터페이스는이 표준을 따릅니다.
여기에 사용할 수 파이썬 데이터베이스 인터페이스의 목록입니다 : 파이썬 데이터베이스 인터페이스 및 API . 액세스해야하는 각 데이터베이스에 대해 별도의 DB API 모듈을 다운로드해야합니다.
이 장에서는 파이썬 프로그래밍 언어에서 SQLite 데이터베이스를 사용하는 방법을 살펴 봅니다. 파이썬의 내장 된 sqlite3 모듈을 사용하여 수행됩니다. 먼저 데이터베이스를 나타내는 연결 개체를 만든 다음 SQL 문을 실행할 커서 개체를 만들어야합니다.
데이터베이스에 연결
다음 Python 코드는 기존 데이터베이스에 연결하는 방법을 보여줍니다. 데이터베이스가 존재하지 않으면 생성되고 마지막으로 데이터베이스 개체가 반환됩니다.
#!/usr/bin/python
import sqlite3
conn = sqlite3.connect('test.db')
print "Opened database successfully";
여기에서 데이터베이스 이름을 특수 이름으로 제공 할 수도 있습니다. :memory:RAM에 데이터베이스를 만듭니다. 이제 위의 프로그램을 실행하여 데이터베이스를 생성하겠습니다.test.db현재 디렉토리에서. 요구 사항에 따라 경로를 변경할 수 있습니다. 위 코드를 sqlite.py 파일에 보관하고 아래와 같이 실행합니다. 데이터베이스가 성공적으로 생성되면 다음 메시지가 표시됩니다.
$chmod +x sqlite.py $./sqlite.py
Open database successfully
테이블 생성
다음 Python 프로그램은 이전에 생성 된 데이터베이스에 테이블을 생성하는 데 사용됩니다.
#!/usr/bin/python
import sqlite3
conn = sqlite3.connect('test.db')
print "Opened database successfully";
conn.execute('''CREATE TABLE COMPANY
(ID INT PRIMARY KEY NOT NULL,
NAME TEXT NOT NULL,
AGE INT NOT NULL,
ADDRESS CHAR(50),
SALARY REAL);''')
print "Table created successfully";
conn.close()
위의 프로그램이 실행되면 COMPANY 테이블이 생성됩니다. test.db 다음 메시지가 표시됩니다.
Opened database successfully
Table created successfully
작업 삽입
다음 Python 프로그램은 위의 예에서 생성 된 COMPANY 테이블에 레코드를 생성하는 방법을 보여줍니다.
#!/usr/bin/python
import sqlite3
conn = sqlite3.connect('test.db')
print "Opened database successfully";
conn.execute("INSERT INTO COMPANY (ID,NAME,AGE,ADDRESS,SALARY) \
VALUES (1, 'Paul', 32, 'California', 20000.00 )");
conn.execute("INSERT INTO COMPANY (ID,NAME,AGE,ADDRESS,SALARY) \
VALUES (2, 'Allen', 25, 'Texas', 15000.00 )");
conn.execute("INSERT INTO COMPANY (ID,NAME,AGE,ADDRESS,SALARY) \
VALUES (3, 'Teddy', 23, 'Norway', 20000.00 )");
conn.execute("INSERT INTO COMPANY (ID,NAME,AGE,ADDRESS,SALARY) \
VALUES (4, 'Mark', 25, 'Rich-Mond ', 65000.00 )");
conn.commit()
print "Records created successfully";
conn.close()
위의 프로그램이 실행되면 COMPANY 테이블에 주어진 레코드를 생성하고 다음 두 줄을 표시합니다.
Opened database successfully
Records created successfully
작업 선택
다음 Python 프로그램은 위의 예에서 만든 COMPANY 테이블에서 레코드를 가져 와서 표시하는 방법을 보여줍니다.
#!/usr/bin/python
import sqlite3
conn = sqlite3.connect('test.db')
print "Opened database successfully";
cursor = conn.execute("SELECT id, name, address, salary from COMPANY")
for row in cursor:
print "ID = ", row[0]
print "NAME = ", row[1]
print "ADDRESS = ", row[2]
print "SALARY = ", row[3], "\n"
print "Operation done successfully";
conn.close()
위 프로그램을 실행하면 다음과 같은 결과가 나옵니다.
Opened database successfully
ID = 1
NAME = Paul
ADDRESS = California
SALARY = 20000.0
ID = 2
NAME = Allen
ADDRESS = Texas
SALARY = 15000.0
ID = 3
NAME = Teddy
ADDRESS = Norway
SALARY = 20000.0
ID = 4
NAME = Mark
ADDRESS = Rich-Mond
SALARY = 65000.0
Operation done successfully
업데이트 작업
다음 Python 코드는 UPDATE 문을 사용하여 레코드를 업데이트 한 다음 COMPANY 테이블에서 업데이트 된 레코드를 가져와 표시하는 방법을 보여줍니다.
#!/usr/bin/python
import sqlite3
conn = sqlite3.connect('test.db')
print "Opened database successfully";
conn.execute("UPDATE COMPANY set SALARY = 25000.00 where ID = 1")
conn.commit
print "Total number of rows updated :", conn.total_changes
cursor = conn.execute("SELECT id, name, address, salary from COMPANY")
for row in cursor:
print "ID = ", row[0]
print "NAME = ", row[1]
print "ADDRESS = ", row[2]
print "SALARY = ", row[3], "\n"
print "Operation done successfully";
conn.close()
위 프로그램을 실행하면 다음과 같은 결과가 나옵니다.
Opened database successfully
Total number of rows updated : 1
ID = 1
NAME = Paul
ADDRESS = California
SALARY = 25000.0
ID = 2
NAME = Allen
ADDRESS = Texas
SALARY = 15000.0
ID = 3
NAME = Teddy
ADDRESS = Norway
SALARY = 20000.0
ID = 4
NAME = Mark
ADDRESS = Rich-Mond
SALARY = 65000.0
Operation done successfully
작업 삭제
다음 Python 코드는 DELETE 문을 사용하여 레코드를 삭제 한 다음 COMPANY 테이블에서 나머지 레코드를 가져와 표시하는 방법을 보여줍니다.
#!/usr/bin/python
import sqlite3
conn = sqlite3.connect('test.db')
print "Opened database successfully";
conn.execute("DELETE from COMPANY where ID = 2;")
conn.commit()
print "Total number of rows deleted :", conn.total_changes
cursor = conn.execute("SELECT id, name, address, salary from COMPANY")
for row in cursor:
print "ID = ", row[0]
print "NAME = ", row[1]
print "ADDRESS = ", row[2]
print "SALARY = ", row[3], "\n"
print "Operation done successfully";
conn.close()
위 프로그램을 실행하면 다음과 같은 결과가 나옵니다.
Opened database successfully
Total number of rows deleted : 1
ID = 1
NAME = Paul
ADDRESS = California
SALARY = 20000.0
ID = 3
NAME = Teddy
ADDRESS = Norway
SALARY = 20000.0
ID = 4
NAME = Mark
ADDRESS = Rich-Mond
SALARY = 65000.0
Operation done successfully