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/090-buildables.sql
Emmanuel BENOîT 96c296e9d5 Removed old research system
* Removed all tables, views and functions

* Removed references to old system in Java code, including old import
tool

* Replaced XML dump code
2012-04-09 11:36:09 +02:00

61 lines
No EOL
1.6 KiB
SQL

-- LegacyWorlds Beta 6
-- PostgreSQL database scripts
--
-- Buildings/ships definitions
--
-- Copyright(C) 2004-2010, DeepClone Development
-- --------------------------------------------------------
--
-- "Buildables"
--
CREATE TABLE tech.buildables(
name_id INT NOT NULL PRIMARY KEY ,
description_id INT NOT NULL ,
technology_name_id INT ,
cost INT NOT NULL CHECK( cost > 0 ) ,
work INT NOT NULL CHECK( work > 0 ) ,
upkeep INT NOT NULL CHECK( upkeep >= 0 )
);
CREATE INDEX idx_buildables_description
ON tech.buildables (description_id);
CREATE INDEX idx_buildables_technology
ON tech.buildables ( technology_name_id );
ALTER TABLE tech.buildables
ADD CONSTRAINT fk_buildables_name
FOREIGN KEY (name_id) REFERENCES defs.strings ,
ADD CONSTRAINT fk_buildables_description
FOREIGN KEY (description_id) REFERENCES defs.strings ,
ADD CONSTRAINT fk_buildables_technology
FOREIGN KEY (technology_name_id) REFERENCES defs.technologies;
--
-- Buildings
--
CREATE TABLE tech.buildings(
buildable_id INT NOT NULL PRIMARY KEY ,
workers INT NOT NULL CHECK( workers >= 0 ) ,
output_type building_output_type ,
output INT NOT NULL CHECK( output > 0 )
);
ALTER TABLE tech.buildings
ADD CONSTRAINT fk_buildings_buildable
FOREIGN KEY (buildable_id) REFERENCES tech.buildables;
--
-- Ships
--
CREATE TABLE tech.ships(
buildable_id INT NOT NULL PRIMARY KEY ,
flight_time INT NOT NULL CHECK( flight_time > 0 ) ,
power INT NOT NULL CHECK( power > 0 )
);
ALTER TABLE tech.ships
ADD CONSTRAINT fk_buildings_buildable
FOREIGN KEY (buildable_id) REFERENCES tech.buildables;