草庐IT

【数据库】SQL语法

全部标签

ruby - 如何禁用数据库 :schema:dump for migrations

我不希望Rails3在每次迁移时生成我的模式。如何正确禁用它?谢谢 最佳答案 对于仍在寻找在迁移后禁用数据库转储的方法的任何人,rails4中现在可以使用配置,可以像这样将其设置为false:config.active_record.dump_schema_after_migration=false会阻止它。此更改中已添加配置-https://github.com/rails/rails/pull/13948 关于ruby-如何禁用数据库:schema:dumpformigrations

Ruby: bool 正则表达式方法的正确语法是什么?

检查字符串中的模式并在正则表达式匹配时返回true或false的方法的正确语法是什么?基本思路:defhas_regex?(string)pattern=/something/ireturnstring=~patternend用例:ifhas_regex?("something")#woohooelse#nothingfound:panic!end 最佳答案 在你说的问题中:...methodthatchecksastringforapattern,andreturnstrueorfalseiftheregexmatches作为jo

ruby - Rails,如何迁移大量数据?

我有一个运行旧版本Spree(开源购物车)的Rails3应用程序。我正在将它更新到最新版本。这需要我在数据库上运行大量迁移以与最新版本兼容。但是,应用程序当前的数据库大约为300mb,要在我的本地计算机(macosx10.7、4gbram、2.4GHzCore2Duo)上运行迁移需要三天以上的时间才能完成。我能够使用AmazonEC2实例(高I/O按需实例,四倍超大)将这个时间减少到仅16小时。但是16小时仍然太长,因为我必须关闭网站才能执行此更新。有没有人有任何其他建议来降低这个时间?或提高迁移性能的任何提示?仅供引用:在Amazon实例上使用Ruby1.9.2和Ubuntu。

ruby-on-rails - 我的应用程序一直在创建数据库连接,我该如何追踪原因?

我有一个在Heroku上运行的RubyonRails应用程序。我不断在日志中收到这些消息:2015-05-05T16:11:14Zapp[postgres.27102]:[AQUA]connectionreceived:host=xx.xxx.xx.26port=602782015-05-05T16:11:14Zapp[postgres.27102]:[AQUA]connectionauthorized:user=postgresdatabase=somedb2015-05-05T16:11:14Zapp[postgres.27103]:[AQUA]connectionreceived

ruby-on-rails - Heroku 应用程序的数据库管理

我对Rails和Heroku都很陌生,但我正在认真考虑将其用作部署我的Ruby/Rails应用程序的平台。我想使用Heroku的所有功能,所以我更喜欢Heroku管理的“嵌入式”PostgreSQL,而不是AmazonRDSforMySQL的插件,但如果无法在SQL客户端...我知道在一个制作精良的应用程序中你不需要访问数据库,但有一些情况(将行添加到配置表,查看未映射到View中的数据,更新一些列以解决调试问题,性能监控,运行报告等查询)当这可能很好时......你是如何解决这个问题的?在由Heroku提供支持的真实应用中,您有什么体验?谢谢! 最佳答案

ruby - 为什么需要 ":nodoc:"语法?

似乎很多库/插件都使用这种语法:defself.included(base)#:nodoc:base.extendClassMethodsend为什么:nodoc:部分是必需的? 最佳答案 没有必要。如果应用于一个类,它只会抑制类扩展中所有方法的文档(rdoc)。在ProgrammingRuby中描述为::nodoc:-Don'tincludethiselementinthedocumentation.Forclassesandmodules,themethods,aliases,constants,andattributesdir

ruby-on-rails - 如何检查将脚本/运行程序作为 shebang 的 ruby​​ 脚本的语法?

我在检查其shebang上有railsscript/runner的ruby​​脚本的语法时遇到问题。这里有两个示例脚本以及它们如何响应ruby​​语法检查:脚本hello_world_runner.rb:#!/usr/bin/envscript/runnerp"Helloworld!"脚本hello_world.rb#!/usr/bin/envrubyp"Helloworld!"这是我尝试检查语法的方法。第一行是命令,第二行是输出。$ruby-chello_world_runner.rb"Helloworld!"$ruby-chello_world.rbSYNTAXOK

ruby-on-rails - 类似 Rails 的数据库迁移?

是否有任何易于安装/使用(在unix上)的数据库迁移工具,例如RailsMigrations?我真的很喜欢这个想法,但是纯粹为了管理我的数据库迁移而安装ruby​​/rails似乎有些过分了。 最佳答案 只需使用ActiveRecord和一个简单的Rakefile。例如,如果您将迁移放在db/migrate目录中,并且有一个包含您的数据库配置的database.yml文件,那么这个简单的Rakefile应该可以工作:Rakefile:require'active_record'require'yaml'desc"Migratethe

sql - ActiveRecord::StatementInvalid。 PG错误

我正在尝试使用Project.find(id)从Project模型中找到一个项目,但它给了我ActiveRecord::StatementInvalid错误完整跟踪-PG::Error:ERROR:preparedstatement"a1"alreadyexists:SELECTCOUNT(*)FROMpg_classcLEFTJOINpg_namespacenONn.oid=c.relnamespaceWHEREc.relkindin('v','r')ANDc.relname=$1ANDn.nspname=ANY(current_schemas(false))/home/deploy

ruby - 在 ruby​​ 中以散列形式返回结构数据

没有将标准ruby​​结构的数据作为散列(成员、值对)返回的方法是否有正当理由?看到结构和散列具有非常相似的用例,我很惊讶不存在这样的方法。或者是,我太盲目了?它很容易实现(我现在已经这样做了),但是标准库中缺少这样的功能,让我觉得我可能没有真正掌握ruby​​中结构的概念。 最佳答案 RubyOpenStruct#marshall_dump和Struct#each_pair:Person=Struct.new(:name,:age)person=Person.new("Jamie",23)person_hash=Hash[pers