-
Notifications
You must be signed in to change notification settings - Fork 26
Expand file tree
/
Copy pathengine-1-select.py
More file actions
27 lines (20 loc) · 855 Bytes
/
engine-1-select.py
File metadata and controls
27 lines (20 loc) · 855 Bytes
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
from sqlalchemy import create_engine
#engine = create_engine("sqlite:///some.db") # create sqlite db. use "////" to specify absolute path
engine = create_engine("sqlite:///:memory:", echo=True)
# create table
engine.execute("""CREATE TABLE emp (
id INTEGER PRIMARY KEY,
name VARCHAR(50)
)""")
# insert data (connectionless execution (via engine))
engine.execute("INSERT INTO emp (name) VALUES (:name)", name="Slavo")
engine.execute("INSERT INTO emp (name) VALUES (:name)", name="Jano")
engine.execute("INSERT INTO emp (name) VALUES (:name)", name="Vlado")
# query data
result = engine.execute("select id, name from emp")
rows = result.fetchall()
result.close(); # should be done automatically
# display data
for row in rows: # we could also iterate directly over result without need to call fetchall()
print("DATA: " + repr(row))
print("done")