-
Notifications
You must be signed in to change notification settings - Fork 1
Expand file tree
/
Copy pathpython_basic_jm_22.py
More file actions
98 lines (65 loc) · 2 KB
/
python_basic_jm_22.py
File metadata and controls
98 lines (65 loc) · 2 KB
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
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
'''
파이썬 데이터베이스 연동 (SQlite)
테이블 조회
'''
import sqlite3
# DB파일 조회(없으면 새로 생성)
conn = sqlite3.connect('D:/Python/python_basic/resource/database.db')
# 커서 바인딩
cursor = conn.cursor()
# 데이터 조회
cursor.execute("SELECT * FROM users")
# 커서 위치가 변경
# 1개 로우 선택
# print('One-> \n', cursor.fetchone())
# 지정 로우 선택
# print('Three-> \n', cursor.fetchmany(size=3))
# 나머지 전체 로우 선택
# print('All-> \n', cursor.fetchall())
# 커서위치 초과 되어 데이터가 없음
# print('All-> \n', cursor.fetchall(), end='\n\n')
# 순회1
# rows = cursor.fetchall()
# for row in rows:
# print('retrieve1 > ', row)
# 순회2
for row in cursor.fetchall():
print('retrieve2 > ', row)
print()
# 순회3
for row in cursor.execute("SELECT * FROM users ORDER BY id desc"):
print('retrieve3 > ', row)
print()
# WHERE Retrieve1
param1 = (3,)
cursor.execute("SELECT * FROM users WHERE id=?", param1)
print('param1 : ', cursor.fetchall())
print()
# WHERE Retrieve2
param2 = 4
cursor.execute("SELECT * FROM users WHERE id='%s'" % param2)
print('param2 : ', cursor.fetchall())
print()
# WHERE Retrieve3
cursor.execute("SELECT * FROM users WHERE id=:Id", {"Id":5})
print('param3 : ', cursor.fetchall())
print()
# WHERE Retrieve4
param4 = (3,5)
cursor.execute("SELECT * FROM users WHERE id IN(?,?)", param4) # IN은 합집합입니다.
print('param4 : ', cursor.fetchall())
print()
# WHERE Retrieve5
cursor.execute("SELECT * FROM users WHERE id IN('%d','%d')" % (3,4)) # IN은 합집합입니다.
print('param5 : ', cursor.fetchall())
print()
# WHERE Retrieve6
cursor.execute("SELECT * FROM users WHERE id=:id1 OR id=:id2", {"id1":1, "id2":2}) # IN은 합집합입니다.
print('param6 : ', cursor.fetchall())
print()
# Dump 출력
with conn:
with open('D:/Python/python_basic/resource/dump.sql', 'w') as f :
for line in conn.iterdump():
f.write('%s\n' % line)
print('Dump print complete')