草庐IT

数据库--T-SQL创建数据库表

全部标签

ruby-on-rails - ruby on rails,创建新对象,使用创建或新方法?

我正在尝试通过API创建一个对象,即不需要任何形式,我应该做MyModel.new(:name=>params[:name])还是MyModel.create(:name=>params[:name])?假设我在routes中有resources:my_models我检查了一下,发现方法可以使用参数散列。 最佳答案 .new创建一个实例(但您仍然需要.save它)。而.create创建一个实例并一次性保存它。希望这有助于您决定使用哪个。 关于ruby-on-rails-rubyonrai

ruby - 从数组和频率创建散列

我有一个数组[1,2,4,5,4,7],我想找到每个数字的频率并将其存储在哈希中。我有这段代码,但它返回NoMethodError:undefinedmethod'+'fornil:NilClassdefscore(array)hash={}array.each{|key|hash[key]+=1}end期望的输出是{1=>1,2=>1,4=>2,5=>1,7=>1} 最佳答案 在Ruby2.4+中:defscore(array)array.group_by(&:itself).transform_values!(&:size)en

ruby - 如何为 Ruby 应用程序创建 REST API?

我想知道如何为Ruby应用程序提供RESTAPI。我可以基于Ruby的TCPServerAPI编写一些代码,但这似乎有点低级。你认为这是一个好的解决方案吗?或者您推荐更好的方法? 最佳答案 您可以使用Sinatra非常快速地编写微型、专注的Web应用程序和轻量级REST服务。在documentation他们重点介绍了有关该问题的几个视频:AdamWiggins和BlakeMizerany介绍Sinatra和RestClient在RubyConf2008.演讲详细介绍了Sinatra的基本理念,并反射(reflection)了如何使用

ruby - Rails:猴子修补 ActiveRecord::Base 与创建模块

我正在通读TheRails4way(由ObieFernandez撰写),一本关于Rails的著名书籍,从我目前阅读的内容来看,我强烈推荐它。但是,有一个示例部分9.2.7.1:MultipleCallbackMethodsinOneClass让我感到困惑:请耐心等待,为了让每个人都清楚问题,我在这个问题中复制了书中描述的步骤。该部分讨论了ActiveRecord回调(before_create、before_update等),并且可以创建一个类来为您处理多个回调。列出的代码如下:classAuditordefinitialize(audit_log)@audit_log=audit_l

ruby-on-rails - 在 Ruby on Rails 中,如何为 has_many 关系创建作用域?

这是一个例子:假设我有一个Student对象,它与ReportCard对象有has_many关系。ReportCard对象有一个名为“graded”的bool字段,用于标记它们已被评分。所以它看起来像:classStudent现在,假设您要创建一个默认范围,以便如果学生没有已评分的成绩单,您希望看到所有这些成绩单,但如果他们至少有一张已评分的成绩单,您只想查看已评分的成绩单.最后,假设您按“semester_number”排序。在ReportCard上使用此范围可以正常工作:scope:only_graded_if_possible,->(student){where(graded:t

ruby-on-rails - 是否有 Ruby 数据库迁移 gem,可帮助您将内容从旧结构移动到新结构?

是否有任何Rubygem/库可以帮助您从旧的数据库结构迁移到新的结构?ActiveRecord迁移在跟踪新数据库结构方面做得很好,但我想知道是否有什么可以帮助您将整个遗留数据库迁移到新结构:transfer_from(:source_table=>'person',:destination_table=>'dudes_and_dudets')dofrom:name,:to=>:full_namefrom:dob,:to=>:agedo|dob|#thiswould,forexample,loadtheresult(Date.today-dob)/60/60/24/365#ofthebl

ruby-on-rails - ruby 中的图形数据库?

ruby有没有图数据库。我听说过Jruby中的neo4j,是否有纯ruby​​中的图形数据库实现? 最佳答案 我自己一直在研究这个。有许多有趣的图形数据库;然而,Neo4j和OrientDB是我唯一找到的任何类型的RubyAPI。虽然不是真正的图形数据库,但FlockDB使用MySQL后端来模拟图形数据库结构。InfoGrid和HyperGraphDB看起来很有趣,但遗憾的是,没有RubyAPI。 关于ruby-on-rails-ruby中的图形数据库?,我们在StackOverflow

ruby-on-rails - Rails 应用程序和 goliath api 以及数据库/模型共享

我正在尝试使用Goliath框架创建异步API。服务应该写入mysql,将消息添加到RabbitMQ并接收返回的响应。还应该有一个用Rails构建的单独的管理应用程序。我对此有几个问题:有没有办法在Rails和Goliath之间有效地共享模型?在em中使用Activerecord或任何其他orm有什么问题吗?是否有任何最佳实践、配置(连接池大小、驱动程序)或其他相关选项?我必须使用什么来接收来自AMQP的消息?构建一个单独的eventmachine守护进程会更好,还是我可以以某种方式使用Goliath的守护进程?感谢您的提前。 最佳答案

ruby-on-rails - Rails/postgres, 'foreign keys' 存储在数组中以创建一对多关联

可以使用postgres数组在rails(4)中创建一对多/has_many关联吗?我知道外键类型数组是不可能的。示例:一项任务有多个受让人。传统上我会使用关联表来解决这个问题:tasks->assignees->users。使用数组,这将不是必需的,因为可以存储多个“外键”。然后可以使用以下查询来获取分配给我的所有任务:select*fromtaskswhere?INtasks.assignees 最佳答案 您将无法让Rails识别此数组并将其用于关联。但是如果您想要更快地搜索/过滤分配给用户的任务,您可以在任务对象中保留一个用户

sql - 在 Rails 中使用连接执行 update_all

在这种情况下,Rails对原始SQL的抽象让我抓狂。在MySQL中我可以这样做:UPDATEFROMtasksAStLEFTJOINprojectsaspONt.project_id=p.idSETt.invoice_id=7WHEREp.organization_id==42ANDt.invoice_idISNULL我如何在Rails3.0.1中使用预先加载来做到这一点?我已经尝试了以下所有方法:Tasks.joins(:project).where('projects.organization_id'=>42,:invoice_id=>nil).update_all(:invoic