草庐IT

SQL的ROUND函数用法及其实例

全部标签

ruby - 如何在 ARel 中使用 CONCAT() 等函数?

有没有办法让ARel将列名写入(经过净化、可能别名等)CONCAT()和其他SQL函数?这是howtodoitwithAVG()...?>name=Arel::Attribute.new(Arel::Table.new(:countries),:name)=>#population=Arel::Attribute.new(Arel::Table.new(:countries),:population)=>#Country.select([name,population.average]).to_sql=>"SELECT`countries`.`name`,AVG(`countries`

ruby - 为什么要使用 SQL 构建器? Arel 诉 Sequel 诉 T-SQL

我正在尝试了解通过面向对象的构建器DSL构建SQL与参数化原始SQL字符串相比的优势。在以三种方式研究/实现相同的查询之后,我注意到原始SQL是迄今为止最容易阅读的。这就引出了一个问题,“为什么要跳过一个箍?”为什么不直接声明和使用原始SQL?这是我想出的:首先,我猜它使SQL更具可移植性,因为它可以被任何带有适配器的数据库使用。我猜这是大人物,对吧?尽管如此,难道大多数T-SQL不是大多数数据库都能理解的吗?其次,它提供了一个可以重复使用的查询对象——作为其他查询、命名范围链接等的基础。通过构建SQL而不是声明SQL,您实现的主要投资返回是什么?definstances_of_sql

sql - Ruby Rails - 使用 created_at 列制作表格

Rubyonrails有t.timestamps方法创建两列,created_at和updated_at。我怎样才能只创建created_at列?这行得通classCreateLinesSources这两个我都想工作但是都失败了classCreateLinesSources和classCreateLinesSources 最佳答案 t.datetime:created_at,null:false就像任何其他专栏一样。由于列名,Rails仍会负责魔术更新。 关于sql-RubyRails-

ruby - ruby 中有基数函数吗?

在阅读此处的另一个问题时,在创建URL缩短服务时,建议获取行的ID,然后将其转换为基数62(0到9,a到z,A到Z)。在Ruby中是否有一个标准的函数来完成这个?编辑:不确定我是否足够清楚。是这样的:123456.radix(62)应该给出123456的基数62。我正在考虑写一个,如果它还没有的话。 最佳答案 Ruby整数类中的to_s方法有一个可选参数指定基数,类似于:123456.to_s(16)但是,它只接受2到36之间的值作为基数。如果您想编写自己的编码器,Thissnippet可能是一个不错的起点。还有一个base62Ru

ruby-on-rails - 向 Rails 模型实例对象动态添加哈希属性?

有模型classPlaylistModel然后在ControllerAction中有这样的代码PlaylistController但是PlaylistModel中(或播放列表表的架构中)没有定义visited属性!看起来一个新属性正在动态添加到对象中。这是正在发生的事情吗?所有这些功能在哪里定义/我在哪里可以阅读更多相关信息。感谢您的帮助! 最佳答案 这是解释的属性setter快捷方式here.它几乎等同于:@item.attributes[:visited]=true 关于ruby-o

ruby - 理解 Ruby 类实例变量

这个问题在这里已经有了答案:关闭10年前。PossibleDuplicate:WhydoRubysettersneed“self.”qualificationwithintheclass?有人可以解释以下内容之间的区别,以及为什么它不像人们预期的那样:#version#1classUserdefinitialize(name,age)@name=name@age=ageendend#version#2classUserattr_accessor:name,:agedefinitialize(name,age)@name=name@age=ageendend#version#3class

ruby - 如何在命令行上将实例变量传递给 HAML 模板?

背景我正在尝试测试Rails之外的一些HAML模板的格式。这个想法是在命令行或通过包含的Ruby文件传递​​一些实例变量,将模板呈现为标准输出。我尝试了几种不同的方法但没有成功,如下所述。需要一个Ruby文件例如,给定以下两个文件:HAML模板:“test.haml”!!!%h1TestingHAMLCLI%p=@bar%p=@bazRuby文件:“test.rb”@foo='abc'@bar='123'我希望像haml-r./testtest.haml这样的调用在标准输出上返回一个内插的HTML文件,但它没有。相反,我只得到HTML:TestingHAMLCLI程序化尝试由于这不起作

ruby - 如何在 rspec 测试中定义一个可以被辅助函数访问的简单全局变量

我不知道如何在rspec测试中使用一个简单的全局变量。这似乎是一个微不足道的功能,但经过多次目击后我还没有找到解决方案。我想要一个可以在整个主规范文件和辅助规范文件中的函数中访问/更改的变量。这是我目前所拥有的:require_relative'spec_helper.rb'require_relative'helpers.rb'let(:concept0){''}describe'ICETesting'dodescribe'step1'doit"Populatessuggestionscorrectly"doconcept0="tg"selectConcept()#inhelperf

ruby-on-rails - Rails 中 url_for 的反义词是什么?采用路径并生成解释路径的函数?

脑子有点炸了....我如何从relative_path获取:controller和:action的散列?这基本上与url_for相反。在下面的示例中,“some_function”是我正在寻找的神秘函数名称...我知道这很简单,只是不记得或似乎无法在文档中找到它。像这样:some_function('/posts/1/edit')=>{:controller=>'posts',:action=>'edit',:id=>'1'} 最佳答案 Rspec有一个方法'params_for',它使用ActionController的路由方法将

ruby-on-rails - 相关模型的每个实例的事件管理范围

我对动态事件管理范围有疑问。我正在尝试为我的应用程序中的“项目”的每个“经理”创建一个范围。但是,当创建新经理(或分配给项目)时,范围似乎不会更新,但如果我重新启动服务器,它们会更新。所以代码本身“有效”,但显然不是我想要的方式。我是ruby​​/rails新手,所以我不确定是否需要做一些事情以某种方式“刷新”范围。仅供引用,我在带有ActiveAdmin的HerokuCedar上使用Rails3.2这是有问题的代码(有效但仅在服务器重新启动后引入新的管理器):Manager.find_eachdo|m|scopem.first_namedo|projects|projects.whe