CREATE TABLE blfiles ( _id bigint NOT NULL DEFAULT nextval('bltags__id_seq'::regclass), -- Identifier name character varying(2048), -- File Name, relative to the user home directory, must not begin with a slash. blid bigint, -- Blog entry identifier (foreign key) CONSTRAINT bltags_pkey PRIMARY KEY (_id), CONSTRAINT bltags_blid_fkey FOREIGN KEY (blid) REFERENCES blog (_id) MATCH SIMPLE ON UPDATE CASCADE ON DELETE CASCADE ) WITH ( OIDS=FALSE ); COMMENT ON COLUMN blfiles._id IS 'Identifier'; COMMENT ON COLUMN blfiles.name IS 'File Name, relative to the user home directory, must not begin with a slash.'; COMMENT ON COLUMN blfiles.blid IS 'Blog entry identifier (foreign key)'; -- Table: blog -- DROP TABLE blog; CREATE TABLE blog ( applicationname character varying(255) NOT NULL, username character varying(255) NOT NULL, posted timestamp with time zone NOT NULL, modified timestamp with time zone NOT NULL, title character varying(512) NOT NULL, bcontent text NOT NULL, visible boolean NOT NULL, _id bigserial NOT NULL, CONSTRAINT blog_pkey PRIMARY KEY (_id), CONSTRAINT bloguser FOREIGN KEY (applicationname, username) REFERENCES users (applicationname, username) MATCH SIMPLE ON UPDATE CASCADE ON DELETE CASCADE ) WITH ( OIDS=FALSE ); -- Table: commandes -- DROP TABLE commandes; CREATE TABLE commandes ( id bigint NOT NULL, -- Identifiant unique de commande e, cours validation date, -- Date de validation prdref character varying(255) NOT NULL, -- Product reference from the unique valid catalog at the validation date CONSTRAINT commandes_pkey PRIMARY KEY (id) ) WITH ( OIDS=FALSE ); COMMENT ON COLUMN commandes.id IS 'Identifiant unique de commande e, cours'; COMMENT ON COLUMN commandes.validation IS 'Date de validation'; COMMENT ON COLUMN commandes.prdref IS 'Product reference from the unique valid catalog at the validation date'; -- Table: comment -- DROP TABLE comment; CREATE TABLE comment ( username character varying(255) NOT NULL, bcontent text NOT NULL, posted timestamp with time zone NOT NULL, modified timestamp with time zone NOT NULL, visible boolean NOT NULL, _id bigserial NOT NULL, postid bigint, applicationname character varying(255), CONSTRAINT comment_pkey PRIMARY KEY (_id), CONSTRAINT fkey_blog FOREIGN KEY (postid) REFERENCES blog (_id) MATCH SIMPLE ON UPDATE NO ACTION ON DELETE NO ACTION, CONSTRAINT fkey_users FOREIGN KEY (username, applicationname) REFERENCES users (username, applicationname) MATCH SIMPLE ON UPDATE NO ACTION ON DELETE NO ACTION ) WITH ( OIDS=FALSE ); -- Index: fki_fkey_blog -- DROP INDEX fki_fkey_blog; CREATE INDEX fki_fkey_blog ON comment USING btree (postid); -- Index: fki_fkey_users -- DROP INDEX fki_fkey_users; CREATE INDEX fki_fkey_users ON comment USING btree (username COLLATE pg_catalog."default", applicationname COLLATE pg_catalog."default"); -- Table: estimate -- DROP TABLE estimate; CREATE TABLE estimate ( _id bigserial NOT NULL, -- identifier title character varying(1024) NOT NULL, username character varying(255) NOT NULL, -- User name of the owner and creator for this estimate applicationname character varying(255) NOT NULL, status integer, client character varying(255) NOT NULL, -- a login name description character varying(65000), CONSTRAINT estimate_pkey PRIMARY KEY (_id), CONSTRAINT estimate_client_fkey FOREIGN KEY (client, applicationname) REFERENCES users (username, applicationname) MATCH SIMPLE ON UPDATE CASCADE ON DELETE CASCADE, CONSTRAINT estimate_username_fkey FOREIGN KEY (username, applicationname) REFERENCES users (username, applicationname) MATCH SIMPLE ON UPDATE CASCADE ON DELETE CASCADE ) WITH ( OIDS=FALSE ); COMMENT ON COLUMN estimate._id IS 'identifier'; COMMENT ON COLUMN estimate.username IS 'User name of the owner and creator for this estimate'; COMMENT ON COLUMN estimate.client IS 'a login name'; -- Index: cliuser -- DROP INDEX cliuser; CREATE INDEX cliuser ON estimate USING btree (client COLLATE pg_catalog."default", applicationname COLLATE pg_catalog."default"); -- Table: histoestim -- DROP TABLE histoestim; CREATE TABLE histoestim ( datechange timestamp with time zone NOT NULL DEFAULT now(), status integer, estid bigint NOT NULL, username character varying(255), applicationname character varying(255), _id bigserial NOT NULL, CONSTRAINT histoestim_pkey PRIMARY KEY (_id), CONSTRAINT histoestim_estid_fkey FOREIGN KEY (estid) REFERENCES estimate (_id) MATCH SIMPLE ON UPDATE CASCADE ON DELETE CASCADE, CONSTRAINT histoestim_username_fkey FOREIGN KEY (username, applicationname) REFERENCES users (username, applicationname) MATCH SIMPLE ON UPDATE NO ACTION ON DELETE NO ACTION ) WITH ( OIDS=FALSE ); -- Table: histowritting -- DROP TABLE histowritting; CREATE TABLE histowritting ( datechange timestamp with time zone NOT NULL DEFAULT now(), status integer, wrtid bigint NOT NULL, username character varying(255), applicationname character varying, _id bigserial NOT NULL, CONSTRAINT histowritting_pkey PRIMARY KEY (_id), CONSTRAINT histowritting_username_fkey FOREIGN KEY (username, applicationname) REFERENCES users (username, applicationname) MATCH SIMPLE ON UPDATE NO ACTION ON DELETE NO ACTION, CONSTRAINT histowritting_wrtid_fkey FOREIGN KEY (wrtid) REFERENCES writtings (_id) MATCH SIMPLE ON UPDATE CASCADE ON DELETE CASCADE ) WITH ( OIDS=FALSE ); -- Table: hr -- DROP TABLE hr; CREATE TABLE hr ( userid character varying NOT NULL, rate numeric NOT NULL, comment text NOT NULL, CONSTRAINT hr_pk_new PRIMARY KEY (userid) ) WITH ( OIDS=FALSE ); -- Table: product -- DROP TABLE product; CREATE TABLE product ( ref character varying(255) NOT NULL, -- Product reference from the catalog "Name" character varying(1000), -- Product Name "Description" character varying(64000), -- Product description CONSTRAINT product_pkey PRIMARY KEY (ref) ) WITH ( OIDS=FALSE ); COMMENT ON COLUMN product.ref IS 'Product reference from the catalog'; COMMENT ON COLUMN product."Name" IS 'Product Name'; COMMENT ON COLUMN product."Description" IS 'Product description'; -- Table: profiledata -- DROP TABLE profiledata; CREATE TABLE profiledata ( uniqueid integer, zipcode character varying(10), cityandstate character varying(255), blogtitle character varying(255), -- Blog Title address character varying(2048), -- Postal address country character varying(100), website character varying(256), blogvisible boolean, hasavatar boolean, -- True when user has specified an image for avatar name character varying(1024), phone character varying(15), mobile character varying(15), accountnumber character varying(15), -- Numero de compte bankedkey integer, -- clé RIB bankcode character varying(5), -- Code banque wicketcode character varying(5), iban character varying(33), bic character varying(15), gcode character varying(512), CONSTRAINT fkprofiles2 FOREIGN KEY (uniqueid) REFERENCES profiles (uniqueid) MATCH SIMPLE ON UPDATE CASCADE ON DELETE CASCADE ) WITH ( OIDS=FALSE ); COMMENT ON COLUMN profiledata.blogtitle IS 'Blog Title'; COMMENT ON COLUMN profiledata.address IS 'Postal address'; COMMENT ON COLUMN profiledata.hasavatar IS 'True when user has specified an image for avatar'; COMMENT ON COLUMN profiledata.accountnumber IS 'Numero de compte'; COMMENT ON COLUMN profiledata.bankedkey IS 'clé RIB'; COMMENT ON COLUMN profiledata.bankcode IS 'Code banque'; -- Index: fki_fkprofiles2 -- DROP INDEX fki_fkprofiles2; CREATE INDEX fki_fkprofiles2 ON profiledata USING btree (uniqueid); -- Table: profiles -- DROP TABLE profiles; CREATE TABLE profiles ( uniqueid bigserial NOT NULL, username character varying(255) NOT NULL, applicationname character varying(255) NOT NULL, isanonymous boolean, lastactivitydate timestamp with time zone, lastupdateddate timestamp with time zone, CONSTRAINT profiles_pkey PRIMARY KEY (uniqueid), CONSTRAINT pkprofiles UNIQUE (username, applicationname) ) WITH ( OIDS=FALSE ); -- Table: projet -- DROP TABLE projet; CREATE TABLE projet ( id bigserial NOT NULL, name character varying NOT NULL, prdesc text, managerid character varying NOT NULL, "ApplicationName" character varying(250), CONSTRAINT projet_pk_new PRIMARY KEY (id), CONSTRAINT pk_project_manager FOREIGN KEY (managerid, "ApplicationName") REFERENCES users (username, applicationname) MATCH SIMPLE ON UPDATE NO ACTION ON DELETE NO ACTION ) WITH ( OIDS=FALSE ); -- Index: fki_pk_project_manager -- DROP INDEX fki_pk_project_manager; CREATE INDEX fki_pk_project_manager ON projet USING btree (managerid COLLATE pg_catalog."default", "ApplicationName" COLLATE pg_catalog."default"); -- Table: roles -- DROP TABLE roles; CREATE TABLE roles ( rolename character varying(255) NOT NULL, applicationname character varying(255) NOT NULL, comment character varying(255) NOT NULL, CONSTRAINT roles_pkey PRIMARY KEY (rolename, applicationname) ) WITH ( OIDS=FALSE ); COMMENT ON TABLE roles IS 'Web application roles'; -- Table: stocksymbols -- DROP TABLE stocksymbols; CREATE TABLE stocksymbols ( uniqueid integer, stocksymbol character varying(10), CONSTRAINT fkprofiles1 FOREIGN KEY (uniqueid) REFERENCES profiles (uniqueid) MATCH SIMPLE ON UPDATE NO ACTION ON DELETE NO ACTION ) WITH ( OIDS=FALSE ); -- Table: tag -- DROP TABLE tag; CREATE TABLE tag ( _id bigserial NOT NULL, -- Identifier name character varying(30), -- Tag name CONSTRAINT tag_pkey PRIMARY KEY (_id), CONSTRAINT tag_name_key UNIQUE (name) ) WITH ( OIDS=FALSE ); COMMENT ON COLUMN tag._id IS 'Identifier'; COMMENT ON COLUMN tag.name IS 'Tag name'; -- Table: tagged -- DROP TABLE tagged; CREATE TABLE tagged ( postid bigint NOT NULL, tagid bigint NOT NULL, CONSTRAINT tagged_pkey PRIMARY KEY (postid, tagid), CONSTRAINT tagged_postid_fkey FOREIGN KEY (postid) REFERENCES blog (_id) MATCH SIMPLE ON UPDATE CASCADE ON DELETE CASCADE, CONSTRAINT tagged_tagid_fkey FOREIGN KEY (tagid) REFERENCES tag (_id) MATCH SIMPLE ON UPDATE CASCADE ON DELETE CASCADE ) WITH ( OIDS=FALSE ); -- Table: taskdeps -- DROP TABLE taskdeps; CREATE TABLE taskdeps ( "taskId" bigint NOT NULL, -- dependent task deptask bigint NOT NULL, -- Dependency CONSTRAINT pk_tasks_deps PRIMARY KEY ("taskId", deptask), CONSTRAINT pk_foreign_dep FOREIGN KEY (deptask) REFERENCES tasks (id) MATCH SIMPLE ON UPDATE NO ACTION ON DELETE NO ACTION, CONSTRAINT pk_foreign_task FOREIGN KEY ("taskId") REFERENCES tasks (id) MATCH SIMPLE ON UPDATE NO ACTION ON DELETE NO ACTION ) WITH ( OIDS=FALSE ); COMMENT ON TABLE taskdeps IS 'Dependencies between tasks'; COMMENT ON COLUMN taskdeps."taskId" IS 'dependent task'; COMMENT ON COLUMN taskdeps.deptask IS 'Dependency'; -- Index: fki_pk_foreign_dep -- DROP INDEX fki_pk_foreign_dep; CREATE INDEX fki_pk_foreign_dep ON taskdeps USING btree (deptask); -- Index: fki_pk_foreign_task -- DROP INDEX fki_pk_foreign_task; CREATE INDEX fki_pk_foreign_task ON taskdeps USING btree ("taskId"); -- Table: tasks -- DROP TABLE tasks; CREATE TABLE tasks ( id bigserial NOT NULL, name character varying NOT NULL, start date NOT NULL, endd date NOT NULL, tdesc text NOT NULL, prid bigint NOT NULL, CONSTRAINT tasks_pk_new PRIMARY KEY (id), CONSTRAINT tasks_fk_new FOREIGN KEY (prid) REFERENCES projet (id) MATCH SIMPLE ON UPDATE NO ACTION ON DELETE NO ACTION ) WITH ( OIDS=FALSE ); -- Table: users -- DROP TABLE users; CREATE TABLE users ( pkid character varying NOT NULL, username character varying(255) NOT NULL, applicationname character varying(255) NOT NULL, email character varying(128) NOT NULL, comment character varying(255), passw character varying(128) NOT NULL, passwordquestion character varying(255), passwordanswer character varying(255), isapproved boolean, lastactivitydate timestamp with time zone, lastlogindate timestamp with time zone, lastpasswordchangeddate timestamp with time zone, creationdate timestamp with time zone, islockedout boolean, lastlockedoutdate timestamp with time zone, failedpasswordattemptcount integer, failedpasswordattemptwindowstart timestamp with time zone, failedpasswordanswerattemptcount integer, failedpasswordanswerattemptwindowstart timestamp with time zone, CONSTRAINT users_pkey PRIMARY KEY (pkid), CONSTRAINT uniquelogin UNIQUE (applicationname, email), CONSTRAINT uniquemail UNIQUE (applicationname, username) ) WITH ( OIDS=FALSE ); -- Table: usersroles -- DROP TABLE usersroles; CREATE TABLE usersroles ( applicationname character varying(255) NOT NULL, rolename character varying(255) NOT NULL, username character varying(255) NOT NULL, CONSTRAINT attrroles_pkey PRIMARY KEY (applicationname, rolename, username), CONSTRAINT usersroles_fk_role FOREIGN KEY (applicationname, rolename) REFERENCES roles (applicationname, rolename) MATCH SIMPLE ON UPDATE CASCADE ON DELETE CASCADE, CONSTRAINT usersroles_fk_user FOREIGN KEY (applicationname, username) REFERENCES users (applicationname, username) MATCH SIMPLE ON UPDATE CASCADE ON DELETE CASCADE ) WITH ( OIDS=FALSE ); -- Table: wrfiles -- DROP TABLE wrfiles; CREATE TABLE wrfiles ( _id bigint NOT NULL DEFAULT nextval('wrtags__id_seq'::regclass), -- Identifier name character varying(2048), -- File Name, relative to the user home directory, must not begin with a slash. wrid bigint, -- Writting identifier (foreign key) CONSTRAINT wrtags_pkey PRIMARY KEY (_id), CONSTRAINT wrtags_wrid_fkey FOREIGN KEY (wrid) REFERENCES writtings (_id) MATCH SIMPLE ON UPDATE CASCADE ON DELETE CASCADE ) WITH ( OIDS=FALSE ); COMMENT ON COLUMN wrfiles._id IS 'Identifier'; COMMENT ON COLUMN wrfiles.name IS 'File Name, relative to the user home directory, must not begin with a slash.'; COMMENT ON COLUMN wrfiles.wrid IS 'Writting identifier (foreign key)'; -- Table: writtings -- DROP TABLE writtings; CREATE TABLE writtings ( _id bigserial NOT NULL, -- identifier count integer, -- multiplier estimid bigint NOT NULL, -- Estimaton identifier description character varying(2047), -- item textual description productid character varying(512), -- Product reference ... may be a key in a catalog, may contain a catalog id ucost numeric(8,2), -- en euro.? CONSTRAINT writtings_pkey PRIMARY KEY (_id), CONSTRAINT writtings_estimid_fkey FOREIGN KEY (estimid) REFERENCES estimate (_id) MATCH SIMPLE ON UPDATE CASCADE ON DELETE CASCADE ) WITH ( OIDS=FALSE ); COMMENT ON COLUMN writtings._id IS 'identifier'; COMMENT ON COLUMN writtings.count IS 'multiplier'; COMMENT ON COLUMN writtings.estimid IS 'Estimaton identifier'; COMMENT ON COLUMN writtings.description IS 'item textual description'; COMMENT ON COLUMN writtings.productid IS 'Product reference ... may be a key in a catalog, may contain a catalog id'; COMMENT ON COLUMN writtings.ucost IS 'en euro.?'; -- Table: wrtags -- DROP TABLE wrtags; CREATE TABLE wrtags ( wrid bigint NOT NULL, tagid bigint NOT NULL, CONSTRAINT wrtags_pkey1 PRIMARY KEY (wrid, tagid), CONSTRAINT cstwrtagsref FOREIGN KEY (tagid) REFERENCES tag (_id) MATCH SIMPLE ON UPDATE NO ACTION ON DELETE NO ACTION, CONSTRAINT wrtags_wrid_fkey1 FOREIGN KEY (wrid) REFERENCES writtings (_id) MATCH SIMPLE ON UPDATE NO ACTION ON DELETE NO ACTION ) WITH ( OIDS=FALSE ); -- Index: fki_cstwrtagsref -- DROP INDEX fki_cstwrtagsref; CREATE INDEX fki_cstwrtagsref ON wrtags USING btree (tagid);