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
|
--
-- SQLite does not support removing of columns, so we'll need to recreate the
-- table and copy the data over.
--
BEGIN TRANSACTION;
CREATE TEMPORARY TABLE mana_characters_backup
(
id INTEGER PRIMARY KEY,
user_id INTEGER NOT NULL,
name TEXT NOT NULL UNIQUE,
gender INTEGER NOT NULL,
hair_style INTEGER NOT NULL,
hair_color INTEGER NOT NULL,
level INTEGER NOT NULL,
char_pts INTEGER NOT NULL,
correct_pts INTEGER NOT NULL,
x INTEGER NOT NULL,
y INTEGER NOT NULL,
map_id INTEGER NOT NULL,
--
FOREIGN KEY (user_id) REFERENCES mana_accounts(id)
);
INSERT INTO mana_characters_backup SELECT
id,
user_id,
name,
gender,
hair_style,
hair_color,
level,
char_pts,
correct_pts,
x,
y,
map_id FROM mana_characters;
DROP TABLE mana_characters;
CREATE TABLE mana_characters
(
id INTEGER PRIMARY KEY,
user_id INTEGER NOT NULL,
name TEXT NOT NULL UNIQUE,
gender INTEGER NOT NULL,
hair_style INTEGER NOT NULL,
hair_color INTEGER NOT NULL,
level INTEGER NOT NULL,
char_pts INTEGER NOT NULL,
correct_pts INTEGER NOT NULL,
x INTEGER NOT NULL,
y INTEGER NOT NULL,
map_id INTEGER NOT NULL,
--
FOREIGN KEY (user_id) REFERENCES mana_accounts(id)
);
CREATE INDEX mana_characters_user ON mana_characters ( user_id );
CREATE UNIQUE INDEX mana_characters_name ON mana_characters ( name );
INSERT INTO mana_characters SELECT
id,
user_id,
name,
gender,
hair_style,
hair_color,
level,
char_pts,
correct_pts,
x,
y,
map_id FROM mana_characters_backup;
DROP TABLE mana_characters_backup;
CREATE TABLE IF NOT EXISTS mana_char_attr
(
char_id INTEGER NOT NULL,
attr_id INTEGER NOT NULL,
attr_base FLOAT NOT NULL,
attr_mod FLOAT NOT NULL,
--
FOREIGN KEY (char_id) REFERENCES mana_characters(id)
);
CREATE INDEX IF NOT EXISTS mana_char_attr_char ON mana_char_attr ( char_id );
CREATE TABLE IF NOT EXISTS mana_char_equips
(
id INTEGER PRIMARY KEY,
owner_id INTEGER NOT NULL,
slot_type INTEGER NOT NULL,
inventory_slot INTEGER NOT NULL,
--
FOREIGN KEY (owner_id) REFERENCES mana_characters(id)
);
-- update the database version, and set date of update
UPDATE mana_world_states
SET value = '11',
moddate = strftime('%s','now')
WHERE state_name = 'database_version';
COMMIT;
|