-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathdatabase.py
113 lines (101 loc) · 3.13 KB
/
database.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
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
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
import sqlite3
from contextlib import closing
def create_connection(db_file):
"""
Create a database connection to the SQLite database.
"""
conn = sqlite3.connect(db_file)
return conn
def create_tables(conn):
"""
Create tables in the SQLite database.
"""
cursor = conn.cursor()
# Voice Table
cursor.execute('''
CREATE TABLE IF NOT EXISTS voice (
id INTEGER PRIMARY KEY AUTOINCREMENT,
name TEXT NOT NULL,
elevenlabs_voice_id TEXT NOT NULL,
gender TEXT CHECK(gender IN ('male', 'female')) NOT NULL,
language_id INTEGER,
FOREIGN KEY(language_id) REFERENCES language(id),
UNIQUE(name, gender, language_id)
)
''')
# Language Table
cursor.execute('''
CREATE TABLE IF NOT EXISTS language (
id INTEGER PRIMARY KEY AUTOINCREMENT,
name TEXT NOT NULL,
code TEXT NOT NULL UNIQUE
)
''')
# Name Table
cursor.execute('''
CREATE TABLE IF NOT EXISTS name (
id INTEGER PRIMARY KEY AUTOINCREMENT,
name TEXT NOT NULL,
gender TEXT CHECK(gender IN ('male', 'female')) NOT NULL,
language_id INTEGER,
FOREIGN KEY(language_id) REFERENCES language(id),
UNIQUE(name, gender, language_id)
)
''')
# Category Table
cursor.execute('''
CREATE TABLE IF NOT EXISTS category (
id INTEGER PRIMARY KEY AUTOINCREMENT,
name TEXT NOT NULL,
language_id INTEGER,
FOREIGN KEY(language_id) REFERENCES language(id),
UNIQUE(name, language_id)
)
''')
# Personal Table
cursor.execute('''
CREATE TABLE IF NOT EXISTS personal (
id INTEGER PRIMARY KEY AUTOINCREMENT,
name_id INTEGER,
text TEXT,
type TEXT CHECK(type IN ('greeting', 'morning', 'day', 'evening', 'night')),
audio_file TEXT,
FOREIGN KEY(name_id) REFERENCES name(id)
)
''')
# General Table
cursor.execute('''
CREATE TABLE IF NOT EXISTS general (
id INTEGER PRIMARY KEY AUTOINCREMENT,
category_id INTEGER,
theme_name TEXT,
topic_name TEXT,
text TEXT,
audio_file TEXT,
symbols INTEGER,
gender TEXT CHECK(gender IN ('male', 'female')) NOT NULL,
FOREIGN KEY(category_id) REFERENCES category(id)
)
''')
conn.commit()
def execute_query(conn, query, params=()):
"""
Execute a SQL query with optional parameters.
"""
with closing(conn.cursor()) as cursor:
cursor.execute(query, params)
conn.commit()
def fetch_all(conn, query, params=()):
"""
Fetch all results from a SQL query.
"""
with closing(conn.cursor()) as cursor:
cursor.execute(query, params)
return cursor.fetchall()
def fetch_one(conn, query, params=()):
"""
Fetch one result from a SQL query.
"""
with closing(conn.cursor()) as cursor:
cursor.execute(query, params)
return cursor.fetchone()