草庐IT

PostgresQL

全部标签

ruby-on-rails - Rails 验证数组中的值

在我的Schedule模型中,我想向:wdays字段添加一些验证,它是一个int[]。我只希望值0..6有效有效Schedule.wdays=[0,1,6]无效Schedule.wdays=[0,1,10]我试过用validates:wdays,inclusion:{in:[0,1,2,3,4,5,6]}和validates:wdays,inclusion:{in:0..6}但都不行在您的模型中验证数组中的值的正确方法是什么? 最佳答案 我不认为默认的Rails验证器可以解决这个问题,不过您可以这样做:validate:valida

ruby-on-rails - 错误 : must be owner of language plpgsql

我正在使用PostgreSQLv9.0.1和Rails(它是deps)@v2.3.8,由于使用了postgres的全文能力,我有一个定义为的表:CREATETABLEaffiliate_products(idintegerNOTNULL,namecharactervarying(255),modelcharactervarying(255),descriptiontext,pricenumeric(9,2),created_attimestampwithouttimezone,updated_attimestampwithouttimezone,textsearch_vectortsv

ruby-on-rails - Rails 控制台 - 查找在某天创建的位置

使用RubyonRails控制台,是否可以查询数据库中某一天创建的所有记录?有点像date="january52013"users=User.find(:all,:conditions=>{:created_at=>date}) 最佳答案 你可以这样做:date=Date.parse('january52013')users=User.where(created_at:date.midnight..date.end_of_day) 关于ruby-on-rails-Rails控制台-查找在

ruby - gem install pg 无法绑定(bind)到 libpq

在Ubuntu10.04.3上升级到Ruby1.9.3(从1.9.2使用系统RVM)后,我删除了所有的gem,并尝试重新安装pg(alabundleinstallpg).然后它抛出一个错误并通知我应该查看mkmf.log,这两个都包含在这个要点中:https://gist.github.com/d05a81701d968895c730libpq-dev、libpq5和postgresql-client都已安装并正常工作。将gem指向pg_config,直接包含和bin目录似乎没有任何改变。我在stackoverflow和网络的其余部分看到了几个关于类似错误消息的问题,但它们似乎都是简单

ruby-on-rails - 简单的 Rails 应用程序 : Error Cannot visit Integer

我正在尝试构建一个简单的Rails应用程序。Railsv3.2.22.5(这是一项要求)。我用PostgreSQL运行它。然而,当我启动服务器时,当我尝试从数据库中读取一个简单的帖子时出现以下错误。CannotvisitInteger跟踪将我带到下面的显示方法。更具体到第二行。我是Rails的新手,完全不知道如何解决这个问题。搜索网络已经没有成功。欢迎提出任何想法。defshow@post=Post.find(params[:id])respond_todo|format|format.html#show.html.erbformat.json{renderjson:@post}end

ruby - Ruby 中 DateTime 的毫秒分辨率

我有一个类似2012-01-01T01:02:03.456的字符串,我使用ActiveRecord将其存储在Postgres数据库TIMESTAMP中。不幸的是,Ruby似乎切断了毫秒数:ruby-1.9.3-rc1:078>'2012-12-31T01:01:01.232323+3'.to_datetime=>Mon,31Dec201201:01:01+0300Postgrs支持微秒分辨率。如何相应地保存我的时间戳?我至少需要毫秒分辨率。(PS是的,我可以破解postgres中的毫秒整数列;这违背了ActiveRecord的全部目的。)更新:非常有帮助的回复表明Ruby的DateTi

ruby - 从 ActiveRecord 原始 SQL 获取类型化结果

在Sequel中,我可以做到:irb(main):003:0>DB["selectfalse"].get=>false返回一个错误的bool值。我希望能够在ActiveRecord中做类似的事情:irb(main):007:0>ActiveRecord::Base.connection.select_value"selectfalse"=>"f"如您所见,它返回字符串"f"。有没有办法用ActiveRecord得到一个错误的bool值?(类似地,我可能正在调用一个返回timestamptz、数组等的函数——我希望返回的值具有正确的类型)我的用例:我正在调用一个数据库函数,想要返回一个键

sql - GROUP BY 和 COUNT 使用 ActiveRecord

引用这个:IsthereanydifferencebetweenGROUPBYandDISTINCTGivenatablethatlookslikethis:name------barrydavebilldavedavebarryjohnThisquery:SELECTname,count(*)AScountFROMtableGROUPBYname;Willproduceoutputlikethis:namecount-------------barry2dave3bill1john1对于ActiveModel使用COUNT执行GROUPBY的正确Rails约定是什么?

ruby-on-rails - 尝试为 ror 应用程序设置 postgres,出现错误 - fe_sendauth : no password supplied

获得:Anerrorhasoccurred:Errorconnectingtotheserver:fe_sendauth:nopasswordsupplieddatabase.yml中的设置与其他机器上的应用设置相同。我如何设置才能不需要硬编码密码?我可以使用PgAdmin-III查看数据库。我宁愿不要在database.yml中设置密码,因为使用此应用程序的其他机器没有/不需要密码,所以这似乎与我的Pg安装有关。 最佳答案 您需要更改您的pg_hba.conf。这是我的一个例子:pg_hba.conf:TYPEDATABASEUS

ruby-on-rails - PostgreSQL gem pg 无法安装

我的数据库是PostgreSQL。我在CENTOS上...。在安装pggem时,我收到以下错误。我也重新安装以清除我的YAML问题,但没有用,但这只是一个警告。我的主要问题是pggem的安装:[root@vdimc04~]#geminstallpg/usr/local/lib/ruby/1.9.1/yaml.rb:56:in`':Itseemsyourrubyinstallationismissingpsych(forYAMLoutput).Toeliminatethiswarning,pleaseinstalllibyamlandreinstallyourruby.Buildingn