demo.shop.db2.create_tables.db2.sql Maven / Gradle / Ivy
--
-- db_category
--
CREATE TABLE db_category (
id varchar(9) NOT NULL,
name varchar(30) NOT NULL,
parent_id varchar(9) default NULL,
PRIMARY KEY (id),
FOREIGN KEY (parent_id) REFERENCES db_category (id)
);
CREATE INDEX db_cat_parent_fki ON db_category (parent_id);
--
-- db_product
--
CREATE TABLE db_product (
ean_code varchar(13) NOT NULL,
name varchar(30) NOT NULL,
category_id varchar(9) NOT NULL,
price decimal(8,2) NOT NULL,
manufacturer varchar(30) NOT NULL,
notes varchar(256),
description clob,
image blob,
PRIMARY KEY (ean_code),
FOREIGN KEY (category_id) REFERENCES db_category (id)
);
CREATE INDEX db_product_category_fki ON db_product (category_id);
--
-- db_role
--
CREATE TABLE db_role (
name varchar(16) NOT NULL,
PRIMARY KEY (name)
);
--
-- db_user
--
CREATE TABLE db_user (
id integer generated by default as identity (start with 1) NOT NULL,
name varchar(30) NOT NULL,
email varchar(50) NOT NULL,
password varchar(16) NOT NULL,
role_id varchar(16) NOT NULL,
active smallint NOT NULL default 1,
PRIMARY KEY (id),
FOREIGN KEY (role_id) REFERENCES db_role (name),
constraint active_flag check (active in (0,1))
);
CREATE INDEX db_user_role_fki on db_user (role_id);
--
-- db_customer
--
CREATE TABLE db_customer (
id integer NOT NULL,
category char(1) NOT NULL,
salutation varchar(10),
first_name varchar(30) NOT NULL,
last_name varchar(30) NOT NULL,
birth_date date,
PRIMARY KEY (id),
FOREIGN KEY (id) REFERENCES db_user (id)
);
--
-- db_order
--
CREATE TABLE db_order (
id integer NOT NULL generated by default as identity (start with 1),
customer_id integer NOT NULL,
total_price decimal(8,2) NOT NULL,
created_at timestamp NOT NULL,
PRIMARY KEY (id),
FOREIGN KEY (customer_id) REFERENCES db_customer (id)
);
CREATE INDEX db_order_customer_fki on db_order (customer_id);
--
-- db_order_item
--
CREATE TABLE db_order_item (
id integer NOT NULL generated by default as identity (start with 1),
order_id integer NOT NULL,
number_of_items integer NOT NULL default 1,
product_ean_code varchar(13) NOT NULL,
total_price decimal(8,2) NOT NULL,
PRIMARY KEY (id),
FOREIGN KEY (order_id) REFERENCES db_order (id),
FOREIGN KEY (product_ean_code) REFERENCES db_product (ean_code)
);
CREATE INDEX db_order_item_order_fki ON db_order_item (order_id);
CREATE INDEX db_order_item_product_fki ON db_order_item (product_ean_code);
CREATE SEQUENCE seq_id_gen START WITH 1000;
© 2015 - 2025 Weber Informatics LLC | Privacy Policy