草庐IT

删除数据库表中重复数据的方法

全部标签

ruby-on-rails - rake 数据库 :migrate not working on my postgres db

好的,所以我有一个Rails应用程序,我试图在postgres数据库上运行迁移,我通常使用mysql,一切都很好,但是当我运行命令时,我得到了这个rakedb:migrate(in/Users/tamer/Sites/my_app)/Users/tamer/.rvm/gems/ruby-1.9.2-p290@my_app/gems/activerecord-3.0.3/lib/active_record/connection_adapters/postgresql_adapter.rb:487:[BUG]Segmentationfaultruby1.9.2p290(2011-07-09

ruby-on-rails - 如何使用 ActiveRecord 3.1 在不停机的情况下删除列?

在使用ActiveRecord运行应用程序时从表中删除列会导致错误,因为ActiveRecord会缓存列名。其他版本的ActiveRecord的解决方法是覆盖模型中的#columns方法并在迁移前过滤掉不推荐使用的列名称(基本上-对AR隐藏这些列)。这是有效的,因为所有与列名相关的方法都基于#columns调用在ActiveRecord3.1中,表结构的缓存被移至ConnectionPool,并且所有与列名相关的值(例如coluumns_hash)都被独立缓存(3.2使用ModelSchema.columns使其再次工作)在ActiveRecord3.1中是否有任何方法(除了具体适配器

ruby-on-rails - 我如何解析一个 Excel 文件,它会给我提供与视觉上完全一样的数据?

我正在使用Rails5(Ruby2.4)。我想阅读.xls文档,我想将数据转换为CSV格式,就像它出现在Excel文件中一样。有人推荐我使用Roo,所以我有book=Roo::Spreadsheet.open(file_location)sheet=book.sheet(0)text=sheet.to_csvarr_of_arrs=CSV.parse(text)但是,返回的内容与我在电子表格中看到的内容不同。例如,电子表格中的一个单元格有16:45.81当我从上面获取CSV数据时,返回的是"0.011641319444444444"如何解析Excel文档并准确获取我所看到的内容?我不在

ruby - 真正的 sinatra(ruby/rack) after_filter 最快的方法是什么?

好的,这是一个简单的任务。在我向客户端呈现html之后,我想使用请求中的信息执行数据库调用。我正在使用sinatra,因为它是一个轻量级的微框架,但我真的支持ruby​​中的任何东西,如果它更快/更容易(Rack?)。我只想获取url并根据url将客户端重定向到其他地方。那么如何使用rack/sinatra作为一个真正的after_filter。after_filter我的意思是在响应发送到客户端之后。还是没有线程就无法实现?我fork了sinatra并在过滤器之后添加,但是没有办法刷新响应,即使是假设流式传输文件(显然是二进制文件)的send_data也在等待after_filter

ruby-on-rails - 我应该将我的数据库查询测试放在 Rails 中的什么位置?

我来自Spring/hibernate背景。我注意到Rails没有dao和服务层。这确实加快了开发速度,但有时我不知道将测试放在哪里。现在,我一直在将我的模型方法和验证测试放在主要模型规范中。这个文件已经相当大了。测试查询的“标准”位置在哪里?我可以想象自己制作了大量固定装置/虚拟数据以确保我的查询按预期工作(可能是一个更好的主意,因为我是Rails的新手)。这些对于基本模型逻辑和验证测试来说并不是真正需要的。如果您能提供一些关于将这些测试放在哪里的建议,使用rails测试查询的最佳方法(尤其是具有多个连接的查询!),也许还有一些基本准则,说明它与使用DBunit/spring进行测试

ruby - 是否有一种直接的包罗万象的方法来记录在 Ruby 中的对象上调用的方法?

有没有一种快速的方法来跟踪在对象上调用的方法?通常,当我在gem的公共(public)界面之下的级别上工作时,我会遇到难以追踪的错误。最终,我最终通过源代码跟踪对象并将所有内容都记在脑海中。但是,如果能够在对象上调用类似#log_method_calls的东西,那么,比如说,调用它的所有方法都会打印到stdout或其他东西。有什么办法可以做到这一点? 最佳答案 有几种方法可以做到这一点,视情况而定。如果可以创建一个新对象而不是被观察对象,您可以使用method_missing轻松编写一个观察者类。classLogProxydefin

ruby - 为什么 block 不像方法那样继承调用者的 $SAFE 级别?

当$SAFE=4的线程调用方法时,该方法以相同的$SAFE级别运行:deftest_methodraise"valueof$SAFEinsidethemethod:#{$SAFE}"endt=Thread.new{$SAFE=4;self.test_method};t.join=>RuntimeError:valueof$SAFEinsidethemethod:4但是,当一个block被调用时,它似乎使用了来自其原始上下文的$SAFE:test_lambda=lambdadoraise"valueof$SAFEinsidethelambda:#{$SAFE}"endt=Thread.n

ruby - NoMethodError(未定义方法 `[]' 为 nil :NilClass)

我有一个非常奇怪的错误实例:NoMethodError(undefinedmethod`[]'fornil:NilClass):app/controllers/main_controller.rb:150:in`blockinfind_data_label'app/controllers/main_controller.rb:149:in`each'app/controllers/main_controller.rb:149:in`find_data_label'app/controllers/main_controller.rb:125:in`data_string'app/cont

ruby - 为什么 RVM 会为不同的 gemset 安装重复的 gem?

因此,我为我的每个Rails项目创建了一个单独的rvmgemset。他们都使用相同版本的ruby​​1.9.3。这会导致bundleinstall为两个项目完全安装一组新的gem。另一个项目是否在另一个gemset中安装了完全相同的gem版本并不重要。我猜这对我来说是预期的行为,但它似乎是对硬盘空间和带宽的低效使用。我知道我可以手动将其中一些gem移动到全局gemset,但这对我来说似乎很乏味,而且如果我的依赖项针对特定项目发生变化,也很容易崩溃。是否有更好的组织方式,或者让rvm自动检测何时安装了gem版本并只使用该副本?或者我应该使用RVM的更好替代品。

ruby - 在 Ruby 中漂亮地打印树数据结构

我正在构建一个编译器,并在其中生成一棵树来表示传入的源程序。我想展示这是一棵时尚的树,以便我可以向任何感兴趣的人展示程序的结构.现在我只是像这样在一行中打印树:ProgramNode->'Math'BlockNode->DeclarationNode->ConstantDeclarationNode->constConstantListNode->[m:=7,ConstantANode->[n:=StringLiteralNode->""TEST""]];我想要的是这样的:ProgramNode/\'Math'BlockNode|DeclarationNode|ConstantDecl