草庐IT

查询缓存MySQL

全部标签

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-on-rails - 如何使控制台中的 View 缓存片段过期?

有点像Rails.cache.delete('site_search_form')好像不行。这可能吗?谢谢。 最佳答案 ActionController::Base.new.expire_fragment(key) 关于ruby-on-rails-如何使控制台中的View缓存片段过期?,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/756888/

ruby-on-rails - Rails 4 俄罗斯套娃缓存如何防止踩踏?

我正在查找有关Rails4中的缓存机制如何防止多个用户同时尝试重新生成缓存键(也称为缓存踩踏)的信息:http://en.wikipedia.org/wiki/Cache_stampede我无法通过谷歌搜索找到很多信息。如果我查看其他系统(例如Drupal),缓存踩踏预防是通过数据库中的semaphores表实现的。 最佳答案 Rails没有内置机制来防止缓存踩踏。根据atomic_mem_cache_store的自述文件(替代ActiveSupport::Cache::MemCacheStore以减轻缓存踩踏):Rails(and

ruby-on-rails - 在 Rails 中通过 belongs_to 关系查询记录

我有一个事件模型,它们属于一个位置如何选择location.country=Australia的所有事件?(例如)我可以在一个范围内这样做吗? 最佳答案 使用最新的rails版本,您可以:Activity.joins(:location).where(locations:{country:"Australia"})注意:它是joins(:location)中的位置(单数),因为它引用了belongs_to关系名称它是where(…)中的位置(复数),因为它引用了表名后者意味着如果您有以下情况:belongs_to:location,

ruby - 思维狮身人面像未知类型 'mysql';跳绳

我使用的是ts版本2.0.5、rails3.0.9和mysql20.2.11尝试使用rakets:index创建索引时,出现以下错误:ERROR:source'technical_core_0':unknowntype'mysql';skipping.我的development.sphinx.conf包含:sourcetechnical_core_0{type=mysqlsql_host=localhostsql_user=rootsql_pass=sql_db=ps_developmentsql_sock=/tmp/mysql.socksql_query_pre=SETNAMESut

ruby - 使用 ActiveRecord 在查询对象中转义参数?

给定一个查询对象(不是AR模型)classComplexQueryQUERY=如何方便地转义所有参数?我成功地使用了三种技术,但没有一种是方便的。使用raw_connection(对我而言)返回PG::Conn的实例并调用exec_params。我对此并不满意,因为exec_params需要一组详细的参数来指定数据类型。在我的查询对象中包含ActiveRecord::Sanitization并使用其中一种方便的方法,例如replace_named_bind_variables。我对此不满意,因为replace_named_bind_variables是protected并且我必须使用s

sql - 何时使用 ORM(Sequel、Datamapper、AR 等)与纯 SQL 进行查询

我的一位同事目前正在设计如下所示的SQL查询以生成报告,这些报告通过外部数据查询显示在excel文件中。目前只需要DB上的上报流程(无CRUD操作)。我试图说服他最好使用ruby​​ORM以便能够在rails/sinatra应用程序中显示数据。尽管在显示数据方面有明显的优势,但学习使用像Sequel或Datamapper这样的ORM对他有什么优势?他正在编写的SQL查询显然相当复杂,并且对SQL比较陌生,他经常提示它非常耗时且令人困惑。是否可以使用ORM编写极其复​​杂的查询?如果是这样,哪个最合适(我听说Sequel对遗留数据库有好处)?在进行复杂的数据库查询时,学习Ruby和使用O

ruby - 清除 ActiveRecord 缓存

我正在使用ActiveRecord3.0(没有rails)构建一个命令行应用程序。如何清除ActiveRecord维护的查询缓存? 最佳答案 第一次近似:ActiveRecord::Base.connection.query_cache.clear 关于ruby-清除ActiveRecord缓存,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/3740705/

ruby - 高效的 Ruby LRU 缓存

使用任意Ruby对象作为基于最近最少使用算法过期的键来构建缓存的最有效方法是什么。它应该使用Ruby的正常哈希语义(不等于?) 最佳答案 我知道它晚了几年,但我刚刚实现了我认为是Ruby最快的LRU缓存。它还经过测试,可以在多线程环境中安全使用。https://github.com/SamSaffron/lru_redux注意:在Ruby1.9中Hash是有序的,所以你可以在几行代码中欺骗并构建最快的LRU缓存classLruRedux::Cache19definitialize(max_size)@max_size=max_siz

ruby-on-rails - 为具有 has_many 关系的俄罗斯娃娃缓存构建 Rails 应用程序

在研究了DHH和其他关于基于键的缓存过期和俄罗斯套娃缓存的博客文章之后,我仍然不确定如何处理一种关系类型。具体来说,has_many关系。我将分享我对示例应用程序的研究结果。这有点讲故事,所以等一下。假设我们有以下ActiveRecord模型。我们只关心模型的cache_key的适当更改,对吗?classArticle我们已经有一篇文章,有一条评论。两者都是不同的作者。目标是在以下情况下更改文章的cache_key:文章正文或标题更改其评论的正文发生变化文章作者姓名变更文章评论作者姓名变更所以默认情况下,我们适用于情况1和情况2。1.9.3-p194:034>article.cache