Re: [dev] Line Wrapping/PostgreSQL Patches Status?

At 10/27/04 11:02 PM, Martin Edenhofer 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. Thanks again! -- Robert L Mathews, Tiger Technologies http://www.tigertech.net/ "Ignorance more frequently begets confidence than does knowledge." -- Darwin

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 -- ----------------------------------------------------------

Martin Edenhofer schrieb:
Attached it the postgresql create script for OTRS 1.3 with your performace improvements.
I created the following, additional indexes for PostgreSQL. I don't know if they all are useful and necessary, but am experiencing speed improvements. Sorry, the used naming scheme might be better. Regards, Robert Kehl CREATE INDEX article_attachment_filename_index ON public.article_attachment USING btree (filename); CREATE INDEX article_attachment_content_type_index ON public.article_attachment USING btree (content_type); CREATE INDEX article_attachment_content_size_index ON public.article_attachment USING btree (content_size); CREATE INDEX article_plain_article_id_index ON public.article_plain USING btree (article_id); CREATE INDEX generic_agent_jobs_job_name_index ON public.generic_agent_jobs USING btree (job_name); CREATE INDEX group_customer_user_user_id_index ON public.group_customer_user USING btree (user_id); CREATE INDEX group_customer_user_group_id_index ON public.group_customer_user USING btree (group_id); CREATE INDEX group_role_role_id_index ON public.group_role USING btree (role_id); CREATE INDEX group_user_user_id_index ON public.group_user USING btree (user_id); CREATE INDEX group_user_group_id_index ON public.group_user USING btree (group_id); CREATE INDEX notifications_notification_type_index ON public.notifications USING btree (notification_type); CREATE INDEX personal_queues_user_id_index ON public.personal_queues USING btree (user_id); CREATE INDEX personal_queues_queue_id_index ON public.personal_queues USING btree (queue_id); CREATE INDEX postmaster_filter_f_name_index ON public.postmaster_filter USING btree (f_name); CREATE INDEX queue_group_id_index ON public.queue USING btree (group_id); CREATE INDEX queue_system_address_id_index ON public.queue USING btree (system_address_id); CREATE INDEX queue_auto_response_queue_id_index ON public.queue_auto_response USING btree (queue_id); CREATE INDEX queue_auto_response_auto_response_id_index ON public.queue_auto_response USING btree (auto_response_id); CREATE INDEX queue_standard_response_queue_id_index ON public.queue_standard_response USING btree (queue_id); CREATE INDEX queue_standard_response_standard_response_id_index ON public.queue_standard_response USING btree (standard_response_id); CREATE INDEX role_user_role_id_index ON public.role_user USING btree (role_id); CREATE INDEX role_user_user_id_index ON public.role_user USING btree (user_id); CREATE INDEX search_profile_login_index ON public.search_profile USING btree (login); CREATE INDEX search_profile_name_index ON public.search_profile USING btree (profile_name); CREATE INDEX session_session_id_index ON public.session USING btree (session_id); CREATE INDEX standard_response_attachment_standard_attachment_id_index ON public.standard_response_attachment USING btree (standard_attachment_id); CREATE INDEX standard_response_attachment_standard_response_id_index ON public.standard_response_attachment USING btree (standard_response_id); CREATE INDEX system_address_queue_id_index ON public.system_address USING btree (queue_id); CREATE INDEX ticket_queue_id_index ON public.ticket USING btree (queue_id); CREATE INDEX ticket_group_id_index ON public.ticket USING btree (group_id); CREATE INDEX ticket_history_article_id_index ON public.ticket_history USING btree (article_id); CREATE INDEX ticket_index_queue_id_index ON public.ticket_index USING btree (queue_id); CREATE INDEX ticket_index_group_id_index ON public.ticket_index USING btree (group_id); CREATE INDEX ticket_link_ticket_id_master_index ON public.ticket_link USING btree (ticket_id_master); CREATE INDEX ticket_link_ticket_id_slave_index ON public.ticket_link USING btree (ticket_id_slave); CREATE INDEX ticket_state_for_type_id_index ON public.ticket_state USING btree (type_id); CREATE INDEX time_accounting_article_id_index ON public.time_accounting USING btree (article_id);
participants (3)
-
Martin Edenhofer
-
Robert Kehl
-
Robert L Mathews