db-patch-mysql-utf8.sh 1.0 KB

123456789101112131415161718192021222324252627
  1. #!/bin/bash
  2. db_name=$1
  3. echo -n "Enter password:"
  4. read db_pass
  5. C_TABLES=$(mysql -u root -p ${db_name} --password=${db_pass} -B -N -e "SHOW TABLES")
  6. echo "Stage 1. CHange charset for tables"
  7. echo "${C_TABLES}" | awk '{print "SET foreign_key_checks = 0; ALTER TABLE", $1, "CONVERT TO CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci; SET foreign_key_checks = 1; "}' >migration_utf8
  8. echo "ALTER DATABASE ${db_name} CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci;">>migration_utf8
  9. mysql -u root -p ${db_name} --password=${db_pass} < migration_utf8
  10. echo "Stage 1 - Done"
  11. >migration_utf8
  12. echo "Stage 2. Revert filed type to TEXT"
  13. echo "${C_TABLES}" | while read table; do
  14. mysql -u root -p ${db_name} --password=${db_pass} -e "show create table ${table}" | sed 's/\\n/\n/g' | egrep -i "[[:space:]]MEDIUMTEXT[[:space:]]" | awk '{ print $1 }' | while read c_field; do
  15. echo "ALTER TABLE $table MODIFY $c_field TEXT;" >>migration_utf8
  16. done
  17. done
  18. mysql -u root -p ${db_name} --password=${db_pass} < migration_utf8
  19. echo "Stage2 - Done"
  20. rm -f migration_utf8
  21. exit