Merb/DataMapperをしばらく使っていたのですが、
少なくともバージョン0.9.10, 0.9.11では、
associationの実装にバグがあり、
レコード数が多いテーブルがあると、aggregation系の処理に時間がかかるという問題がある事が分かりました。

例えば、Post.has n, :comments な関係がある時に、
以下のようなコードを実行すると、このようになります。

ruby>>
?> Post.first.comments.count #=> 188
~ (0.000865) SELECT "id" FROM "posts" ORDER BY "id" LIMIT 1
~ (0.000094) SELECT "id", "post_id" FROM "comments" WHERE ("post_id" IN (1)) ORDER BY "id"
~ (0.000063) SELECT COUNT(*) FROM "comments" WHERE ("post_id" = 1)
<<--

2つ目のSQLは不要なのですが、発行されてしまいます。
例えばCommentのレコード数が多かった場合、Commentオブジェクトを大量に生成しようとしてしまうため、致命的な遅さになってしまいます。

目下この問題の解決策を探しているところですが、
Edge-DMのspec/仕様でerrorが出ている状態なので、なかなか手が付けられない感じです。
とりあえず、dm-coreのassociations/relationship.rbの中の、

ruby>>
# @api private
def get_children(parent, options = {}, finder = :all, *args)
parent_value = parent_key.get(parent)
bind_values = [ parent_value ]

    with_repository(child_model) do |r|
      parent_identity_map = parent.repository.identity_map(parent_model)

      query_values = parent_identity_map.keys
      bind_values = query_values unless query_values.empty?
      query = child_key.zip(bind_values.transpose).to_hash
      collection = child_model.send(finder, *(args.dup << @query.merge(optio

ns).merge(query)))

      return collection unless collection.kind_of?(Collection) && collection.any?

<<--

の最後の collection.any? で件のSQLが実行されているところまでは分かりました。
DataMapper::CollectionはextlibのLazyArrayを継承しているクラスなのですが、どうもそのへんの仕様が変わったのに追従できてないのかな。
モジュールを過度に分散しすぎるのも、整合性を保つのが大変になるという問題がありますね。
注意深く完全なSpecを書く事を心がけていれば防げる問題かもしれないですが。

posted by genki genki on Wed 8 Apr 2009 at 04:52 with 0 comments
Contents rssrss
光ファイバーを二次元振動させて走査するAR用ディスプレイ
因果の取り違え
Swift2's defer for CoffeeScript
mongodb-3.0からcreateIndexのdropDupsが無くなったらしい
mongodb-3.0以降のWiredTigerの設定を動的に変更する方法
一般楕円の高速生成アルゴリズムへの道標
farro mantecatoのレシピ
Droonga関連の記事のまとめ
RuntimeErrorの特定のメッセージに限定してrescueする方法
jQueryでscriptタグを実行せずにappendする
Tags
coffeescriptdefergroongajsmemonodenodejs
Comments rssrss
https://englishlearning.ketnooi.com/@jinamceacharn5?page=about https://englishlearning.ketnooi.com/@jinamceacharn5?page=about: Если отношения зашли в тупик, иногда лучше вовремя... 04/10 07:25
https://901radio.com/@estelleganz413?page=about https://901radio.com/@estelleganz413?page=about: Интрига в общении должна присутствовать всегда. Ч... 04/10 06:22
https://акваторг24.рф/zapornaya-radiatornaya-kotelnaya-armatura/klapan-predohranitelnyy-mvi-1-2-h-6-bar-art-se-660-04/ https://акваторг24.рф/zapornaya-radiatornaya-kotelnaya-armatura/klapan-predohranitelnyy-mvi-1-2-h-6-bar-art-se-660-04/: В Москве имеется один офлайн-магазин , работающий ... 04/09 12:46
https://meb-estet.ru/shkafy/detskaya/ https://meb-estet.ru/shkafy/detskaya/: Изготовление шкафов на заказ в Москве от компании ... 04/09 00:10
guest guest: I have a question, can you contact me at ja-zu98@m... 04/08 10:52
guest guest: I have a question, can you contact me at ja-zu98@m... 04/08 10:51
guest guest: I have a question, can you contact me at ja-zu98@m... 04/08 10:51
guest guest: I have a question, can you contact me at ja-zu98@m... 04/08 10:50