Шаги ниже работали для меня. Он использует камень taps , созданный Heroku и упомянутый в Railscast # 342 Райана Бейтса. Есть несколько шагов, но они работали отлично (даже даты были перенесены правильно), и это было намного проще, чем миграции Oracle -> DB2 или SQL Server -> Oracle, которые я делал в прошлом.
Обратите внимание, что SQLite не имеет идентификатора пользователя или пароля, но гем taps требует чего-то. Я просто использовал литералы «пользователь» и «пароль».
Создание пользователя базы данных Postgres для новых баз данных
$ createuser f3
Shall the new role be a superuser? (y/n) n
Shall the new role be allowed to create databases? (y/n) y
Shall the new role be allowed to create more new roles? (y/n) y
РЕДАКТИРОВАТЬ - обновленная команда ниже - используйте вместо этого
$ createuser f3 -d -s
Создание необходимых баз данных
$ createdb -Of3 -Eutf8 f3_development
$ createdb -Of3 -Eutf8 f3_test
Обновление Gemfile
gem 'sqlite3'
gem 'pg'
gem 'taps'
$ bundle
Обновление database.yml
#development:
# adapter: sqlite3
# database: db/development.sqlite3
# pool: 5
# timeout: 5000
development:
adapter: postgresql
encoding: unicode
database: f3_development
pool: 5
username: f3
password:
#test:
# adapter: sqlite3
# database: db/test.sqlite3
# pool: 5
# timeout: 5000
test:
adapter: postgresql
encoding: unicode
database: f3_test
pool: 5
username: f3
password:
Запустить сервер taps в базе данных sqlite
$ taps server sqlite://db/development.sqlite3 user password
Перенос данных
$ taps pull postgres://f3@localhost/f3_development http://user:password@localhost:5000
Перезапустите веб-сервер Rails
$ rails s
Очистить Gemfile
#gem 'sqlite3'
gem 'pg'
#gem 'taps'
$ bundle