草庐IT

对数据库

全部标签

ruby-on-rails - Ruby 和金钱,在 Rails 应用程序中,如何在数据库中存储金钱值?

我想确保在Rails应用程序中存储产品价格时没有舍入问题。我应该使用什么mysql数据类型,它在rails中映射到什么?我想要10位的小数以确保精度。 最佳答案 我更喜欢将货币作为最低面额(便士、美分等)的整数存储在数据库中,并据此进行计算。add_column:product,:price,:integer当然,您会希望任何表单输入和显示都以人们期望的形式出现,因此我们在模型中添加了一些辅助方法来帮助实现这一点。classProduct然后在控制台中我们得到:>prod=Product.new=>[snip]>prod.price

ruby-on-rails - 如何在 Rails 上查找数据库迁移日志?

我想使用STEP参数将我的数据库回滚到Rails上的某个版本,但我不知道我应该回滚多少步,所以我想检查迁移日志。我可以在Rails(v3.2.13)上这样做吗? 最佳答案 尝试以下操作:rakedb:migrate:status它将为您提供以下输出,up表示迁移已运行,down尚未运行:StatusMigrationIDMigrationName--------------------------------------------------up20120328154345Devisecreateusersup2012033118

ruby-on-rails - RSpec 在测试数据库中留下记录

每当我运行用户测试时,RSpec都会在测试完成后将Fabricated用户留在测试数据库中,这会扰乱我的其他测试。我将执行rakedb:test:prepare,但是当我再次运行测试时,会在我的数据库中重新创建记录。我不知道为什么会这样。它只发生在用户对象上。在我的spec_helper文件中我什至有:config.use_transactional_fixtures=true这是一个创建记录的示例测试:it"createsapasswordresettokenfortheuser"doalice=Fabricate(:user)post:create,email:alice.emai

ruby-on-rails - 仅在一个 block 中建立与另一个数据库的连接?

在一个Rails应用程序中,我在纯ruby​​中有这段代码:classLinkCreatorattr_accessor:animaldefinitialize(animal:)@animal=animalenddefcall"something#{link_id}"endprivatedeflink_idconnection.execute(sql_request).first.firstenddefsql_request"SELECTfieldFROMtableWHEREfield_id='#{field_id}'LIMIT1"enddeffield_idanimal.field_i

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 - Rails 应用程序和 goliath api 以及数据库/模型共享

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

ruby-on-rails - 设置没有种子数据的数据库

我需要用表格等设置我的数据库,但在某些情况下我不想加载我的种子数据。我也不想每次想忽略我的种子数据时都删除或移动我的db/seeds.rb文件。有没有办法执行rakedb:setup的任务并忽略种子数据? 最佳答案 是的。只需使用以下两个命令:rakedb:createrakedb:schema:loadrakedb:setup所做的只是创建数据库(db:create),从db/schema.rb加载数据(db:schema:load),然后插入种子数据(db:seed)。您可以单独执行这些步骤。

mysql - Rails 数据库连接池的工作原理

我正在学习Rails数据库连接池概念。在Rails应用程序中,我将池大小定义为5。我对连接池大小的理解如下。当服务器启动时,rails会自动创建n个在database.yml文件中定义的连接。在我的例子中,它将创建5个连接,因为池大小为5。在每个http请求上,如果需要访问数据库,rails将使用连接池中的可用连接来处理请求。但我的问题是,如果我一次达到1000个请求,那么大部分请求将无法访问数据库连接,因为我的连接池大小只有5个。我上面对rails连接池的理解对吗??谢谢, 最佳答案 目的:数据库连接不是线程安全的;所以Activ

Java读取数据库表

Java读取数据库表packagecom.easycrud.builder;importcom.easycrud.utils.PropertiesUtils;importorg.slf4j.Logger;importorg.slf4j.LoggerFactory;importjava.sql.*;/***@BelongsProject:EasyCrud*@BelongsPackage:com.easycrud.builder*@Author:xpx*@Email:2436846019@qq.com*@CreateTime:2023-05-0218:02*@Description:读Table*

ruby - “Stack level too deep” 运行 rake 数据库 :create:all

当我运行rakedb:create:all时,我收到以下消息:/Users/junior/.rvm/gems/ruby-1.9.2-p290@global/gems/rake-0.9.2/lib/rake/version.rb:4:warning:alreadyinitializedconstantMAJOR/Users/junior/.rvm/gems/ruby-1.9.2-p290@global/gems/rake-0.9.2/lib/rake/version.rb:5:warning:alreadyinitializedconstantMINOR/Users/junior/.rv