如何将mysql数据库文件连接到Rails应用程序上的本地ruby
我有一个数据库文件(name.sql)发送给我,我应该连接到Mac本地托管的Rails应用程序,该应用程序是我从github下载的(分叉的?).如何设置我的database.yml文件以与sql文件连接.
解决方法:
您不能将Rails应用程序直接连接到SQL文件. Rails应用程序从数据库服务器获取其数据,然后将SQL文件的内容导入到服务器托管的数据库中.
您可以从http://dev.mysql.com/downloads/mysql/#downloads下载DMG存档,该存档将在Mac上安装MySQL Community Server
该下载内容还包括一个方便的“首选项窗格”,用于启动和停止服务器.
一旦MySQL启动并运行,则应使用以下命令为root用户(即数据库系统管理员)设置密码:
mysqladmin -u root password "secret"
—显然用您要使用的真实密码替换secret.
然后,您可以为Rails应用程序设置database.yml文件.对于名为app的应用程序,它将如下所示:
development:
adapter: mysql
database: app_development
username: root
password: secret
host: localhost
test:
adapter: mysql
database: app_test
username: root
password: secret
host: localhost
production:
adapter: mysql
database: app_production
username: root
password: secret
host: localhost
请注意,通常在生产中,您将为Rails应用程序创建一个单独的受限特权数据库用户帐户,以用于与MySQL连接,但是对于在本地计算机上进行开发,root帐户是可以的.
完成此步骤后,您可以从终端中的Rails应用程序的根目录运行rake db:create.该命令将在MySQL中创建app_development数据库(rake db:create:all也会创建测试数据库和生产数据库).最后,您可以通过在终端中输入以下命令来导入SQL文件:
mysql -u root -p app_development < path/to/file/name.sql
系统将提示您输入MySQL根密码.如果该路径不在SQL Server的当前目录中,请用SQL文件的完整路径替换path / to / file.例如,如果?/ Desktop / name.sql在桌面上,则使用它.