jjzjj

sql-update

全部标签

sql - Arel中 "where exists"怎么办

如何在Arel中执行包含“whereexists”的查询?例如,在这样的查询中显示至少有一个订单的所有供应商:SELECT*FROMsuppliersWHEREEXISTS(SELECT*FROMordersWHEREsuppliers.supplier_id=orders.supplier_id);我在Arel文档中看到“存在”http://rubydoc.info/gems/arel/2.0.7/Arel/Nodes/Exists但我在使用它时遇到了问题。 最佳答案 给你:suppliers=Supplier.arel_tabl

ruby - 有没有办法查看 Sequel 表达式将生成的原始 SQL?

假设我有一个像这样的Sequel表达式:db.select(:id).from(:some_table).where(:foo=>5)有没有办法获取这将生成的SQL字符串(即"SELECTidFROMsome_tableWHEREfoo=5")?我注意到对上述表达式的结果调用inspect或to_s包括生成的SQL,但不确定如何直接访问它。以及不返回数据集的Sequel表达式如何,例如:db.from(:some_table).update(:foo=>5)是否可以在执行之前从中看到SQL? 最佳答案 你可以在数据集上调用sql:d

ruby-on-rails - 在 Rails 3 中使用 update_columns?

在Rails3中有更短的方法吗?user.update_column(:attribute1,value1)user.update_column(:attribute2,value2)user.update_column(:attribute3,value3)user.update_column(:attribute4,value4)我试过update_columns但它只在Rails4中可用。感谢您的帮助。 最佳答案 这是Rails3.x的解决方法:User.where(id:user.id).update_all(attribu

ruby-on-rails - 数组上的 rails where() sql 查询

我会尽可能详细地解释这一点。我对用户帖子有疑问:@selected_posts=Posts.where(:category=>"棒球")我想写下面的语句。这是伪术语:User.where(用户在@selected_posts中有帖子)请记住,我设置了多对多关系,因此post.user可用。有什么想法吗?/编辑@posts_matches=User.includes(@selected_posts).map{|user|[user.company_name,user.posts.count,user.username]}.sort基本上,我需要上面的工作,以便它使用在selected_p

ruby-on-rails - Rails 5 SQL 注入(inject)

我已经在各种SO线程、指南等上阅读了一段时间...但所有答案都是相互矛盾和矛盾的。好像有很多类似的方法,而且很多答案都说使用不同的方法。清理sanitize_conditionssanitize_sqlsanitize_sql_arraysanitize_sql_for_assignmentsanitize_sql_for_conditionssanitize_sql_hashsanitize_sql_hash_for_assignmentsanitize_sql_hash_for_conditionssanitize_sql_like我正在尝试编写一个“原始查询”适配器,让我可以运行

sql - 在 ActiveRecord 中存储序列化哈希与键/值数据库对象的优缺点?

如果我有几个对象,每个对象基本上都有一个Profile,我用什么来存储随机属性,有什么优缺点:在记录列中存储序列化哈希,对比存储一组属于主对象的键/值对象。代码假设您有这样的STI记录:classBuilding:profilableendclassOfficeBuilding每个has_one:profile选项1.序列化哈希classSerializedProfiletruedo|t|t.string:namet.string:websitet.string:emailt.string:phonet.string:typet.text:settingst.integer:profi

sql - 如何使用 ActiveRecord 模型在日期范围内进行搜索?

我是Ruby和ActiveRecord的新手。我目前需要修改现有的一段代码以在选择中添加日期范围。当前的作品是这样的:ReportsThirdparty.find(:all,:conditions=>{:site_id=>site_id,:campaign_id=>campaign_id,:size_id=>size_id})现在,我需要添加一个范围,但我不确定如何做BETWEEN或>=或运营商。我想我需要的是类似于:ReportsThirdparty.find(:all,:conditions=>{:site_id=>site_id,:campaign_id=>campaign_id

sql - 使用 SQL IN 和 SQL OR 运算符的 Rails 3 ActiveRecord 查询

我正在使用“where”语法编写一个Rails3ActiveRecord查询,它同时使用了SQLIN和SQLOR运算符,但不知道如何同时使用它们。此代码有效(在我的用户模型中):Question.where(:user_id=>self.friends.ids)#note:self.friends.idsreturnsanarrayofintegers但是这段代码Question.where(:user_id=>self.friends.idsOR:target=>self.friends.usernames)返回这个错误syntaxerror,unexpectedtCONSTANT,

ruby-on-rails - 使用#update_all 更新时间戳

当我有要更新其属性的ID列表时,数据库中的updated_at字段似乎没有改变,这就是我的意思:ids=[2,4,51,124,33]MyObj.where(:id=>ids).update_all(:closed=>true)执行此更新后,updated_at字段不会更改。但是,当我使用railsc进入rails控制台并执行此操作时:obj=MyObj.find(2)obj.closed=false;obj.save!在此语句之后updated_at字段更改值。为什么是这样?当发生这种情况时,我正在监听更新并执行整个应用程序流程时,我依赖于我的应用程序中的这个updated_at字段

ruby-on-rails - 尝试更新数据库值时,rails update_attributes 返回 false

希望这里有人能给我指出正确的方向。我有一个ControllerUpdatedef运行“update_attributes”。目前它返回false,没有错误消息。我是Ruby的新手,但不是编码的新手,这让我困惑了好几天!我正在尝试使用下面指定的值更新用户模型和数据库。defupdate#getcurrentlyloggedinuser@user=current_user#updateuserparamsbasedoneditform...if@user.update_attributes(params[:user])redirect_toprofile_path,:notice=>"Su