Warning, /pim/akonadi/src/server/storage/dbupdate.xml is written in an unsupported language. File is not indexed.

0001 <?xml version="1.0" encoding="UTF-8"?>
0002 <!--
0003 
0004     SPDX-FileCopyrightText: 2007 Volker Krause <vkrause@kde.org>
0005 
0006     SPDX-License-Identifier: LGPL-2.0-or-later
0007 
0008 -->
0009 
0010 
0011 <!--
0012   Akonadi Database Schema Update Description
0013 
0014   update element:
0015     text: SQL statement to execute for update
0016     version attribute: the new schmema version
0017     abortOnFailure attribute: if true, the update must succeed, otherwise failures are ignored
0018 
0019   Please note: if you're adding a column to the db then you DON'T need to add an update
0020   statement here. Add your column to akonadidb.xml instead: it will be added to the db automagically.
0021 -->
0022 <updates>
0023 
0024   <update version="2" abortOnFailure="false">
0025     <raw-sql backends="mysql,psql,sqlite">ALTER TABLE LocationTable DROP COLUMN existCount;</raw-sql>
0026     <raw-sql backends="mysql,psql,sqlite">ALTER TABLE LocationTable DROP COLUMN recentCount;</raw-sql>
0027     <raw-sql backends="mysql,psql,sqlite">ALTER TABLE LocationTable DROP COLUMN unseenCount;</raw-sql>
0028     <raw-sql backends="mysql,psql,sqlite">ALTER TABLE LocationTable DROP COLUMN firstUnseen;</raw-sql>
0029   </update>
0030 
0031   <update version="3" abortOnFailure="false">
0032     <raw-sql backends="mysql,psql,sqlite">UPDATE LocationTable SET subscribed = true;</raw-sql>
0033   </update>
0034 
0035   <update version="4" abortOnFailure="false">
0036     <raw-sql backends="mysql,psql,sqlite">ALTER TABLE LocationTable DROP COLUMN cachePolicyId;</raw-sql>
0037     <raw-sql backends="mysql,psql,sqlite">ALTER TABLE ResourceTable DROP COLUMN cachePolicyId;</raw-sql>
0038     <raw-sql backends="mysql,psql,sqlite">DROP TABLE CachePolicyTable;</raw-sql>
0039   </update>
0040 
0041   <update version="8" abortOnFailure="false">
0042     <raw-sql backends="mysql,psql,sqlite">UPDATE PartTable SET name = 'PLD:ENVELOPE' WHERE name = 'ENVELOPE';</raw-sql>
0043     <raw-sql backends="mysql,psql,sqlite">UPDATE PartTable SET name = 'PLD:RFC822' WHERE name = 'RFC822';</raw-sql>
0044     <raw-sql backends="mysql,psql,sqlite">UPDATE PartTable SET name = 'PLD:HEAD' WHERE name = 'HEAD';</raw-sql>
0045     <raw-sql backends="mysql,psql,sqlite">UPDATE PartTable SET name = concat( 'ATR:', name ) WHERE substr( name, 1, 4 ) != 'PLD:';</raw-sql>
0046   </update>
0047 
0048   <!-- the initializer runs first, so we will have all the new tables and columns already
0049        therefore we have to clean that up first -->
0050   <update version="10" abortOnFailure="true">
0051     <raw-sql backends="mysql,psql,sqlite">DROP TABLE CollectionTable;</raw-sql>
0052     <raw-sql backends="mysql,psql,sqlite">ALTER TABLE LocationTable RENAME TO CollectionTable;</raw-sql>
0053     <raw-sql backends="mysql,psql,sqlite">ALTER TABLE PimItemTable DROP COLUMN collectionId;</raw-sql>
0054     <raw-sql backends="mysql,psql,sqlite">ALTER TABLE PimItemTable CHANGE locationId collectionId BIGINT;</raw-sql>
0055     <raw-sql backends="mysql,psql,sqlite">DROP TABLE CollectionAttributeTable;</raw-sql>
0056     <raw-sql backends="mysql,psql,sqlite">ALTER TABLE LocationAttributeTable CHANGE locationId collectionId BIGINT;</raw-sql>
0057     <raw-sql backends="mysql,psql,sqlite">ALTER TABLE LocationAttributeTable RENAME TO CollectionAttributeTable;</raw-sql>
0058     <raw-sql backends="mysql,psql,sqlite">DROP TABLE CollectionMimeTypeRelation;</raw-sql>
0059     <raw-sql backends="mysql,psql,sqlite">ALTER TABLE LocationMimeTypeRelation CHANGE Location_Id Collection_Id BIGINT NOT NULL DEFAULT '0';</raw-sql>
0060     <raw-sql backends="mysql,psql,sqlite">ALTER TABLE LocationMimeTypeRelation RENAME TO CollectionMimeTypeRelation;</raw-sql>
0061     <raw-sql backends="mysql,psql,sqlite">DROP TABLE CollectionPimItemRelation;</raw-sql>
0062     <raw-sql backends="mysql,psql,sqlite">ALTER TABLE LocationPimItemRelation CHANGE Location_Id Collection_Id BIGINT NOT NULL DEFAULT '0';</raw-sql>
0063     <raw-sql backends="mysql,psql,sqlite">ALTER TABLE LocationPimItemRelation RENAME TO CollectionPimItemRelation;</raw-sql>
0064   </update>
0065 
0066   <update version="12" abortOnFailure="false">
0067     <raw-sql backends="mysql,psql,sqlite">ALTER TABLE PartTable CHANGE datasize datasize BIGINT;</raw-sql>
0068   </update>
0069 
0070   <update version="13" abortOnFailure="true">
0071     <raw-sql backends="mysql,psql,sqlite">UPDATE CollectionTable SET parentId = NULL WHERE parentId = 0;</raw-sql>
0072     <raw-sql backends="mysql,psql,sqlite">ALTER TABLE CollectionTable CHANGE parentId parentId BIGINT DEFAULT NULL;</raw-sql>
0073   </update>
0074 
0075   <update version="14" abortOnFailure="false">
0076     <raw-sql backends="mysql,psql,sqlite">UPDATE ResourceTable SET isVirtual = true WHERE name = 'akonadi_nepomuktag_resource';</raw-sql>
0077     <raw-sql backends="mysql,psql,sqlite">UPDATE ResourceTable SET isVirtual = true WHERE name = 'akonadi_search_resource';</raw-sql>
0078   </update>
0079 
0080   <update version="15" abortOnFailure="false">
0081     <raw-sql backends="mysql,psql,sqlite">UPDATE CollectionTable SET queryString = remoteId WHERE resourceId = 1 AND parentId IS NOT NULL;</raw-sql>
0082     <raw-sql backends="mysql,psql,sqlite">UPDATE CollectionTable SET queryLanguage = 'SPARQL' WHERE resourceId = 1 AND parentId IS NOT NULL;</raw-sql>
0083   </update>
0084 
0085   <update version="16" abortOnFailure="false">
0086     <raw-sql backends="mysql,psql,sqlite">ALTER TABLE CollectionAttributeTable CONVERT TO CHARACTER SET utf8 COLLATE utf8_general_ci;</raw-sql>
0087     <raw-sql backends="mysql,psql,sqlite">ALTER TABLE CollectionMimeTypeRelation CONVERT TO CHARACTER SET utf8 COLLATE utf8_general_ci;</raw-sql>
0088     <raw-sql backends="mysql,psql,sqlite">ALTER TABLE CollectionPimItemRelation CONVERT TO CHARACTER SET utf8 COLLATE utf8_general_ci;</raw-sql>
0089     <raw-sql backends="mysql,psql,sqlite">ALTER TABLE CollectionTable CONVERT TO CHARACTER SET utf8 COLLATE utf8_general_ci;</raw-sql>
0090     <raw-sql backends="mysql,psql,sqlite">ALTER TABLE FlagTable CONVERT TO CHARACTER SET utf8 COLLATE utf8_general_ci;</raw-sql>
0091     <raw-sql backends="mysql,psql,sqlite">ALTER TABLE MimeTypeTable CONVERT TO CHARACTER SET utf8 COLLATE utf8_general_ci;</raw-sql>
0092     <raw-sql backends="mysql,psql,sqlite">ALTER TABLE PartTable CONVERT TO CHARACTER SET utf8 COLLATE utf8_general_ci;</raw-sql>
0093     <raw-sql backends="mysql,psql,sqlite">ALTER TABLE PimItemFlagRelation CONVERT TO CHARACTER SET utf8 COLLATE utf8_general_ci;</raw-sql>
0094     <raw-sql backends="mysql,psql,sqlite">ALTER TABLE PimitemTable CONVERT TO CHARACTER SET utf8 COLLATE utf8_general_ci;</raw-sql>
0095     <raw-sql backends="mysql,psql,sqlite">ALTER TABLE ResourceTable CONVERT TO CHARACTER SET utf8 COLLATE utf8_general_ci;</raw-sql>
0096     <raw-sql backends="mysql,psql,sqlite">ALTER TABLE SchemaVersionTable CONVERT TO CHARACTER SET utf8 COLLATE utf8_general_ci;</raw-sql>
0097   </update>
0098 
0099   <!-- change all string based columns to use BINARY flag, this makes the comparison operator
0100        finally work -->
0101   <update version="17" abortOnFailure="false">
0102     <raw-sql backends="mysql">ALTER TABLE ResourceTable CHANGE name name VARCHAR(255) BINARY UNIQUE;</raw-sql>
0103     <raw-sql backends="mysql">ALTER TABLE CollectionTable CHANGE remoteId remoteId VARCHAR(255) BINARY;</raw-sql>
0104     <raw-sql backends="mysql">ALTER TABLE CollectionTable CHANGE remoteRevision remoteRevision VARCHAR(255) BINARY;</raw-sql>
0105     <raw-sql backends="mysql">ALTER TABLE CollectionTable CHANGE name name VARCHAR(255) BINARY;</raw-sql>
0106     <raw-sql backends="mysql">ALTER TABLE CollectionTable CHANGE cachePolicyLocalParts cachePolicyLocalParts VARCHAR(255) BINARY;</raw-sql>
0107     <raw-sql backends="mysql">ALTER TABLE CollectionTable CHANGE queryString queryString VARCHAR(255) BINARY;</raw-sql>
0108     <raw-sql backends="mysql">ALTER TABLE CollectionTable CHANGE queryLanguage queryLanguage VARCHAR(255) BINARY;</raw-sql>
0109     <raw-sql backends="mysql">ALTER TABLE MimeTypeTable CHANGE name name VARCHAR(255) BINARY UNIQUE;</raw-sql>
0110     <raw-sql backends="mysql">ALTER TABLE PimItemTable CHANGE remoteId remoteId VARCHAR(255) BINARY;</raw-sql>
0111     <raw-sql backends="mysql">ALTER TABLE PimItemTable CHANGE remoteRevision remoteRevision VARCHAR(255) BINARY;</raw-sql>
0112     <raw-sql backends="mysql">ALTER TABLE FlagTable CHANGE name name VARCHAR(255) BINARY UNIQUE;</raw-sql>
0113     <raw-sql backends="mysql">ALTER TABLE PartTable CHANGE name name VARCHAR(255) BINARY;</raw-sql>
0114   </update>
0115 
0116   <!-- change all string based columns to VARBINARY to make indexes and comparison operator work -->
0117   <update version="18" abortOnFailure="false">
0118     <raw-sql backends="mysql">ALTER TABLE ResourceTable CHANGE name name VARBINARY(255) UNIQUE;</raw-sql>
0119     <raw-sql backends="mysql">ALTER TABLE CollectionTable CHANGE remoteId remoteId VARBINARY(255);</raw-sql>
0120     <raw-sql backends="mysql">ALTER TABLE CollectionTable CHANGE remoteRevision remoteRevision VARBINARY(255);</raw-sql>
0121     <raw-sql backends="mysql">ALTER TABLE CollectionTable CHANGE name name VARBINARY(255);</raw-sql>
0122     <raw-sql backends="mysql">ALTER TABLE CollectionTable CHANGE cachePolicyLocalParts cachePolicyLocalParts VARBINARY(255);</raw-sql>
0123     <raw-sql backends="mysql">ALTER TABLE CollectionTable CHANGE queryString queryString VARBINARY(255);</raw-sql>
0124     <raw-sql backends="mysql">ALTER TABLE CollectionTable CHANGE queryLanguage queryLanguage VARBINARY(255);</raw-sql>
0125     <raw-sql backends="mysql">ALTER TABLE MimeTypeTable CHANGE name name VARBINARY(255) UNIQUE;</raw-sql>
0126     <raw-sql backends="mysql">ALTER TABLE PimItemTable CHANGE remoteId remoteId VARBINARY(255);</raw-sql>
0127     <raw-sql backends="mysql">ALTER TABLE PimItemTable CHANGE remoteRevision remoteRevision VARBINARY(255);</raw-sql>
0128     <raw-sql backends="mysql">ALTER TABLE FlagTable CHANGE name name VARBINARY(255) UNIQUE;</raw-sql>
0129     <raw-sql backends="mysql">ALTER TABLE PartTable CHANGE name name VARBINARY(255);</raw-sql>
0130   </update>
0131   <update version="19" abortOnFailure="false">
0132     <raw-sql backends="mysql,psql,sqlite">UPDATE PimItemFlagRelation SET Flag_id=(SELECT id FROM FlagTable WHERE name='\\SEEN') WHERE Flag_id=(SELECT id FROM FlagTable WHERE name='\\Seen');</raw-sql>
0133     <raw-sql backends="mysql,psql,sqlite">DELETE FROM FlagTable WHERE name='\\Seen';</raw-sql>
0134   </update>
0135 
0136   <!-- wider query column (only affects MySQL) -->
0137   <update version="20" abortOnFailure="false">
0138     <raw-sql backends="mysql">ALTER TABLE CollectionTable CHANGE queryString queryString VARBINARY(1024);</raw-sql>
0139   </update>
0140 
0141   <!-- even wider query column (only affects MySQL) -->
0142   <update version="21" abortOnFailure="false">
0143     <raw-sql backends="mysql">ALTER TABLE CollectionTable CHANGE queryString queryString VARBINARY(32768);</raw-sql>
0144   </update>
0145 
0146   <!-- fix previously wrongly used 32bit column type on n:m helper tables (TODO: also needed for the other backends) -->
0147   <update version="22" abortOnFailure="false">
0148     <raw-sql backends="mysql">ALTER TABLE PimItemFlagRelation CHANGE PimItem_id PimItem_id BIGINT NOT NULL</raw-sql>
0149     <raw-sql backends="mysql">ALTER TABLE PimItemFlagRelation CHANGE Flag_id Flag_id BIGINT NOT NULL</raw-sql>
0150     <raw-sql backends="mysql">ALTER TABLE CollectionMimeTypeRelation CHANGE Collection_id Collection_id BIGINT NOT NULL</raw-sql>
0151     <raw-sql backends="mysql">ALTER TABLE CollectionMimeTypeRelation CHANGE MimeType_id MimeType_id BIGINT NOT NULL</raw-sql>
0152     <raw-sql backends="mysql">ALTER TABLE CollectionPimItemRelation CHANGE Collection_id Collection_id BIGINT NOT NULL</raw-sql>
0153     <raw-sql backends="mysql">ALTER TABLE CollectionPimItemRelation CHANGE PimItem_id PimItem_id BIGINT NOT NULL</raw-sql>
0154   </update>
0155 
0156   <update version="23" abortOnFailure="false">
0157     <raw-sql backends="mysql,psql">UPDATE CollectionTable SET isVirtual = true WHERE resourceId IN (SELECT id FROM ResourceTable WHERE isVirtual = true)</raw-sql>
0158     <raw-sql backends="sqlite">UPDATE CollectionTable SET isVirtual = 1 WHERE resourceId IN (SELECT id FROM ResourceTable WHERE isVirtual = 1)</raw-sql>
0159   </update>
0160 
0161   <update version="24" abortOnFailure="false">
0162     <raw-sql backends="psql">ALTER TABLE CollectionTable ALTER remoteId TYPE text USING convert_from(remoteId,'utf8');</raw-sql>
0163     <raw-sql backends="psql">ALTER TABLE CollectionTable ALTER remoteRevision TYPE text USING convert_from(remoteRevision,'utf8');</raw-sql>
0164     <raw-sql backends="psql">ALTER TABLE CollectionTable ALTER name TYPE text USING convert_from(name,'utf8');</raw-sql>
0165     <raw-sql backends="psql">ALTER TABLE CollectionTable ALTER cachePolicyLocalParts TYPE text USING convert_from(cachePolicyLocalParts,'utf8');</raw-sql>
0166     <raw-sql backends="psql">ALTER TABLE CollectionTable ALTER queryString TYPE text USING convert_from(queryString,'utf8');</raw-sql>
0167     <raw-sql backends="psql">ALTER TABLE CollectionTable ALTER queryLanguage TYPE text USING convert_from(queryLanguage,'utf8');</raw-sql>
0168     <raw-sql backends="psql">ALTER TABLE FlagTable ALTER name TYPE text USING convert_from(name,'utf8');</raw-sql>
0169     <raw-sql backends="psql">ALTER TABLE MimeTypeTable ALTER name TYPE text USING convert_from(name,'utf8');</raw-sql>
0170     <raw-sql backends="psql">ALTER TABLE PartTable ALTER name TYPE text USING convert_from(name,'utf8');</raw-sql>
0171     <raw-sql backends="psql">ALTER TABLE PimItemTable ALTER remoteId TYPE text USING convert_from(remoteId,'utf8');</raw-sql>
0172     <raw-sql backends="psql">ALTER TABLE PimItemTable ALTER remoteRevision TYPE text USING convert_from(remoteRevision,'utf8');</raw-sql>
0173     <raw-sql backends="psql">ALTER TABLE ResourceTable ALTER name TYPE text USING convert_from(name,'utf8');</raw-sql>
0174   </update>
0175 
0176   <!-- adapt to new part type table layout
0177     (1) perform complex update by populating PartTypeTable and updating partTypeId column in PartTable
0178     (2) drop the old part name column in the part table
0179   -->
0180   <update version="25" abortOnFailure="true">
0181     <complex-update backends="mysql,psql,sqlite" />
0182   </update>
0183 
0184   <update version="26" abortOnFailure="false">
0185     <raw-sql backends="mysql,psql,sqlite">UPDATE CollectionTable SET queryAttributes = 'QUERYLANGUAGE SPARQL' WHERE queryLanguage = 'SPARQL';</raw-sql>
0186     <raw-sql backends="mysql,psql">ALTER TABLE CollectionTable DROP COLUMN queryLanguage;</raw-sql>
0187   </update>
0188 
0189   <update version="28" abortOnFailure="false">
0190     <raw-sql backends="mysql,psql,sqlite">UPDATE CollectionTable SET enabled = subscribed;</raw-sql>
0191     <raw-sql backends="mysql,psql">ALTER TABLE CollectionTable DROP COLUMN subscribed;</raw-sql>
0192   </update>
0193 
0194   <!--
0195    Update 30 fixes missing constraints on relation tables in PostgreSQL.
0196    We cannot just let DbInitializer create the foreign keys there, because data
0197    in the relation tables might reference rows from other tables that no longer
0198    exist.
0199   -->
0200   <update version="30" abortOnFailure="false">
0201     <!-- PimItemFlagRelation -->
0202     <raw-sql backends="psql">DELETE FROM PimItemFlagRelation WHERE pimItem_id IN (
0203                                 SELECT pimItem_id FROM PimItemFlagRelation
0204                                 LEFT JOIN PimItemTable ON PimItemFlagRelation.pimItem_id = PimItemTable.id
0205                                 WHERE PimItemTable.id IS NULL)
0206     </raw-sql>
0207     <raw-sql backends="psql">DELETE FROM PimItemFlagRelation WHERE flag_id IN (
0208                                 SELECT flag_id FROM PimItemFlagRelation
0209                                 LEFT JOIN FlagTable ON PimItemFlagRelation.flag_id = FlagTable.id
0210                                 WHERE FlagTable.id IS NULL)
0211     </raw-sql>
0212     <!-- PimItemTagRelation -->
0213     <raw-sql backends="psql">DELETE FROM PimItemTagRelation WHERE pimItem_id IN (
0214                                 SELECT pimItem_id FROM PimItemTagRelation
0215                                 LEFT JOIN PimItemTable ON PimItemTagRelation.pimItem_id = PimItemTable.id
0216                                 WHERE PimItemTable.id IS NULL)
0217     </raw-sql>
0218     <raw-sql backends="psql">DELETE FROM PimItemTagRelation WHERE tag_id IN (
0219                                 SELECT tag_id FROM PimItemTagRelation
0220                                 LEFT JOIN TagTable ON PimItemTagRelation.tag_id = TagTable.id
0221                                 WHERE TagTable.id IS NULL)
0222     </raw-sql>
0223     <!-- CollectionMimeTypeRelation -->
0224     <raw-sql backends="psql">DELETE FROM CollectionMimeTypeRelation WHERE collection_id IN (
0225                                 SELECT collection_id FROM CollectionMimeTypeRelation
0226                                 LEFT JOIN CollectionTable ON CollectionMimeTypeRelation.collection_id = CollectionTable.id
0227                                 WHERE CollectionTable.id IS NULL)
0228     </raw-sql>
0229     <raw-sql backends="psql">DELETE FROM CollectionMimeTypeRelation WHERE mimeType_id IN (
0230                                 SELECT mimeType_id FROM CollectionMimeTypeRelation
0231                                 LEFT JOIN MimeTypeTable ON CollectionMimeTypeRelation.mimeType_id = MimeTypeTable.id
0232                                 WHERE MimeTypeTable.id IS NULL)
0233     </raw-sql>
0234     <!-- CollectionPimItemRelation -->
0235     <raw-sql backends="psql">DELETE FROM CollectionPimItemRelation WHERE collection_id IN (
0236                                 SELECT collection_id FROM CollectionPimItemRelation
0237                                 LEFT JOIN CollectionTable ON CollectionPimItemRelation.collection_id = CollectionTable.id
0238                                 WHERE CollectionTable.id IS NULL)
0239     </raw-sql>
0240     <raw-sql backends="psql">DELETE FROM CollectionPimItemRelation WHERE pimItem_id IN (
0241                                 SELECT pimItem_id FROM CollectionPimItemRelation
0242                                 LEFT JOIN PimItemTable ON CollectionPimItemRelation.pimItem_id = PimItemTable.id
0243                                 WHERE PimItemTable.id IS NULL)
0244     </raw-sql>
0245   </update>
0246   <!--
0247    Update 31 fixes missing constraints on relation tables in MySQL.
0248    We cannot just let DbInitializer create the foreign keys there, because data
0249    in the relation tables might reference rows from other tables that no longer
0250    exist.
0251   -->
0252   <update version="31" abortOnFailure="false">
0253     <!-- PimItemFlagRelation -->
0254     <raw-sql backends="mysql">DELETE FROM PimItemFlagRelation WHERE pimItem_id IN (
0255                                 SELECT id FROM (
0256                                 SELECT pimItem_id AS id FROM PimItemFlagRelation
0257                                 LEFT JOIN PimItemTable ON PimItemFlagRelation.pimItem_id = PimItemTable.id
0258                                 WHERE PimItemTable.id IS NULL) x)
0259     </raw-sql>
0260     <raw-sql backends="mysql">DELETE FROM PimItemFlagRelation WHERE flag_id IN (
0261                                 SELECT id FROM (
0262                                 SELECT flag_id AS id FROM PimItemFlagRelation
0263                                 LEFT JOIN FlagTable ON PimItemFlagRelation.flag_id = FlagTable.id
0264                                 WHERE FlagTable.id IS NULL) x)
0265     </raw-sql>
0266     <!-- PimItemTagRelation -->
0267     <raw-sql backends="mysql">DELETE FROM PimItemTagRelation WHERE pimItem_id IN (
0268                                 SELECT id FROM (
0269                                 SELECT pimItem_id AS id FROM PimItemTagRelation
0270                                 LEFT JOIN PimItemTable ON PimItemTagRelation.pimItem_id = PimItemTable.id
0271                                 WHERE PimItemTable.id IS NULL) x)
0272     </raw-sql>
0273     <raw-sql backends="mysql">DELETE FROM PimItemTagRelation WHERE tag_id IN (
0274                                 SELECT id FROM (
0275                                 SELECT tag_id AS id FROM PimItemTagRelation
0276                                 LEFT JOIN TagTable ON PimItemTagRelation.tag_id = TagTable.id
0277                                 WHERE TagTable.id IS NULL) x)
0278     </raw-sql>
0279     <!-- CollectionMimeTypeRelation -->
0280     <raw-sql backends="mysql">DELETE FROM CollectionMimeTypeRelation WHERE collection_id IN (
0281                                 SELECT id FROM (
0282                                 SELECT collection_id AS id  FROM CollectionMimeTypeRelation
0283                                 LEFT JOIN CollectionTable ON CollectionMimeTypeRelation.collection_id = CollectionTable.id
0284                                 WHERE CollectionTable.id IS NULL) x)
0285     </raw-sql>
0286     <raw-sql backends="mysql">DELETE FROM CollectionMimeTypeRelation WHERE mimeType_id IN (
0287                                 SELECT id FROM (
0288                                 SELECT mimeType_id AS id FROM CollectionMimeTypeRelation
0289                                 LEFT JOIN MimeTypeTable ON CollectionMimeTypeRelation.mimeType_id = MimeTypeTable.id
0290                                 WHERE MimeTypeTable.id IS NULL) x)
0291     </raw-sql>
0292     <!-- CollectionPimItemRelation -->
0293     <raw-sql backends="mysql">DELETE FROM CollectionPimItemRelation WHERE collection_id IN (
0294                                 SELECT id FROM (
0295                                 SELECT collection_id AS id FROM CollectionPimItemRelation
0296                                 LEFT JOIN CollectionTable ON CollectionPimItemRelation.collection_id = CollectionTable.id
0297                                 WHERE CollectionTable.id IS NULL) x)
0298     </raw-sql>
0299     <raw-sql backends="mysql">DELETE FROM CollectionPimItemRelation WHERE pimItem_id IN (
0300                                 SELECT id FROM (
0301                                 SELECT pimItem_id AS id FROM CollectionPimItemRelation
0302                                 LEFT JOIN PimItemTable ON CollectionPimItemRelation.pimItem_id = PimItemTable.id
0303                                 WHERE PimItemTable.id IS NULL) x)
0304     </raw-sql>
0305   </update>
0306   <update version="33" abortOnFailure="false">
0307     <raw-sql backends="psql">SELECT setval('tagtypetable_id_seq', (SELECT max(id) FROM TagTypeTable))</raw-sql>
0308     <raw-sql backends="psql">SELECT setval('relationtypetable_id_seq', (SELECT max(id) FROM RelationTypeTable))</raw-sql>
0309   </update>
0310 
0311   <update version="35" abortOnFailure="true">
0312     <raw-sql backends="mysql,sqlite">UPDATE PartTable SET storage = external;</raw-sql>
0313     <raw-sql backends="mysql">ALTER TABLE PartTable DROP COLUMN external;</raw-sql>
0314     <!-- TODO: SQLITE: drop the column as well, but SQLite does not have DROP COLUMN //-->
0315     <raw-sql backends="psql">UPDATE PartTable SET storage = cast(external as integer);</raw-sql>
0316     <raw-sql backends="psql">ALTER TABLE PartTable DROP COLUMN external;</raw-sql>
0317   </update>
0318 
0319   <!-- Update 36 introduces foreign key support for SQLite //-->
0320   <update version="36" abortOnFailure="true">
0321     <complex-update backends="sqlite" />
0322   </update>
0323 
0324   <!-- Update 37 fixes TagRemoteIdResourceRelation RIDs being stored a BLOB instead of TEXT,
0325   which broke querying tags by RID if the RID was passed as QString //-->
0326   <update version="37" abortOnFailure="true">
0327     <raw-sql backends="sqlite">UPDATE TagRemoteIdResourceRelationTable SET remoteId = printf('%s', remoteId)</raw-sql>
0328   </update>
0329 
0330   <update version="39" abortOnFailure="false">
0331     <raw-sql backends="mysql">ALTER TABLE TagTable MODIFY COLUMN parentId BIGINT(20);</raw-sql>
0332     <raw-sql backends="psql">ALTER TABLE TagTable ALTER COLUMN parentId DROP DEFAULT;</raw-sql>
0333     <!-- FIXME: SQLite doesn't allow for a straight-forward migration, but this has never reached
0334          a release, so we are mostly OK here. //-->
0335   </update>
0336 
0337   <update version="41" abortOnFailure="true">
0338     <!-- Allow for up to 1024-character long indexes, used for PimItem.remoteId //-->
0339     <raw-sql backends="mysql">ALTER TABLE PimItemTable ROW_FORMAT=DYNAMIC</raw-sql>
0340     <raw-sql backends="mysql">ALTER TABLE PimItemTable MODIFY COLUMN remoteId VARBINARY(1024)</raw-sql>
0341   </update>
0342 </updates>