summaryrefslogtreecommitdiff
path: root/src/sql/sqlite/updates/update_19_to_20.sql
blob: 2dea3eff8e9ee298f8b69bf82f8d9322ae87f4ee (plain) (blame)
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
--
-- SQLite does not support altering of columns, so we'll need to recreate the
-- table and copy the data over.
--

BEGIN;

CREATE TEMPORARY TABLE mana_world_states_backup
(
   state_name   TEXT        PRIMARY KEY,
   map_id       INTEGER     NULL,
   value        TEXT        NULL,
   moddate      INTEGER     NOT NULL
);

INSERT INTO mana_world_states_backup SELECT
    state_name, map_id, value, moddate FROM mana_world_states;

DROP TABLE mana_world_states;

-- Create the new world states table with the corrected primary key, and move
-- the existing data over
CREATE TABLE mana_world_states
(
   state_name   TEXT        NOT NULL,
   map_id       INTEGER     NOT NULL,
   value        TEXT        NOT NULL,
   moddate      INTEGER     NOT NULL,
   --
   PRIMARY KEY (state_name, map_id)
);

-- Copy over all map states
INSERT INTO mana_world_states (state_name, map_id, value, moddate)
    SELECT state_name, map_id, value, moddate
      FROM mana_world_states_backup
      WHERE map_id > 0;

-- Copy over all world states
INSERT INTO mana_world_states (state_name, map_id, value, moddate)
    SELECT state_name, 0, value, moddate
      FROM mana_world_states_backup
      WHERE map_id ISNULL;

-- Move some known system variables into the system scope
UPDATE mana_world_states SET map_id = -1 WHERE
    state_name = 'database_version' OR
    state_name = 'accountserver_version' OR
    state_name = 'accountserver_startup';

DROP TABLE mana_world_states_backup;

-- Update the database version, and set date of update
UPDATE mana_world_states
   SET value      = '20',
       moddate    = strftime('%s','now')
   WHERE state_name = 'database_version';

END;