草庐IT

IDEA连接MySQL数据库并执行SQL查询操作

全部标签

ruby-on-rails - 将查询字符串附加到 url

我有一个回调url字符串params[:callback],我需要附加一个查询字符串"&result=true"并重定向用户。我发现这样做的更好方法是使用addressable但我认为代码对于这样的任务来说太大了,尤其是当我们谈论ruby​​时:callback=Addressable::URI.parse(params[:callback])query=callback.query_valuesquery[:result]='true'callback.query_values=queryredirect_tocallback.to_s是否有更优雅的方式来获得与此代码段相同的结果?

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

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

ruby-on-rails - 如何获取触发查询的代码行?

在rails3.2中是否有一种方法(一个gem、一个插件或其他东西)来知道哪一行代码触发了一个数据库查询?例如在我的日志中我有:UserLoad(0.4ms)SELECT`users`.*FROM`users`WHERE`users`.`id`=5LIMIT1如何知道触发查询的代码行?谢谢... 最佳答案 我找到了这个解决方案:moduleQueryTracedefself.enable!::ActiveRecord::LogSubscriber.send(:include,self)enddefself.append_featur

ruby - 从 Ruby 执行 Rspec

我正在尝试从ruby​​执行rspec,并从方法或类似的东西中获取状态或失败次数。实际上我正在运行这样的东西:system("rspec'myfilepath'")但我只能得到函数返回的字符串。有没有办法直接使用对象来做到这一点? 最佳答案 我认为最好的方法是使用RSpec的配置和格式化程序。这不涉及解析IO流,还以编程方式提供更丰富的结果自定义。RSpec2:require'rspec'config=RSpec.configuration#optionallysettheconsoleoutputtocolourful#equiv

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 - "gem install"可以配置为默认安装/usr/bin/外的可执行文件吗?

默认情况下,当您sudogeminstallthegemname时,它会将可执行文件安装到/usr/bin/有办法改变吗?例如,要将它们安装到/usr/local/rubygems/bin(或任何其他路径)?路径似乎没有硬编码到gemspec文件中,所以我不明白为什么这不可能(尽管我对Ruby/Gems的经验很少) 最佳答案 我将此添加为答案,以便当我再次遇到此问题时很明显:)首先,将/var/lib/gems/1.8/bin/中的所有bin移动到/usr/bin/。如果您不这样做,那么卸载或更新gem将不会从原始bin目录中删除二

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

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

ruby - 执行 gem ... ["extconf.rb", ...] 不是文件

我正在尝试围绕C扩展构建一个ruby​​gem。使用rubyextconf.rb可以很好地编译C扩展;制作;sudomakeinstall例程,但是当我尝试使用rake构建gem时,该过程终止并出现此跟踪底部的错误。我正在使用帖子here,具有相同的目录结构,以创建gem。我的配置有什么问题?我的gemspec和Rakefile位于跟踪下方(该gem称为netconf)。//跟踪**Executecopy:netconf:i686-linux:1.9.2install-ctmp/i686-linux/netconf/1.9.2/netconf.solib/netconf/netconf

ruby - 如何在 ruby​​ 中执行 attr_accessor_with_default?

我在Rails模型中使用attr_accessor_with_default的一些代码现在给我一个弃用警告,告诉我“改用Ruby!”所以,考虑到ruby1.9.2中可能有一个新的位使attr_accessor处理默认值,我用谷歌搜索了它,但我没有看到。我确实看到了一堆方法来覆盖attr_accessor来处理默认值。当他们告诉我“使用Ruby”时,这就是他们的意思吗?或者我现在应该写完整的getters/setters吗?或者有什么我找不到的新方法吗? 最佳答案 Thisapidockpage建议只在初始化方法中执行。classSo

ruby - 执行 rake db :migrate on Heroku 时出错

做的时候heroku运行rakedb:migrate所有迁移都已执行,最后我总是收到以下消息:/app/vendor/bundle/ruby/1.9.1/bin/rake:没有这样的文件或目录-pg_dump-i-s-x-O-f/app/db/structure.sqldan79p98fykovu我无法在Heroku上将pg_dump添加到PATH。如何处理? 最佳答案 问题在于,迁移完成后,rails会尝试转储新的structure.sql,但由于pg_dump不存在而失败。为已部署的应用程序生成新的structure.sql毫无