-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathcontroller.py
55 lines (45 loc) · 1.56 KB
/
controller.py
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
#!/usr/bin/python
# -*- coding: utf-8 -*-
import sqlite3
#http://pastie.org/7984116
def connect():
con = sqlite3.connect('movies.db')
con.row_factory = sqlite3.Row
return con
def get_countries():
con = connect()
c = con.cursor()
query = """SELECT id_country, name FROM countries"""
result = c.execute(query)
countries = result.fetchall()
con.close()
return countries
def get_movies():
con = connect()
c = con.cursor()
query = """SELECT a.id_movie, a.title, a.year_of_release, a.director, b.name as 'country'
FROM movies a, countries b WHERE a.fk_id_country = b.id_country"""
result = c.execute(query)
movies = result.fetchall()
con.close()
return movies
def get_movies_by_country(id_country):
con = connect()
c = con.cursor()
query = """SELECT a.id_movie, a.title, a.year_of_release, a.director, b.name as 'country'
FROM movies a, countries b WHERE a.fk_id_country = b.id_country
AND a.fk_id_country = ?"""
result = c.execute(query, [id_country])
movies = result.fetchall()
con.close()
return movies
def search_movies(word):
con = connect()
c = con.cursor()
query = """SELECT a.id_movie, a.title, a.year_of_release, a.director, b.name as 'country'
FROM movies a, countries b WHERE a.fk_id_country = b.id_country
AND (a.title LIKE '%'||?||'%' OR a.director LIKE '%'||?||'%' OR b.name LIKE '%'||?||'%' )"""
result = c.execute(query, [word, word, word])
movies = result.fetchall()
con.close()
return movies