在Rails(4.1.5/ruby2.0.0p481/win64)应用程序中,我在Student和Course之间建立了多对多关系,并表示了该关联的联接模型StudentCourse并具有和附加属性,称为start(set默认情况下为“false”)。我还在由student_id和course_id组成的联接表中添加了一个索引,并对此设置了唯一的检查,就像这样t.index[:student_id,:course_id],:unique=>true,:name=>'by_student_and_course'我希望将其用作复合主键,但是由于在Rails中没有复合主键(不使用gem)
我在Ubuntu14.04中的通用终端(应用程序简称为“终端”)内运行railsserver和railsconsole。每当我运行涉及数据库的命令时,控制台都会输出它发送的SQL查询,但有时文本是绿松石色,有时是紫色。例如在这个控制台输出中:2.2.2:025>pl=ProjectLevel.find_by(name:'Premium')ProjectLevelLoad(0.5ms)SELECT"project_levels".*FROM"project_levels"WHERE"project_levels"."deleted_at"ISNULLAND"project_level
我正在创建一个轻量级应用程序来创建和显示即将发生的事件的信息。我定义了一个Event类,它将args散列作为参数。初始化方法定义如下。classEvent到目前为止,还不错。然后,在Rails控制台中,我定义了一个args散列并尝试创建一个Event实例,但出现以下错误。[4]pry(main)>args={what:'what',theme:'theme'}=>{:what=>"what",:theme=>"theme"}[5]pry(main)>Event.new(args)=>#这看起来很简单,但我很难理解。任何帮助表示赞赏。 最佳答案
我有以下型号classSurvey我的Controller:defnew@survey=Survey.newsurvey_section=@survey.survey_sections.buildsurvey_section.questions.buildenddefcreate@survey=Survey.new(survey_params)if@survey.saveredirect_to@survey,notice:'Super'elserender'new'endenddefsurvey_paramsparams.require(:survey).permit(:title,:
假设我有一个整数数组:arr=[0,5,7,8,11,16]我还有另一个整数:n=6我需要一个函数来向下舍入到数组中最接近的数字:foo(n)#=>5如您所见,数字没有固定的模式。执行此操作的优雅方法是什么?谢谢 最佳答案 使用select其次是max:arr=[0,5,7,8,11,16]putsarr.select{|item|item结果:5这在线性时间内运行,不需要对数组进行排序。 关于Ruby:根据任意数字列表将数字舍入到最接近的数字,我们在StackOverflow上找到一个
我必须在mongoid模型中添加几个字段,我知道MongoDB没有迁移,但如果我继续而不删除数据库,使rails完全“重新生成”数据库,它不会显示或使用新的领域!去这里最好的方法是什么?有比删除/重新打开mongodb更软的东西吗?提前致谢卢卡 最佳答案 一般来说,应该可以在运行时用新字段更新旧文档。MongoDB中不需要迁移。您可能想编写rake任务以使用新字段和默认值更新旧文档。您可以通过检查那些默认值为nil的新字段来找到这些文档。更新简单风格:如果您使用默认值定义一个新字段,只要您设置了一个新值,就应该始终使用该值:应用程序
如何将数据从Controller传递到模型?在我的application_controller中,我获取用户的位置(州和城市)并包含一个before_filter以使其在我的所有Controller中都可以通过访问before_filter:communitydefcommunity@city=request.location.city@state=request.location.state@community=@city+@stateend然后我尝试通过以下方式将Controller中检索到的数据添加到模型中:before_save:add_communitydefadd_comm
在PHP中,我可以为模型设置一个属性(不是数据库中的列)。例如(PHP代码),$user=newUser;$user->flag=true;但在Rails中,当我设置数据库中不存在的任何属性时,它会抛出错误undefinedmethodflag。有attr_accessor方法,但是如果我需要大约十个临时属性会怎样? 最佳答案 butwhatwillhappenifIneedabouttentempattributes?#app/models/user.rbclassUserattr_accessor创建"virtual"attri
在shell中,我可以做到$catname_of_file_with_a_lot_of_text|grep"WhatIamlookingfor"在Rails控制台中,我能否实现类似的功能,比如当我运行一个命令并且输出很大时,尤其是数据库查询。我知道将其输出为YAML,但这不是我要找的。谢谢。 最佳答案 是的,你可以。该方法称为gr...等待它...ep。Ruby的grep适用于String、Array和许多其他内置对象。例如,要获取一个数字的所有to_xxx方法,只需执行以下操作:1.methods.grep(/to_/)
我正在使用ruby和activerecord获取有关mysql表的信息。我希望我可以直接从我的模型类中获取这些信息,这可能吗?假设我有我的模型:classProduct我现在可以获取以下信息吗:1.mysqltable2.columns3.columntypes或者我是否必须更深入地查看ActiveRecord模块才能获得它? 最佳答案 Product.table_nameProduct.column_namesProduct.columns_hash['title'].type 关