2.2.17.js 1.6 KB

12345678910111213141516171819202122232425262728293031323334
  1. const _ = require('lodash')
  2. /* global WIKI */
  3. exports.up = async knex => {
  4. let sqlVersionDate = ''
  5. switch (WIKI.config.db.type) {
  6. case 'postgres':
  7. case 'mssql':
  8. sqlVersionDate = 'UPDATE "pageHistory" h1 SET "versionDate" = COALESCE((SELECT prev."createdAt" FROM "pageHistory" prev WHERE prev."pageId" = h1."pageId" AND prev.id < h1.id ORDER BY prev.id DESC LIMIT 1), h1."createdAt")'
  9. break
  10. case 'mysql':
  11. // -> Fix for 2.2.50 failed migration
  12. const pageHistoryColumns = await knex.schema.raw('SHOW COLUMNS FROM pageHistory')
  13. if (_.some(pageHistoryColumns[0], ['Field', 'versionDate'])) {
  14. console.info('MySQL 2.2.50 Migration Fix - Dropping failed versionDate column...')
  15. await knex.schema.raw('ALTER TABLE pageHistory DROP COLUMN versionDate')
  16. console.info('versionDate column dropped successfully.')
  17. }
  18. sqlVersionDate = `UPDATE pageHistory AS h1 INNER JOIN pageHistory AS h2 ON h2.id = (SELECT prev.id FROM (SELECT * FROM pageHistory) AS prev WHERE prev.pageId = h1.pageId AND prev.id < h1.id ORDER BY prev.id DESC LIMIT 1) SET h1.versionDate = h2.createdAt`
  19. break
  20. case 'mariadb':
  21. sqlVersionDate = `UPDATE pageHistory AS h1 INNER JOIN pageHistory AS h2 ON h2.id = (SELECT prev.id FROM pageHistory AS prev WHERE prev.pageId = h1.pageId AND prev.id < h1.id ORDER BY prev.id DESC LIMIT 1) SET h1.versionDate = h2.createdAt`
  22. break
  23. }
  24. await knex.schema
  25. .alterTable('pageHistory', table => {
  26. table.string('versionDate').notNullable().defaultTo('')
  27. })
  28. .raw(sqlVersionDate)
  29. }
  30. exports.down = knex => { }