I was making a web app to deploy using Heroku.com when I realized that the only database type they support is PostgreSQL. Up until now, my app (powered by the Ruby gem Sinatra) accessed the database via the .Sqlite method for the Sequel gem.
Here’s my Ruby script from when I used Sequel to access the .db file via SQLite:
DB = Sequel.sqlite('mydatabase.db')
DB.create_table :mytable do
primary_key :id
String :column_name
end
I installed PostgreSQL after learning Heroku used only that. Here’s the script via postgres (my username is literally ‘postgress’, though I obviously won’t reveal my password in this question):
DB = Sequel.postgres('mydatabase.db',:user=>'postgres',:password=>'my_password_here',:host=>'localhost',:port=>5432,:max_connections=>10)
DB.create_table :mytable do
primary_key :id
String :column_name
end
However, when I run this code, I get the following error:
C:/Ruby193/lib/ruby/gems/1.9.1/gems/sequel-3.38.0/lib/sequel/adapters/postgres.rb:208:in 'initialize': PG::Error: FATAL: database "mydatabase.db" does not exist (Sequel::DatabaseConnectionError)
I’ve tried searching Google, StackOverflow, Sequel documents, and the Heroku help documents for any help, but I’ve found no fix to this problem.
Does anyone know what I am doing wrong?
The database
mydatabase.dbdoesn’t exist, as per the error message from Pg. Likely reasons:mydatabasewithout the SQLite-specific.dbfilename suffix"Mydatabase.db";If in doubt, connect to Pg with
psqland run\lto list databases, or connect via PgAdmin-III.The PostgreSQL documentation and tutorial are highly recommended, too. They’re well written and will teach you a lot about SQL in general as well as Pg in particular.
BTW, the
postgresuser is a superuser. You should not be using it for your application; it’s like running your server as root, ie a really bad idea. Create a new PostgreSQL user without superuser, createdb or createuser rights and use that for your application. You can eitherCREATE DATABASE somedb WITH OWNER myappuser– or preferably, create the database owned by a different user to your webapp user and then expicitlyGRANTthe webapp user the minimum required permissions. See user management and GRANT.