草庐IT

数据模型MySQL

全部标签

ruby-on-rails - 如何验证关联的模型 ID?

我有一个学生和一个类(class)模型。学生属于类(class),类(class)有很多学生。classStudenttruevalidates_associated:courseendclassCoursetruevalidates:courseCode,:courseYr,:uniqueness=>{:message=>"Cannotrepeatthecode"}has_many:studentsend在用于创建学生记录的表单中,我让用户输入类(class)ID。但我不知道如何验证用户输入的course_id。学生模型验证不会产生错误,即使我键入不存在的类(class)ID。如何让

ruby - ruby 对象模型的良好解释——主要是 'classes are objects'?

正在研究ruby对象模型,有一些疑问。我理解对象只存储实例变量,方法存储在对象引用的类中的想法。我也理解“self”的概念——它是什么,它如何变化等等。但是,我不明白“类是对象”这一概念。哪里有好的、直观的解释吗?(顺便说一句:我正在使用RubyObjectModelandMetaprogramming和MetaprogrammingRuby作为我的两个资源。如果有人可以提出其他建议,那将会很有帮助。)谢谢。 最佳答案 顾名思义,类就是对象。具体来说,它们是Class类的实例,它本身是Module类的子类,而后者又是Object的子

ruby-on-rails - postgresql 数据库错误 : Is the server running locally and accepting connections on Unix domain socket "/var/run/postgresql/.s.PGSQL.5432"?

当我运行rakedb:migrate或运行railss命令时,我得到同样的错误:Error:couldnotconnecttoserver:NosuchfileordirectoryIstheserverrunninglocallyandacceptingconnectionsonUnixdomainsocket"/var/run/postgresql/.s.PGSQL.5432"?当我尝试railss时,浏览器出现错误。这是我的database.ymldefault:&defaultadapter:postgresqlencoding:unicodepool:5development

ruby-on-rails - 不能在模型中包含模块

我正在使用Rubyversion1.8.7Railsversion3.0.3我的Rails应用程序的每个模型中都有一个名为alive的方法:defalivewhere('deleterisnull')end我不想在每个模型中都复制这段代码,所以我做了一个/lib/life_control.rbmoduleLifeControldefalivewhere('deleterisnull')enddefdeadwhere('deleterisnotnull')endend在我的模型(例如client.rb)中我写道:classClient在我的config/enviroment.rb中我写了

ruby - 使用 ruby​​ 规范化数据集

我有一个范围从1到30,000的数据集我想把它归一化,让它变成0.1到10最好的方法/函数是什么?如能提供示例代码,将不胜感激! 最佳答案 这是一个代码片段,假设您想要一个线性规范化。这是一个非常简单的版本(只有直接代码,没有方法),因此您可以看到“它是如何工作的”并将其应用于任何事物。xmin=1.0xmax=30000.0ymin=0.1ymax=10.0xrange=xmax-xminyrange=ymax-yminy=ymin+(x-xmin)*(yrange/xrange)这里是作为函数完成的:defnormalise(x

ruby - 如何更新或插入 Sequel 数据集?

我刚开始在一个非常小的Sinatra应用程序中使用Sequel。因为我只有一个数据库表,所以我不需要使用模型。我想更新一条记录(如果它存在)或者插入一条新记录(如果它不存在)。我提出了以下解决方案:rec=$nums.where(:number=>n,:type=>t)if$nums.select(1).where(rec.exists)rec.update(:counter=>:counter+1)else$nums.insert(:number=>n,:counter=>1,:type=>t)end其中$nums是DB[:numbers]数据集。我相信这种方式不是“更新或插入”行为

sql - 如何查询存储在数组中的 Rails ActiveRecord 数据

我有一个名为MentorData的Rails模型,它有一个名为os_usage的属性。这些ose存储在一个数组中,就像这样['apple','linux']。回顾一下:$MentorData.first.os_usage=>['apple','linux']我希望能够查询所有MentorData的数据,包括apple的os_usage,但是当我搜索MentorData.where(os_usage:'apple')我只得到只会用apple不会用apple和linux的导师。我需要以某种方式进行搜索以检查苹果是否包含在数组中。我也试过以下方法。MentorData.where('os_u

ruby - rails rspec - 如何检查模型常量?

我该如何做:it{shouldhave_constant(:FIXED_LIST)}在我的模型(事件记录)中,我有FIXED_LIST='AString'它不是数据库属性或方法,我无法使用responds_to或has_attribute对其进行测试(它们失败了)。我可以用什么来检查它。-顺便说一句,我安装了shoulda-matchers。 最佳答案 根据DavidChelimsky的回答,我通过稍微修改他的代码使它起作用。在文件spec/support/utilities.rb(或spec/support中的其他文件)中,您可以

ruby-on-rails - 在 Rails 模型中动态生成范围

我想动态生成作用域。假设我有以下模型:classProduct我们可以用基于POSSIBLE_SIZES常量的东西替换scope调用吗?我认为我违反了DRY以重复它们。 最佳答案 你可以做classProduct但我个人更喜欢:classProduct 关于ruby-on-rails-在Rails模型中动态生成范围,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/14061595/

ruby - 覆盖 Mongoid 模型的 setter 和 getter

有没有办法在Mongoid中覆盖模型的setter或getter?像这样的东西:classProjectincludeMongoid::Documentfield:name,:type=>Stringfield:num_users,type:Integer,default:0key:namehas_and_belongs_to_many:users,class_name:"User",inverse_of::projects#Thiswillnotworkdefname=(projectname)@name=projectname.capitalizeendendname方法可以在不使