0

つまり、基本的にupdate_feedsコントローラーのベンチマークを行ったところ、実行されるSQLクエリの量が衝撃的であることがわかりました。複数のフィードを処理してからデータをテーブル(タイトルとURL)に挿入するプロセスを最適化する方法を探しています

現在、DBには193個のフィードがあり、URLを取得してから、これらを1つずつチェックして処理し、それらのデータを別のテーブルに挿入します。問題は、simplepieが通過し、すべてのアイテムを挿入することです。

だから私はQUERIESで終わることになります:3297合計実行時間202.8051

このプロセスを最適化する方法を探しています。誰かヒントがありますか?コードを投稿します。ありがとう。

フィードをフェッチするためのコントローラー

          $this->output->set_profiler_sections($sections);
        $this->load->library('simplepie');
        //$this->simplepie->cache_location = BASEPATH .'cache';
        $this->load->model('FeedModel');
        $this->load->model('FeedItemModel');
        $feeds = $this->FeedModel->get_feed_update_urls();
        foreach ($feeds as $feed_id => $feed_url) {
            $this->simplepie->set_feed_url($feed_url);
            //$this->simplepie->set_cache_duration(0);
$this->simplepie->set_timeout(0);
            $this->simplepie->init();
            $items = $this->simplepie->get_items();
            foreach ($items as $item) {
                $this->FeedItemModel->load($feed_id, md5($item->get_id()));
                $this->FeedItemModel->link = $item->get_permalink();
                $this->FeedItemModel->title = $item->get_title();
                $this->FeedItemModel->created_time = $item->get_date('Y-m-d H:i:s');
                $this->FeedItemModel->save();
            }
        }

フィードを挿入するためのモデル

function save() {
        if ($this->_id !== false) {
            $this->db->query('UPDATE feed_items SET link=?, title=?, created_time=? WHERE id=?', array($this->link, $this->title, $this->created_time, $this->_id));
        } else {
            $this->db->query('INSERT INTO feed_items(feed_id, remote_id, link, title, created_time, updated_time) VALUES (?, ?, ?, ?, ?, NOW()) ON DUPLICATE KEY UPDATE remote_id=remote_id', array($this->feed_id, $this->remote_id, $this->link, $this->title, $this->created_time, $this->remote_id));
            $this->_id = $this->db->insert_id();
        }
    }
4

1 に答える 1

0

毎回ロードしてから保存する代わりに、代わりに更新を行う必要があります (更新で行が見つからない場合は挿入します)。これにより、フィード アイテムごとに 1 つのクエリが削減されます。

于 2011-11-29T00:28:07.920 に答える