jjzjj

pg_attribute

全部标签

ruby-on-rails - 在 Rails 中,update_attributes 的倒数是什么?

在Rails中,update_attributes!的逆运算是什么?换句话说,是什么将记录映射到属性散列以重新创建该记录及其所有子记录?答案不是ActiveRecord.attributes,因为它不会递归到子对象中。澄清您是否有以下情况:classFoo然后你可以像这样传递一个散列{"name"=>"afoo","bars_attributes"=>[{"name"=>"abar}...]}到update_attributes。但目前尚不清楚如何为此目的以编程方式轻松生成这样的哈希值。编辑:正如我在评论中提到的,我可以做类似的事情:foo.as_json(:include=>:bar

ruby-on-rails - RSpec:如何测试使用并行的方法(PG::ConnectionBad 错误)

在我的应用程序中,我有几个生成器类,它们负责获取从外部API请求接收的数据,并将资源构建/保存到数据库中。我正在处理大量数据,并已实现并行gem以通过使用多个进程来加快处理速度。但是,我发现对使用Parallel的方法的任何测试都会失败并出现相同的错误:ActiveRecord::StatementInvalid:PG::ConnectionBad:PQconsumeInput()serverclosedtheconnectionunexpectedlyThisprobablymeanstheserverterminatedabnormallybeforeorwhileprocessi

ruby-on-rails - 在 Rails 中使用 accepts_nested_attributes_for + 批量赋值保护

假设你有这个结构:classHouse请注意,Tv的用户是故意不可访问的。所以你有一个三层嵌套的表单,允许你在一个页面上输入房子、房间和电视。这是Controller的创建方法:defcreate@house=House.new(params[:house])if@house.save#...standardstuffelse#...standardstuffendend问题:您究竟如何为每台电视填充user_id(它应该来自current_user.id)?什么是好的做法?这是我在其中看到的catch22。将user_ids直接填充到params散列中(它们嵌套得很深)保存将失败,因

ruby - 如何使用 PG Ruby Gem 有条件地回滚事务

我目前正在上一门数据库类(class),其中一个实验室问题让我困惑于如何实现上述内容,事实上,如果可能的话。我试过搜索docs但是定义的交易方式比较模糊。这是我第一次尝试在没有Rails的情况下进行任何数据库操作,所以我有点迷茫。我已经成功地创建了一个到我的postgresql数据库的连接并且可以执行语句,我需要做的最后一件事是根据一个简单的条件回滚一个事务。请允许我向您展示代码:require'pg'@conn=PG::Connection.open(:dbname=>'db_15_11_labs')@conn.prepare('insert','INSERTINTOhouse(ho

ruby - Rails+ActiveAdmin - 使用 ransacker 过滤会抛出错误 PG::SyntaxError: ERROR: syntax error at or near ","

我在RubyonRails4.1.4上有一个项目,使用来自git://github.com/activeadmin/activeadmin的activeadmin1.0.0.pre,pg0.17.1,PostgreSQL9.3在项目中我有这些模型:类用户has_one:账户类账户属于:用户有很多:project_accountshas_many:项目,:through=>:project_accounts类项目#该项目有一个bool属性'archive'has_many:project_accounts类ProjectAccount属于:帐户属于:项目我有一个任务是在索引页面上实现一个

ruby - pg: exec_params 不替换参数?

第一次使用pggem访问postgres数据库。我已成功连接并可以使用#exec运行查询,但现在使用#exec_params构建一个简单的查询似乎没有替换参数。即:get'/databases/:db/tables/:table'do|db_name,table_name|conn=connect(db_name)query_result=conn.exec_params("SELECT*FROM$1;",[table_name])end结果为#这似乎是一个非常简单的示例-我是否从根本上误解了如何使用此方法? 最佳答案 您可以将占位

ruby-on-rails - PG::DependentObjectsStillExist:使用 rspec 时出错

当我运行时$rspec"/any_file"rspec加载schema.rb文件以设置数据库。我的理解是说到这一行create_table"queue_classic_jobs",force:truedo|t|;endRspec运行一个DROPTABLE"queue_classic_jobs"命令。它抛出了这个错误PG::DependentObjectsStillExist:ERROR:cannotdroptablequeue_classic_jobsbecauseotherobjectsdependonit(ActiveRecord::StatementInvalid)DETAIL:

ruby-on-rails - PG::UndefinedTable - 错误:关系 "active_storage_attachments"不存在

我刚刚为产品和购物车创建了一个简单的应用程序,其中包含名称、价格和附件。它工作正常,没有任何问题。我决定分别使用rails-admingem和devise创建管理和身份验证。我已按照说明进行操作here.在我到达rails_admin部分之前,一切都很好。除了使用github页面上描述的rails_admin1.3版本外,我按照描述做了所有事情。我也在链接上尝试了旧版本,但每次都遇到这个错误PG::UndefinedTable-ERROR:relation"active_storage_attachments"doesnotexistLINE8:WHEREa.attrelid='"ac

ruby - self.attribute 与 @attribute 的优势?

假设如下:defcreate_new_saltself.salt=self.object_id.to_s+rand.to_send为什么使用“self”更好。而不是实例变量“@salt”? 最佳答案 如果已定义,使用self.salt=将导致使用salt=方法。这对于确保使用salt=方法内的任何错误检查/转换很有用。然而,这意味着必须有一个明确的salt=方法(例如,可能由attr_accessor创建),这不一定是个好主意。总结:如果你有一个自定义的salt=方法,使用self.salt=;使用@salt=如果你确切地知道你想要

ruby-pg 在插入之前清理数据

这里是Ruby新手。我正在尝试插入此字符串“LadyArabella'sScandalo...”我正在使用ruby​​-pg来执行此操作。但是由于单引号我有错误,我怎样才能清理这个字符串并删除所有html标签?是否有内置函数? 最佳答案 您可以使用escape_string正确转义你的单引号:db=PG.connect(...)db.exec("insertintot(...)values('#{db.escape_string(str)}',...)")或使用prepare和exec_prepared改为使用准备好的语句:db.p