
Hi Robert, Robert L Mathews wrote:
o PostgreSQL with smallints and bigints changes to ints: Currently we write a tool to generate MySQL, PostgreSQL, SAPDB, Oracle, ... output based from XML. This is nearly finished. We hate to maintain different .sql files for different sql databases. So if this is ready, we just generate for postgresql performance improved create scripts (not smallints, no bigints).
That sounds great. Please post to the dev list when this is ready and I will test the generated PostgreSQL schema to be sure it is working as fast as possible.
Now we created a framework to generate the target table create sql script based on the scripts/database/otrs-schema.xml file. Attached it the postgresql create script for OTRS 1.3 with your performace improvements. Thanks for feedback. PS: OTRS 2.0 comes with foreign-key (see scripts/database/otrs-schema.xml cvs head). :)
Thanks again!
Martin Edenhofer -- ((otrs.de)) :: OTRS GmbH :: Norsk-Data-Str. 1 :: 61352 Bad Homburg http://www.otrs.de/ :: Manage your communication! -- ---------------------------------------------------------- -- database: postgresql, generated: Mon Nov 1 11:31:22 2004 -- ---------------------------------------------------------- -- ---------------------------------------------------------- -- valid -- ---------------------------------------------------------- CREATE TABLE valid ( id serial, name VARCHAR (50) NOT NULL, create_time timestamp(0) NOT NULL, create_by INTEGER NOT NULL, change_time timestamp(0) NOT NULL, change_by INTEGER NOT NULL, PRIMARY KEY(id), UNIQUE (name) ); -- ---------------------------------------------------------- -- ticket_priority -- ---------------------------------------------------------- CREATE TABLE ticket_priority ( id serial, name VARCHAR (50) NOT NULL, create_time timestamp(0) NOT NULL, create_by INTEGER NOT NULL, change_time timestamp(0) NOT NULL, change_by INTEGER NOT NULL, PRIMARY KEY(id), UNIQUE (name) ); -- ---------------------------------------------------------- -- ticket_lock_type -- ---------------------------------------------------------- CREATE TABLE ticket_lock_type ( id serial, name VARCHAR (50) NOT NULL, valid_id INTEGER NOT NULL, create_time timestamp(0) NOT NULL, create_by INTEGER NOT NULL, change_time timestamp(0) NOT NULL, change_by INTEGER NOT NULL, PRIMARY KEY(id), UNIQUE (name) ); -- ---------------------------------------------------------- -- system_user -- ---------------------------------------------------------- CREATE TABLE system_user ( id serial, login VARCHAR (100) NOT NULL, pw VARCHAR (50) NOT NULL, salutation VARCHAR (50), first_name VARCHAR (100) NOT NULL, last_name VARCHAR (100) NOT NULL, valid_id INTEGER NOT NULL, create_time timestamp(0) NOT NULL, create_by INTEGER NOT NULL, change_time timestamp(0) NOT NULL, change_by INTEGER NOT NULL, PRIMARY KEY(id), UNIQUE (login) ); -- ---------------------------------------------------------- -- user_preferences -- ---------------------------------------------------------- CREATE TABLE user_preferences ( user_id INTEGER NOT NULL, preferences_key VARCHAR (150) NOT NULL, preferences_value VARCHAR (250) ); CREATE INDEX index_user_preferences_user_id ON user_preferences (user_id); -- ---------------------------------------------------------- -- groups -- ---------------------------------------------------------- CREATE TABLE groups ( id serial, name VARCHAR (100) NOT NULL, comments VARCHAR (250), valid_id INTEGER NOT NULL, create_time timestamp(0) NOT NULL, create_by INTEGER NOT NULL, change_time timestamp(0) NOT NULL, change_by INTEGER NOT NULL, PRIMARY KEY(id), UNIQUE (name) ); -- ---------------------------------------------------------- -- group_user -- ---------------------------------------------------------- CREATE TABLE group_user ( user_id INTEGER NOT NULL, group_id INTEGER NOT NULL, permission_key VARCHAR (20) NOT NULL, permission_value INTEGER NOT NULL, create_time timestamp(0) NOT NULL, create_by INTEGER NOT NULL, change_time timestamp(0) NOT NULL, change_by INTEGER NOT NULL ); -- ---------------------------------------------------------- -- group_customer_user -- ---------------------------------------------------------- CREATE TABLE group_customer_user ( user_id VARCHAR (100) NOT NULL, group_id INTEGER NOT NULL, permission_key VARCHAR (20) NOT NULL, permission_value INTEGER NOT NULL, create_time timestamp(0) NOT NULL, create_by INTEGER NOT NULL, change_time timestamp(0) NOT NULL, change_by INTEGER NOT NULL ); -- ---------------------------------------------------------- -- roles -- ---------------------------------------------------------- CREATE TABLE roles ( id serial, name VARCHAR (100) NOT NULL, comments VARCHAR (250), valid_id INTEGER NOT NULL, create_time timestamp(0) NOT NULL, create_by INTEGER NOT NULL, change_time timestamp(0) NOT NULL, change_by INTEGER NOT NULL, PRIMARY KEY(id), UNIQUE (name) ); -- ---------------------------------------------------------- -- role_group -- ---------------------------------------------------------- CREATE TABLE role_group ( role_id INTEGER NOT NULL, group_id INTEGER NOT NULL, permission_key VARCHAR (20) NOT NULL, permission_value INTEGER NOT NULL, create_time timestamp(0) NOT NULL, create_by INTEGER NOT NULL, change_time timestamp(0) NOT NULL, change_by INTEGER NOT NULL ); -- ---------------------------------------------------------- -- role_user -- ---------------------------------------------------------- CREATE TABLE role_user ( user_id INTEGER NOT NULL, role_id INTEGER NOT NULL, create_time timestamp(0) NOT NULL, create_by INTEGER NOT NULL, change_time timestamp(0) NOT NULL, change_by INTEGER NOT NULL ); -- ---------------------------------------------------------- -- personal_queues -- ---------------------------------------------------------- CREATE TABLE personal_queues ( user_id INTEGER NOT NULL, queue_id INTEGER NOT NULL ); -- ---------------------------------------------------------- -- theme -- ---------------------------------------------------------- CREATE TABLE theme ( id serial, theme VARCHAR (100) NOT NULL, valid_id INTEGER NOT NULL, create_time timestamp(0) NOT NULL, create_by INTEGER NOT NULL, change_time timestamp(0) NOT NULL, change_by INTEGER NOT NULL, PRIMARY KEY(id), UNIQUE (theme) ); -- ---------------------------------------------------------- -- charset -- ---------------------------------------------------------- CREATE TABLE charset ( id serial, name VARCHAR (30) NOT NULL, charset VARCHAR (30) NOT NULL, comments VARCHAR (80), valid_id INTEGER NOT NULL, create_time timestamp(0) NOT NULL, create_by INTEGER NOT NULL, change_time timestamp(0) NOT NULL, change_by INTEGER NOT NULL, PRIMARY KEY(id), UNIQUE (name) ); -- ---------------------------------------------------------- -- ticket_state -- ---------------------------------------------------------- CREATE TABLE ticket_state ( id serial, name VARCHAR (100) NOT NULL, comments VARCHAR (250), type_id INTEGER NOT NULL, valid_id INTEGER NOT NULL, create_time timestamp(0) NOT NULL, create_by INTEGER NOT NULL, change_time timestamp(0) NOT NULL, change_by INTEGER NOT NULL, PRIMARY KEY(id), UNIQUE (name) ); -- ---------------------------------------------------------- -- ticket_state_type -- ---------------------------------------------------------- CREATE TABLE ticket_state_type ( id serial, name VARCHAR (120) NOT NULL, comments VARCHAR (250), create_time timestamp(0) NOT NULL, create_by INTEGER NOT NULL, change_time timestamp(0) NOT NULL, change_by INTEGER NOT NULL, PRIMARY KEY(id), UNIQUE (name) ); -- ---------------------------------------------------------- -- salutation -- ---------------------------------------------------------- CREATE TABLE salutation ( id serial, name VARCHAR (100) NOT NULL, text LONGVARCHAR NOT NULL, comments VARCHAR (250), valid_id INTEGER NOT NULL, create_time timestamp(0) NOT NULL, create_by INTEGER NOT NULL, change_time timestamp(0) NOT NULL, change_by INTEGER NOT NULL, PRIMARY KEY(id), UNIQUE (name) ); -- ---------------------------------------------------------- -- signature -- ---------------------------------------------------------- CREATE TABLE signature ( id serial, name VARCHAR (100) NOT NULL, text LONGVARCHAR NOT NULL, comments VARCHAR (250), valid_id INTEGER NOT NULL, create_time timestamp(0) NOT NULL, create_by INTEGER NOT NULL, change_time timestamp(0) NOT NULL, change_by INTEGER NOT NULL, PRIMARY KEY(id), UNIQUE (name) ); -- ---------------------------------------------------------- -- system_address -- ---------------------------------------------------------- CREATE TABLE system_address ( id serial, value0 VARCHAR (200) NOT NULL, value1 VARCHAR (200) NOT NULL, value2 VARCHAR (200), value3 VARCHAR (200), queue_id INTEGER NOT NULL, comments VARCHAR (200), valid_id INTEGER NOT NULL, create_time timestamp(0) NOT NULL, create_by INTEGER NOT NULL, change_time timestamp(0) NOT NULL, change_by INTEGER NOT NULL, PRIMARY KEY(id) ); -- ---------------------------------------------------------- -- follow_up_possible -- ---------------------------------------------------------- CREATE TABLE follow_up_possible ( id serial, name VARCHAR (100) NOT NULL, comments VARCHAR (250), valid_id INTEGER NOT NULL, create_time timestamp(0) NOT NULL, create_by INTEGER NOT NULL, change_time timestamp(0) NOT NULL, change_by INTEGER NOT NULL, PRIMARY KEY(id), UNIQUE (name) ); -- ---------------------------------------------------------- -- queue -- ---------------------------------------------------------- CREATE TABLE queue ( id serial, name VARCHAR (200) NOT NULL, group_id INTEGER NOT NULL, unlock_timeout INTEGER, escalation_time INTEGER, system_address_id INTEGER NOT NULL, default_sign_key VARCHAR (100), salutation_id INTEGER NOT NULL, signature_id INTEGER NOT NULL, follow_up_id INTEGER NOT NULL, follow_up_lock INTEGER NOT NULL, move_notify INTEGER NOT NULL, state_notify INTEGER NOT NULL, lock_notify INTEGER NOT NULL, owner_notify INTEGER NOT NULL, comments VARCHAR (200), valid_id INTEGER NOT NULL, create_time timestamp(0) NOT NULL, create_by INTEGER NOT NULL, change_time timestamp(0) NOT NULL, change_by INTEGER NOT NULL, PRIMARY KEY(id), UNIQUE (name) ); -- ---------------------------------------------------------- -- ticket -- ---------------------------------------------------------- CREATE TABLE ticket ( id serial, tn VARCHAR (50) NOT NULL, queue_id INTEGER NOT NULL, ticket_lock_id INTEGER NOT NULL, ticket_answered INTEGER NOT NULL, user_id INTEGER NOT NULL, group_id INTEGER NOT NULL, ticket_priority_id INTEGER NOT NULL, ticket_state_id INTEGER NOT NULL, group_read INTEGER, group_write INTEGER, other_read INTEGER, other_write INTEGER, customer_id VARCHAR (150), customer_user_id VARCHAR (250), timeout INTEGER, until_time INTEGER, freekey1 VARCHAR (80), freetext1 VARCHAR (150), freekey2 VARCHAR (80), freetext2 VARCHAR (150), freekey3 VARCHAR (80), freetext3 VARCHAR (150), freekey4 VARCHAR (80), freetext4 VARCHAR (150), freekey5 VARCHAR (80), freetext5 VARCHAR (150), freekey6 VARCHAR (80), freetext6 VARCHAR (150), freekey7 VARCHAR (80), freetext7 VARCHAR (150), freekey8 VARCHAR (80), freetext8 VARCHAR (150), valid_id INTEGER NOT NULL, create_time_unix INTEGER NOT NULL, create_time timestamp(0) NOT NULL, create_by INTEGER NOT NULL, change_time timestamp(0) NOT NULL, change_by INTEGER NOT NULL, PRIMARY KEY(id), UNIQUE (tn) ); CREATE INDEX index_ticket_user ON ticket (user_id); CREATE INDEX index_ticket_queue_view ON ticket (ticket_state_id, ticket_lock_id, group_id); CREATE INDEX index_ticket_answered ON ticket (ticket_answered); -- ---------------------------------------------------------- -- ticket_link -- ---------------------------------------------------------- CREATE TABLE ticket_link ( ticket_id_master INTEGER NOT NULL, ticket_id_slave INTEGER NOT NULL ); -- ---------------------------------------------------------- -- ticket_history -- ---------------------------------------------------------- CREATE TABLE ticket_history ( id serial, name VARCHAR (200) NOT NULL, history_type_id INTEGER NOT NULL, ticket_id INTEGER NOT NULL, article_id INTEGER, queue_id INTEGER NOT NULL, owner_id INTEGER NOT NULL, priority_id INTEGER NOT NULL, state_id INTEGER NOT NULL, valid_id INTEGER NOT NULL, create_time timestamp(0) NOT NULL, create_by INTEGER NOT NULL, change_time timestamp(0) NOT NULL, change_by INTEGER NOT NULL, PRIMARY KEY(id) ); CREATE INDEX ticket_history_ticket_id ON ticket_history (ticket_id); CREATE INDEX ticket_history_create_time ON ticket_history (create_time); -- ---------------------------------------------------------- -- ticket_history_type -- ---------------------------------------------------------- CREATE TABLE ticket_history_type ( id serial, name VARCHAR (100) NOT NULL, comments VARCHAR (250), valid_id INTEGER NOT NULL, create_time timestamp(0) NOT NULL, create_by INTEGER NOT NULL, change_time timestamp(0) NOT NULL, change_by INTEGER NOT NULL, PRIMARY KEY(id), UNIQUE (name) ); -- ---------------------------------------------------------- -- article_type -- ---------------------------------------------------------- CREATE TABLE article_type ( id serial, name VARCHAR (100) NOT NULL, comments VARCHAR (250), valid_id INTEGER NOT NULL, create_time timestamp(0) NOT NULL, create_by INTEGER NOT NULL, change_time timestamp(0) NOT NULL, change_by INTEGER NOT NULL, PRIMARY KEY(id), UNIQUE (name) ); -- ---------------------------------------------------------- -- article_sender_type -- ---------------------------------------------------------- CREATE TABLE article_sender_type ( id serial, name VARCHAR (100) NOT NULL, comments VARCHAR (250), valid_id INTEGER NOT NULL, create_time timestamp(0) NOT NULL, create_by INTEGER NOT NULL, change_time timestamp(0) NOT NULL, change_by INTEGER NOT NULL, PRIMARY KEY(id), UNIQUE (name) ); -- ---------------------------------------------------------- -- article -- ---------------------------------------------------------- CREATE TABLE article ( id serial, ticket_id INTEGER NOT NULL, article_type_id INTEGER NOT NULL, article_sender_type_id INTEGER NOT NULL, a_from LONGVARCHAR, a_reply_to VARCHAR (255), a_to LONGVARCHAR, a_cc LONGVARCHAR, a_subject LONGVARCHAR, a_message_id LONGVARCHAR, a_content_type VARCHAR (250), a_body LONGVARCHAR NOT NULL, incoming_time INTEGER NOT NULL, content_path VARCHAR (250), a_freekey1 VARCHAR (250), a_freetext1 VARCHAR (250), a_freekey2 VARCHAR (250), a_freetext2 VARCHAR (250), a_freekey3 VARCHAR (250), a_freetext3 VARCHAR (250), valid_id INTEGER NOT NULL, create_time timestamp(0) NOT NULL, create_by INTEGER NOT NULL, change_time timestamp(0) NOT NULL, change_by INTEGER NOT NULL, PRIMARY KEY(id) ); CREATE INDEX article_ticket_id ON article (ticket_id); CREATE INDEX article_message_id ON article (a_message_id); -- ---------------------------------------------------------- -- article_plain -- ---------------------------------------------------------- CREATE TABLE article_plain ( id serial, article_id INTEGER NOT NULL, body LONGVARCHAR NOT NULL, create_time timestamp(0) NOT NULL, create_by INTEGER NOT NULL, change_time timestamp(0) NOT NULL, change_by INTEGER NOT NULL, PRIMARY KEY(id) ); CREATE INDEX article_id ON article_plain (article_id); -- ---------------------------------------------------------- -- article_attachment -- ---------------------------------------------------------- CREATE TABLE article_attachment ( id serial, article_id INTEGER NOT NULL, filename VARCHAR (250), content_size VARCHAR (30), content_type VARCHAR (250), content LONGVARCHAR NOT NULL, create_time timestamp(0) NOT NULL, create_by INTEGER NOT NULL, change_time timestamp(0) NOT NULL, change_by INTEGER NOT NULL, PRIMARY KEY(id) ); CREATE INDEX article_id ON article_attachment (article_id); -- ---------------------------------------------------------- -- standard_response -- ---------------------------------------------------------- CREATE TABLE standard_response ( id serial, name VARCHAR (80) NOT NULL, text LONGVARCHAR NOT NULL, comments VARCHAR (80), valid_id INTEGER NOT NULL, create_time timestamp(0) NOT NULL, create_by INTEGER NOT NULL, change_time timestamp(0) NOT NULL, change_by INTEGER NOT NULL, PRIMARY KEY(id), UNIQUE (name) ); -- ---------------------------------------------------------- -- queue_standard_response -- ---------------------------------------------------------- CREATE TABLE queue_standard_response ( queue_id INTEGER NOT NULL, standard_response_id INTEGER NOT NULL, create_time timestamp(0) NOT NULL, create_by INTEGER NOT NULL, change_time timestamp(0) NOT NULL, change_by INTEGER NOT NULL ); -- ---------------------------------------------------------- -- standard_attachment -- ---------------------------------------------------------- CREATE TABLE standard_attachment ( id serial, name VARCHAR (150) NOT NULL, content_type VARCHAR (150) NOT NULL, content LONGVARCHAR NOT NULL, filename VARCHAR (250) NOT NULL, comments VARCHAR (200), valid_id INTEGER NOT NULL, create_time timestamp(0) NOT NULL, create_by INTEGER NOT NULL, change_time timestamp(0) NOT NULL, change_by INTEGER NOT NULL, PRIMARY KEY(id), UNIQUE (name) ); -- ---------------------------------------------------------- -- standard_response_attachment -- ---------------------------------------------------------- CREATE TABLE standard_response_attachment ( id serial, standard_attachment_id INTEGER NOT NULL, standard_response_id INTEGER NOT NULL, create_time timestamp(0) NOT NULL, create_by INTEGER NOT NULL, change_time timestamp(0) NOT NULL, change_by INTEGER NOT NULL, PRIMARY KEY(id) ); -- ---------------------------------------------------------- -- auto_response_type -- ---------------------------------------------------------- CREATE TABLE auto_response_type ( id serial, name VARCHAR (50) NOT NULL, comments VARCHAR (80), valid_id INTEGER NOT NULL, create_time timestamp(0) NOT NULL, create_by INTEGER NOT NULL, change_time timestamp(0) NOT NULL, change_by INTEGER NOT NULL, PRIMARY KEY(id), UNIQUE (name) ); -- ---------------------------------------------------------- -- auto_response -- ---------------------------------------------------------- CREATE TABLE auto_response ( id serial, name VARCHAR (80) NOT NULL, text0 LONGVARCHAR, text1 LONGVARCHAR, text2 LONGVARCHAR, type_id INTEGER NOT NULL, system_address_id INTEGER NOT NULL, charset VARCHAR (80) NOT NULL, comments VARCHAR (100), valid_id INTEGER NOT NULL, create_time timestamp(0) NOT NULL, create_by INTEGER NOT NULL, change_time timestamp(0) NOT NULL, change_by INTEGER NOT NULL, PRIMARY KEY(id), UNIQUE (name) ); -- ---------------------------------------------------------- -- queue_auto_response -- ---------------------------------------------------------- CREATE TABLE queue_auto_response ( id serial, queue_id INTEGER NOT NULL, auto_response_id INTEGER NOT NULL, create_time timestamp(0) NOT NULL, create_by INTEGER NOT NULL, change_time timestamp(0) NOT NULL, change_by INTEGER NOT NULL, PRIMARY KEY(id) ); -- ---------------------------------------------------------- -- time_accounting -- ---------------------------------------------------------- CREATE TABLE time_accounting ( id serial, ticket_id INTEGER NOT NULL, article_id INTEGER, time_unit INTEGER NOT NULL, create_time timestamp(0) NOT NULL, create_by INTEGER NOT NULL, change_time timestamp(0) NOT NULL, change_by INTEGER NOT NULL, PRIMARY KEY(id) ); CREATE INDEX index_ticket_id ON time_accounting (ticket_id); -- ---------------------------------------------------------- -- session -- ---------------------------------------------------------- CREATE TABLE session ( session_id VARCHAR (120) NOT NULL, value LONGVARCHAR NOT NULL, UNIQUE (session_id) ); CREATE INDEX index_session_id ON session (session_id); -- ---------------------------------------------------------- -- ticket_index -- ---------------------------------------------------------- CREATE TABLE ticket_index ( ticket_id INTEGER NOT NULL, queue_id INTEGER NOT NULL, queue VARCHAR (70) NOT NULL, group_id INTEGER NOT NULL, s_lock VARCHAR (70) NOT NULL, s_state VARCHAR (70) NOT NULL, create_time_unix INTEGER NOT NULL ); CREATE INDEX index_ticket_id ON ticket_index (ticket_id); -- ---------------------------------------------------------- -- ticket_lock_index -- ---------------------------------------------------------- CREATE TABLE ticket_lock_index ( ticket_id INTEGER NOT NULL ); CREATE INDEX index_ticket_id ON ticket_lock_index (ticket_id); -- ---------------------------------------------------------- -- customer_user -- ---------------------------------------------------------- CREATE TABLE customer_user ( id serial, login VARCHAR (100) NOT NULL, email VARCHAR (150) NOT NULL, customer_id VARCHAR (200) NOT NULL, pw VARCHAR (50) NOT NULL, salutation VARCHAR (50), first_name VARCHAR (100) NOT NULL, last_name VARCHAR (100) NOT NULL, comments VARCHAR (250) NOT NULL, valid_id INTEGER NOT NULL, create_time timestamp(0) NOT NULL, create_by INTEGER NOT NULL, change_time timestamp(0) NOT NULL, change_by INTEGER NOT NULL, PRIMARY KEY(id), UNIQUE (login) ); -- ---------------------------------------------------------- -- customer_preferences -- ---------------------------------------------------------- CREATE TABLE customer_preferences ( user_id VARCHAR (250) NOT NULL, preferences_key VARCHAR (150) NOT NULL, preferences_value VARCHAR (250) ); CREATE INDEX index_customer_preferences_user_id ON customer_preferences (user_id); -- ---------------------------------------------------------- -- ticket_loop_protection -- ---------------------------------------------------------- CREATE TABLE ticket_loop_protection ( sent_to VARCHAR (250) NOT NULL, sent_date VARCHAR (150) NOT NULL ); CREATE INDEX index_ticket_loop_protection_sent_to ON ticket_loop_protection (sent_to); CREATE INDEX index_ticket_loop_protection_sent_date ON ticket_loop_protection (sent_date); -- ---------------------------------------------------------- -- pop3_account -- ---------------------------------------------------------- CREATE TABLE pop3_account ( id serial, login VARCHAR (200) NOT NULL, pw VARCHAR (200) NOT NULL, host VARCHAR (200) NOT NULL, queue_id INTEGER NOT NULL, trusted INTEGER NOT NULL, comments VARCHAR (250), valid_id INTEGER NOT NULL, create_time timestamp(0) NOT NULL, create_by INTEGER NOT NULL, change_time timestamp(0) NOT NULL, change_by INTEGER NOT NULL, PRIMARY KEY(id) ); -- ---------------------------------------------------------- -- postmaster_filter -- ---------------------------------------------------------- CREATE TABLE postmaster_filter ( f_name VARCHAR (200) NOT NULL, f_type VARCHAR (20) NOT NULL, f_key VARCHAR (200) NOT NULL, f_value VARCHAR (200) NOT NULL ); -- ---------------------------------------------------------- -- generic_agent_jobs -- ---------------------------------------------------------- CREATE TABLE generic_agent_jobs ( job_name VARCHAR (200) NOT NULL, job_key VARCHAR (200) NOT NULL, job_value VARCHAR (200) NOT NULL ); -- ---------------------------------------------------------- -- search_profile -- ---------------------------------------------------------- CREATE TABLE search_profile ( login VARCHAR (200) NOT NULL, profile_name VARCHAR (200) NOT NULL, profile_key VARCHAR (200) NOT NULL, profile_value VARCHAR (200) NOT NULL ); -- ---------------------------------------------------------- -- notifications -- ---------------------------------------------------------- CREATE TABLE notifications ( id serial, notification_type VARCHAR (200) NOT NULL, notification_charset VARCHAR (60) NOT NULL, notification_language VARCHAR (60) NOT NULL, subject VARCHAR (200) NOT NULL, text LONGVARCHAR NOT NULL, create_time timestamp(0) NOT NULL, create_by INTEGER NOT NULL, change_time timestamp(0) NOT NULL, change_by INTEGER NOT NULL, PRIMARY KEY(id) ); -- ---------------------------------------------------------- -- faq_item -- ---------------------------------------------------------- CREATE TABLE faq_item ( id serial, f_name VARCHAR (200) NOT NULL, f_language_id INTEGER NOT NULL, f_subject VARCHAR (200), state_id INTEGER NOT NULL, category_id INTEGER NOT NULL, f_keywords LONGVARCHAR, f_field1 LONGVARCHAR, f_field2 LONGVARCHAR, f_field3 LONGVARCHAR, f_field4 LONGVARCHAR, f_field5 LONGVARCHAR, f_field6 LONGVARCHAR, free_key1 VARCHAR (80), free_value1 VARCHAR (200), free_key2 VARCHAR (80), free_value2 VARCHAR (200), free_key3 VARCHAR (80), free_value3 VARCHAR (200), free_key4 VARCHAR (80), free_value4 VARCHAR (200), create_time timestamp(0) NOT NULL, create_by INTEGER NOT NULL, change_time timestamp(0) NOT NULL, change_by INTEGER NOT NULL, PRIMARY KEY(id), UNIQUE (f_name) ); -- ---------------------------------------------------------- -- faq_language -- ---------------------------------------------------------- CREATE TABLE faq_language ( id serial, name VARCHAR (200) NOT NULL, PRIMARY KEY(id), UNIQUE (name) ); -- ---------------------------------------------------------- -- faq_history -- ---------------------------------------------------------- CREATE TABLE faq_history ( id serial, name VARCHAR (200) NOT NULL, item_id INTEGER NOT NULL, create_time timestamp(0) NOT NULL, create_by INTEGER NOT NULL, change_time timestamp(0) NOT NULL, change_by INTEGER NOT NULL, PRIMARY KEY(id) ); -- ---------------------------------------------------------- -- faq_category -- ---------------------------------------------------------- CREATE TABLE faq_category ( id serial, name VARCHAR (200) NOT NULL, comments VARCHAR (200) NOT NULL, create_time timestamp(0) NOT NULL, create_by INTEGER NOT NULL, change_time timestamp(0) NOT NULL, change_by INTEGER NOT NULL, PRIMARY KEY(id), UNIQUE (name) ); -- ---------------------------------------------------------- -- faq_state -- ---------------------------------------------------------- CREATE TABLE faq_state ( id serial, name VARCHAR (200) NOT NULL, type_id INTEGER NOT NULL, PRIMARY KEY(id), UNIQUE (name) ); -- ---------------------------------------------------------- -- faq_state_type -- ---------------------------------------------------------- CREATE TABLE faq_state_type ( id serial, name VARCHAR (200) NOT NULL, PRIMARY KEY(id), UNIQUE (name) ); -- ---------------------------------------------------------- -- database: postgresql, generated: Mon Nov 1 11:31:22 2004 -- ----------------------------------------------------------