This repository has been archived on 2025-01-04. You can view files and clone it, but cannot push or open issues or pull requests.
lwb6/legacyworlds-server-data/db-structure/parts/030-data/130-fleets.sql
Emmanuel BENOîT e50775ec76 Database definition & tests organisation
* The main loader script has been updated to generate the list of files
it needs to load automatically. As a consequence, files that contained
manually-maintained lists of scripts have been removed, and definition
directories have been renamed accordingly.

* PostgreSQL extension loading and configuration has been moved to a
separate script to be loaded automatically in the main transaction.

* Data and function definition scripts that had the -data or -functions
suffix have been renamed (the suffix is unnecessary).

* Unit tests have been reorganised to follow the definition's structure.

* Documentation has been improved
2012-01-06 11:19:19 +01:00

118 lines
2.7 KiB
SQL

-- LegacyWorlds Beta 6
-- PostgreSQL database scripts
--
-- Fleets
--
-- Copyright(C) 2004-2010, DeepClone Development
-- --------------------------------------------------------
--
-- Fleets
--
CREATE TABLE fleets.fleets(
id BIGSERIAL NOT NULL PRIMARY KEY ,
owner_id INT NOT NULL ,
location_id INT NOT NULL ,
name VARCHAR(64) ,
attacking BOOLEAN NOT NULL ,
status fleet_status NOT NULL ,
penalty INT NOT NULL ,
CHECK( ( status = 'AVAILABLE' AND penalty = 0 )
OR ( status <> 'AVAILABLE' AND penalty > 0) )
);
CREATE INDEX idx_fleets_owner
ON fleets.fleets ( owner_id );
CREATE INDEX idx_fleets_location
ON fleets.fleets ( location_id );
CREATE INDEX idx_fleets_status
ON fleets.fleets ( status , penalty );
ALTER TABLE fleets.fleets
ADD CONSTRAINT fk_fleets_owner
FOREIGN KEY ( owner_id ) REFERENCES emp.empires
ON DELETE CASCADE ,
ADD CONSTRAINT fk_fleets_location
FOREIGN KEY ( location_id ) REFERENCES verse.planets;
--
-- Ships
--
CREATE TABLE fleets.ships(
fleet_id BIGINT NOT NULL ,
ship_id INT NOT NULL ,
amount INT NOT NULL CHECK( amount >= 0 ) ,
damage REAL NOT NULL ,
PRIMARY KEY( fleet_id , ship_id )
);
CREATE INDEX idx_ships_ship
ON fleets.ships( ship_id );
ALTER TABLE fleets.ships
ADD CONSTRAINT fk_ships_fleet
FOREIGN KEY ( fleet_id ) REFERENCES fleets.fleets
ON DELETE CASCADE ,
ADD CONSTRAINT fk_ships_ship
FOREIGN KEY ( ship_id ) REFERENCES tech.ships;
--
-- Fleet movements
--
CREATE TABLE fleets.movements(
fleet_id BIGINT NOT NULL PRIMARY KEY ,
source_id INT NOT NULL ,
time_left INT NOT NULL CHECK( time_left > 0 ) ,
state_time_left INT NOT NULL CHECK( state_time_left > 0 )
);
CREATE INDEX idx_movements_source
ON fleets.movements( source_id );
ALTER TABLE fleets.movements
ADD CONSTRAINT fk_movements_fleet
FOREIGN KEY ( fleet_id ) REFERENCES fleets.fleets
ON DELETE CASCADE ,
ADD CONSTRAINT fk_movements_source
FOREIGN KEY ( source_id ) REFERENCES verse.planets;
--
-- Movement states, outer space
--
CREATE TABLE fleets.ms_space(
movement_id BIGINT NOT NULL PRIMARY KEY ,
start_x REAL NOT NULL ,
start_y REAL NOT NULL
);
ALTER TABLE fleets.ms_space
ADD CONSTRAINT fk_msspace_movement
FOREIGN KEY ( movement_id ) REFERENCES fleets.movements
ON DELETE CASCADE;
--
-- Movement states, in system
--
CREATE TABLE fleets.ms_system(
movement_id BIGINT NOT NULL PRIMARY KEY ,
ref_point_id INT NOT NULL ,
outwards BOOLEAN NOT NULL ,
past_ref_point BOOLEAN NOT NULL
);
ALTER TABLE fleets.ms_system
ADD CONSTRAINT fk_mssystem_movement
FOREIGN KEY ( movement_id ) REFERENCES fleets.movements
ON DELETE CASCADE ,
ADD CONSTRAINT fk_mssystem_refpoint
FOREIGN KEY ( ref_point_id ) REFERENCES verse.planets;