aboutsummaryrefslogtreecommitdiff
path: root/db
diff options
context:
space:
mode:
authorJan-Hendrik Willms <tleilax+studip@gmail.com>2023-03-31 16:38:33 +0000
committerElmar Ludwig <elmar.ludwig@uni-osnabrueck.de>2023-03-31 16:38:33 +0000
commit83dace3cc7bb3819ea3703aaa3dead75be6f72fd (patch)
tree6ebc5fb3f5da72308065f1bada68de5aa0289c96 /db
parent5f672304ede842c789852c8f15198d18c8bbe9e5 (diff)
convert description fields to varchar via migration, fixes #2497
Closes #2497 Merge request studip/studip!1684
Diffstat (limited to 'db')
-rw-r--r--db/migrations/5.1.45_convert_description_columns_to_varchar.php43
1 files changed, 43 insertions, 0 deletions
diff --git a/db/migrations/5.1.45_convert_description_columns_to_varchar.php b/db/migrations/5.1.45_convert_description_columns_to_varchar.php
new file mode 100644
index 0000000..6c7d9a0
--- /dev/null
+++ b/db/migrations/5.1.45_convert_description_columns_to_varchar.php
@@ -0,0 +1,43 @@
+<?php
+
+/**
+ * @see https://gitlab.studip.de/studip/studip/-/issues/2497
+ */
+final class ConvertDescriptionColumnsToVarchar extends Migration
+{
+ public function description()
+ {
+ return 'Convert the `description` columns in tables `termine`, `ex_termine`and `semester_data` to VARCHAR.';
+
+ }
+
+ protected function up()
+ {
+ $query = "ALTER TABLE `termine`
+ CHANGE COLUMN `description` `description` VARCHAR(255) DEFAULT NULL";
+ DBManager::get()->exec($query);
+
+ $query = "ALTER TABLE `ex_termine`
+ CHANGE COLUMN `description` `description` VARCHAR(255) DEFAULT NULL";
+ DBManager::get()->exec($query);
+
+ $query = "ALTER TABLE `semester_data`
+ CHANGE COLUMN `description` `description` VARCHAR(255) NOT NULL DEFAULT ''";
+ DBManager::get()->exec($query);
+ }
+
+ protected function down()
+ {
+ $query = "ALTER TABLE `semester_data`
+ CHANGE COLUMN `description` `description` TEXT NOT NULL";
+ DBManager::get()->exec($query);
+
+ $query = "ALTER TABLE `ex_termine`
+ CHANGE COLUMN `description` `description` TEXT DEFAULT NULL";
+ DBManager::get()->exec($query);
+
+ $query = "ALTER TABLE `termine`
+ CHANGE COLUMN `description` `description` TEXT DEFAULT NULL";
+ DBManager::get()->exec($query);
+ }
+}