Squeak.ru - шаблоны программирования

Проблема Rails 4 с таблицами базы данных mysql после обновления с Rails 3.2

Недавно я обновил свое приложение до Rails 4 (с Rails 3.2).

Но кажется, что приложение больше не находит некоторые таблицы mysql, например, таблицу с именем Accidents.

В приложении я нахожу эту ошибку:

Mysql2::Error: Table 'gms.accidents' doesn't exist: SHOW FULL FIELDS FROM `accidents`

Хорошо, похоже, что таблицы больше нет, тогда (видно, что она в режиме разработки и нет проблем сбросить БД), я запускаю в терминале rake db:schema:load, но:

-- create_table("accidents", {:force=>true})
rake aborted!
Mysql2::Error: Tablespace for table '`gms`.`accidents`' exists. Please DISCARD the tablespace before IMPORT.: CREATE TABLE `accidents`
[...]

Что случилось? Таблица не существует, но существует??
Почему приложение больше не находит некоторые таблицы?


  • 3 предложения: 1. Проверьте свой файл config/database.yml и убедитесь, что он содержит правильную информацию о подключении. 2. Изучите данные в инструменте mysql или подсказке и проверьте там что-то. 3. Расскажите нам, какие таблицы ДЕЙСТВИТЕЛЬНО работают? 30.06.2013
  • спасибо @MichaelDurrant за предложения. В обобщении: 1. все в порядке; 2. с помощью инструмента mysql таблица не существует (не знаю почему); 3...; Я вручную удалил базу данных (с rake db:drop не работает...), а затем заново создал другую. Теперь кажется, что работает, но странно, что происходит. 30.06.2013
  • хорошо, тогда я опубликую это как ответ, я тоже это сделал. 30.06.2013

Ответы:


1

Один вариант (не исправление, но может позволить вам двигаться дальше).

Если это просто база данных разработки или локальная база данных, удалите базу данных вручную и обновите таблицу schema_migrations, а затем выполните миграцию rake:db для воссоздания с нуля.

30.06.2013
  • просто примечание: лучше, чем rake db:migrate: 1. rake db:create, 2. rake db:schema:load (так что он загружает непосредственно окончательную версию db, а не все миграции) 30.06.2013
  • Да, это работает и может быть лучшим вариантом во многих случаях. Предостережение: если люди установили обновления данных, а также схему (да, я это вижу), могут возникнуть проблемы. 30.06.2013
  • Новые материалы

    Угловая структура архитектуры
    Обратите внимание, что эта статья устарела, я решил создать новую с лучшей структурой и с учетом автономных компонентов: https://medium.com/@marekpanti/angular-standalone-architecture-b645edd0d54a..

    «Данные, которые большинство людей используют для обучения своих моделей искусственного интеллекта, поставляются со встроенным…
    Первоначально опубликовано HalkTalks: https://hacktown.com.br/blog/blog/os-dados-que-a-maioria-das-pessoas-usa-para-treinar-seus-modelos-de-inteligencia-artificial- ja-vem-com-um-vies-embutido/..

    Сильный ИИ против слабого ИИ: различия парадигм искусственного интеллекта
    В последние годы изучению и развитию искусственного интеллекта (ИИ) уделяется большое внимание и прогресс. Сильный ИИ и Слабый ИИ — две основные парадигмы в области искусственного интеллекта...

    Правильный способ добавить Firebase в ваш проект React с помощью React Hooks
    React + Firebase - это мощная комбинация для быстрого и безопасного создания приложений, от проверки концепции до массового производства. Раньше (знаете, несколько месяцев назад) добавление..

    Создайте API с помощью Python FastAPI
    Создание API с помощью Python становится очень простым при использовании пакета FastAPI. После установки и импорта вы можете создать приложение FastAPI и указать несколько конечных точек. Каждой..

    Веселье с прокси-сервером JavaScript
    Прокси-серверы JavaScript — это чистый сахар, если вы хотите создать некоторую общую логику в своих приложениях, чтобы облегчить себе жизнь. Вот один пример: Связь клиент-сервер Мы..

    Получить бесплатный хостинг для разработчиков | Разместите свой сайт за несколько шагов 🔥
    Статические веб-сайты — это веб-страницы с фиксированным содержанием и его постоянным содержанием. Но теперь статические сайты также обрабатывают динамические данные с помощью API и запросов...