2017-10-06 02:56:06 +04:00
|
|
|
|
// i2_bot – Instinct PokememBro Bot
|
|
|
|
|
// Copyright (c) 2017 Vladimir "fat0troll" Hodakov
|
|
|
|
|
|
|
|
|
|
package migrations
|
|
|
|
|
|
|
|
|
|
import (
|
2017-10-18 07:03:34 +04:00
|
|
|
|
"database/sql"
|
2017-10-06 02:56:06 +04:00
|
|
|
|
)
|
|
|
|
|
|
2017-11-14 03:44:21 +04:00
|
|
|
|
// CreateLocationsUp creates `locations` table and fills it with data
|
2017-10-06 02:56:06 +04:00
|
|
|
|
func CreateLocationsUp(tx *sql.Tx) error {
|
2017-11-14 03:44:21 +04:00
|
|
|
|
request := "CREATE TABLE `locations` ("
|
|
|
|
|
request += "`id` int(11) NOT NULL AUTO_INCREMENT COMMENT 'ID локации',"
|
|
|
|
|
request += "`symbol` varchar(191) COLLATE 'utf8mb4_unicode_520_ci' NOT NULL COMMENT 'Символ локации',"
|
|
|
|
|
request += "`name` varchar(191) NOT NULL COMMENT 'Имя локации',"
|
|
|
|
|
request += "`created_at` datetime NOT NULL COMMENT 'Добавлена в базу',"
|
|
|
|
|
request += "PRIMARY KEY (`id`),"
|
|
|
|
|
request += "UNIQUE KEY `id` (`id`),"
|
|
|
|
|
request += "KEY `locations_created_at` (`created_at`)"
|
|
|
|
|
request += ") ENGINE=InnoDB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8mb4 COMMENT='Локации';"
|
|
|
|
|
_, err := tx.Exec(request)
|
2017-10-18 07:03:34 +04:00
|
|
|
|
if err != nil {
|
|
|
|
|
return err
|
|
|
|
|
}
|
2017-10-06 02:56:06 +04:00
|
|
|
|
|
2017-10-18 07:03:34 +04:00
|
|
|
|
// Insert locations
|
2018-03-31 08:34:27 +04:00
|
|
|
|
_, err = tx.Exec("INSERT INTO `locations` VALUES(NULL, ':evergreen_tree:', 'Лес', NOW());")
|
|
|
|
|
if err != nil {
|
|
|
|
|
return err
|
2017-10-18 07:03:34 +04:00
|
|
|
|
}
|
2018-03-31 08:34:27 +04:00
|
|
|
|
_, err = tx.Exec("INSERT INTO `locations` VALUES(NULL, '⛰', 'Горы', NOW());")
|
|
|
|
|
if err != nil {
|
|
|
|
|
return err
|
2017-10-18 07:03:34 +04:00
|
|
|
|
}
|
2018-03-31 08:34:27 +04:00
|
|
|
|
_, err = tx.Exec("INSERT INTO `locations` VALUES(NULL, ':rowboat:', 'Озеро', NOW());")
|
|
|
|
|
if err != nil {
|
|
|
|
|
return err
|
2017-10-18 07:03:34 +04:00
|
|
|
|
}
|
2018-03-31 08:34:27 +04:00
|
|
|
|
_, err = tx.Exec("INSERT INTO `locations` VALUES(NULL, '🏙', 'Город', NOW());")
|
|
|
|
|
if err != nil {
|
|
|
|
|
return err
|
2017-10-18 07:03:34 +04:00
|
|
|
|
}
|
2018-03-31 08:34:27 +04:00
|
|
|
|
_, err = tx.Exec("INSERT INTO `locations` VALUES(NULL, '🏛', 'Катакомбы', NOW());")
|
|
|
|
|
if err != nil {
|
|
|
|
|
return err
|
2017-10-18 07:03:34 +04:00
|
|
|
|
}
|
2018-03-31 08:34:27 +04:00
|
|
|
|
_, err = tx.Exec("INSERT INTO `locations` VALUES(NULL, ':church:', 'Кладбище', NOW());")
|
|
|
|
|
if err != nil {
|
|
|
|
|
return err
|
2017-10-18 07:03:34 +04:00
|
|
|
|
}
|
2017-10-06 02:56:06 +04:00
|
|
|
|
|
2017-10-18 07:03:34 +04:00
|
|
|
|
return nil
|
2017-10-06 02:56:06 +04:00
|
|
|
|
}
|
|
|
|
|
|
2017-11-14 03:44:21 +04:00
|
|
|
|
// CreateLocationsDown drops `locations` table
|
2017-10-06 02:56:06 +04:00
|
|
|
|
func CreateLocationsDown(tx *sql.Tx) error {
|
2017-10-18 07:03:34 +04:00
|
|
|
|
_, err := tx.Exec("DROP TABLE `locations`;")
|
|
|
|
|
if err != nil {
|
|
|
|
|
return err
|
|
|
|
|
}
|
|
|
|
|
return nil
|
2017-10-06 02:56:06 +04:00
|
|
|
|
}
|