set-up-and-configure-postgresql-o
全部标签 Rails新应用。当前的database.yml是这样的:#SQLiteversion3.x#geminstallsqlite3##EnsuretheSQLite3gemisdefinedinyourGemfile#gem'sqlite3'development:adapter:sqlite3database:db/development.sqlite3pool:5timeout:5000#Warning:Thedatabasedefinedas"test"willbeerasedand#re-generatedfromyourdevelopmentdatabasewhenyourun
例如,我使用“Bonus”作为我的模型,所以我希望“bonuses”是复数形式而“bonus”是单数形式。但是,在Ruby中,这会导致:"bonus".pluralize#bonus"bonuses".singularize#bonuse因此,例如,当我执行“has_many:bonuses”时,它不会使用Bonus.rb模型(因为Ruby需要Bonuse.rb模型)。有没有一种方法可以在RubyonRails中以某种方式更正这一点,使“bonuses”充当模型bonus.rb的复数形式? 最佳答案 在config/initiali
我正在将我的开发环境从sqlite3切换到postgresql8.4,还有最后一个障碍。在我原来的帮助方法中有以下行;result=Users.find(:all,:order=>"namecollateNOCASE")它提供了一个非常好的不区分大小写的搜索。我不能为postgresql复制这个。应该很简单-有什么想法吗?谢谢。 最佳答案 result=Users.find(:all,:order=>"LOWER(name)")向Brad和Frank学习一点。 关于ruby-on-rai
我使用PostgreSQL数据库在Heroku上的Rails中创建了一个应用程序。它有几个表,旨在能够与移动设备同步,在这些设备上可以在不同的地方创建数据。因此,我有一个uuid字段,它是一个存储GUID以及自动递增主键的字符串。uuid是在服务器和客户端之间通信的。我在服务器端实现同步引擎后意识到,当需要一直在uuidid之间映射时,这会导致性能问题(在编写对象时,我需要先查询uuid以获取id保存和发回数据时相反)。我现在正在考虑切换到仅使用UUID作为主键,从而使写入和读取变得更加简单和快速。我读到UUID作为主键有时会在使用聚簇主键索引时导致糟糕的索引性能(索引碎片)。Post
我的应用程序使用Heroku,它需要PostgreSQL,但您仍然可以使用SQLite3进行开发。由于Heroku强烈建议不要使用2个不同的数据库,因此我决定改用PostgreSQL进行开发。我安装了gempg,还去了官方PostgreSQL站点获取Windows安装程序,还更改了我的database.yml。在安装过程中,它需要PostgreSQL的密码,所以我做了一个。我必须将pg_hba.conf文件从使用md5更改为trust才能通过:fe_sendauth:nopasswordsupplied尝试创建数据库时。#TYPEDATABASEUSERADDRESSMETHOD#IP
运行RubyonRails(RoR)应用程序或使用ActiveRecord框架的Ruby代码,您会收到错误消息:Pleaseinstallthepostgresqladapter:geminstallactiverecord-postgresql-adapter尝试运行:geminstallactiverecord-postgresql-adapter也失败了,让你不知所措。 最佳答案 问题不是任何人写的。问题是postgresql数据库适配器的名称是“postgresql”,而不是“postgres”,尽管GEM的名称是“pg”。
我使用Ruby1.9.2和Rails3.0.5我有以下错误:incompatiblecharacterencodings:ASCII-8BITandUTF-8我认为这与数据库无关。错误发生在View中的这一行(只是一个divhaml调用):#content全栈:ActionView::Template::Error(incompatiblecharacterencodings:ASCII-8BITandUTF-8):21:-flash.eachdo|name,msg|22:=content_tag:div,msg,:id=>"flash_#{name}"23:%div.clear24:
我目前在Ubuntu12.04中通过RVM安装了RubyonRails。默认数据库是在SQLite3中设置的,但为了推送到Heroku,我想切换到PostgreSQL。我怎样才能做到这一点? 最佳答案 以下是我遵循的步骤:安装PostgreSQL和开发包$sudoapt-getinstallpostgresql$sudoapt-getinstalllibpq-dev设置一个与我的Ubuntu登录相同的用户$sudosupostgres-cpsqlpostgres=#CREATEROLESUPERUSERLOGIN;postgres=
我有一个要验证的字段。我希望该字段能够留空,但如果用户正在输入数据,我希望它采用某种格式。目前我在模型中使用以下验证,但这不允许用户将其留空:validates_length_of:foo,:maximum=>5validates_length_of:foo,:minimum=>5如何编写此代码以实现我的目标? 最佳答案 你也可以使用这种格式:validates:foo,length:{minimum:5,maximum:5},allow_blank:true或者因为您的最小值和最大值相同,以下也将起作用:validates:foo
我正在寻找一种将参数传递给Chef食谱的方法,例如:$vagrantupsome_parameter然后在其中一本Chef食谱中使用some_parameter。 最佳答案 您不能将任何参数传递给vagrant。唯一的办法就是使用环境变量MY_VAR='myvalue'vagrantup并在配方中使用ENV['MY_VAR']。 关于ruby-如何在'vagrantup'上传递参数并将其置于Vagrantfile的范围内?,我们在StackOverflow上找到一个类似的问题: