summaryrefslogblamecommitdiff
path: root/src/sql/sqlite/updates/update_10_to_11.sql
blob: 22d9bf3802b2c71d90203d1834f687219bb8821e (plain) (tree)
1
2
3
4
5
6
7
  

                                                                             

  
                  
 








































































                                                                     








                                                       
                                                                             
 
                                           













                                                         

       
--
-- 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;