Upgrade 4.0.17 clean.
[usit-rt.git] / etc / upgrade / 3.3.0 / schema.mysql
1 drop index transactions1 ON Transactions;
2
3 alter Table Transactions
4     ADD COLUMN  (ObjectType varchar(64) not null),
5     DROP COLUMN EffectiveTicket,
6     ADD COLUMN  ReferenceType varchar(255) NULL,
7     ADD COLUMN  OldReference integer NULL,
8     ADD COLUMN  NewReference integer NULL,
9     CHANGE      Ticket ObjectId integer NOT NULL DEFAULT 0;
10
11 UPDATE Transactions set ObjectType = 'RT::Ticket';
12 CREATE INDEX Transactions1 ON Transactions (ObjectType, ObjectId);
13
14 alter table TicketCustomFieldValues rename ObjectCustomFieldValues,
15     change Ticket ObjectId integer NOT NULL DEFAULT 0  ,
16     add column ObjectType varchar(255) not null,
17     add column Current bool default 1,
18     add column LargeContent LONGTEXT NULL,
19     add column ContentType varchar(80) NULL,
20     add column ContentEncoding varchar(80) NULL;
21
22 update ObjectCustomFieldValues set ObjectType = 'RT::Ticket';
23
24 # These could fail if there's no such index and there's no "drop index if exists" syntax
25 #alter table ObjectCustomFieldValues drop index ticketcustomfieldvalues1;
26 #alter table ObjectCustomFieldValues drop index ticketcustomfieldvalues2;
27
28 alter table ObjectCustomFieldValues add index ObjectCustomFieldValues1 (Content),
29     add index ObjectCustomFieldValues2 (CustomField,ObjectType,ObjectId);
30
31
32 CREATE TABLE ObjectCustomFields (
33   id INTEGER NOT NULL  AUTO_INCREMENT,
34   CustomField int NOT NULL  ,
35   ObjectId integer NOT NULL,
36   SortOrder integer NOT NULL DEFAULT 0  ,
37
38   Creator integer NOT NULL DEFAULT 0  ,
39   Created DATETIME NULL  ,
40   LastUpdatedBy integer NOT NULL DEFAULT 0  ,
41   LastUpdated DATETIME NULL  ,
42   PRIMARY KEY (id)
43 ) ENGINE=InnoDB;
44
45
46 INSERT into ObjectCustomFields (id, CustomField, ObjectId, SortOrder, Creator, LastUpdatedBy) SELECT  null, id, Queue, SortOrder, Creator, LastUpdatedBy from CustomFields;
47
48 alter table CustomFields add column LookupType varchar(255) NOT NULL,
49     add column Repeated int2 NOT NULL DEFAULT 0 ,
50     add column Pattern varchar(255) NULL,
51     add column MaxValues integer;
52 # See above
53 # alter table CustomFields drop index CustomFields1;
54
55 UPDATE CustomFields SET MaxValues = 0 WHERE Type LIKE '%Multiple';
56 UPDATE CustomFields SET MaxValues = 1 WHERE Type LIKE '%Single';
57 UPDATE CustomFields SET Type = 'Select' WHERE Type LIKE 'Select%';
58 UPDATE CustomFields SET Type = 'Freeform' WHERE Type LIKE 'Freeform%';
59 UPDATE CustomFields Set LookupType = 'RT::Queue-RT::Ticket';
60 alter table CustomFields drop column Queue;