0

私は複雑なクエリを持っていて、それを $complexQuery と言います。次に、データ結果を必要とせずに、そこからすべてのデータ行番号を取得する必要があります。

count_all_results() が num_rows() よりも優れていることを調査しました

今私のコードを言ってください:

$complexQuery = 'Some sql query';
$q = $this->db->query($complexQuery);
$total1 = $q->num_rows();

$this->db->count_all_results() をそのクエリで使用するための提案はありますか?

== DB_active_rec.php を編集することで解決 ==

私はこれを行います(テーブル名に「select」が含まれている場合はそのままにしておきます):

public function from($from)
{
    foreach ((array)$from as $val)
    {
        if (strpos($val, ',') !== FALSE)
        {
            foreach (explode(',', $val) as $v)
            {
                $v = trim($v);
                $this->_track_aliases($v);
                $v = $this->ar_from[] = $this->_protect_identifiers($v, TRUE, NULL, FALSE);

                if ($this->ar_caching === TRUE)
                {
                    $this->ar_cache_from[] = $v;
                    $this->ar_cache_exists[] = 'from';
                }
            }
        }
        else
        {
            $val = trim($val);

            // Added to bypass from arr if $val contained 'select' for complex query
            // $this->db->count_all_rows("select * from tableName")
            // will be select count(1) from (select * from tableName)
            if(FALSE !== strpos(strtolower($val),'select')){
                $this->ar_from[] = "($val)";
            }else{
                // Extract any aliases that might exist. We use this information
                // in the _protect_identifiers to know whether to add a table prefix
                $this->_track_aliases($val);
                $this->ar_from[] = $val = $this->_protect_identifiers($val, TRUE, NULL, FALSE);
            }

            if ($this->ar_caching === TRUE)
            {
                $this->ar_cache_from[] = $val;
                $this->ar_cache_exists[] = 'from';
            }
        }
    }

    return $this;
}
4

2 に答える 2

1

それは次のようになります:

$this->db->where($complexQuery);
$this->db->from('your_table_name');
echo $this->db->count_all_results();

参照:Codeigniter count_all_results()

于 2013-01-29T04:22:45.083 に答える
0

別の分、しかし同じコード

<?php if ( ! defined('BASEPATH')) exit('No direct script access allowed');

      class SomeMyModel extends CI_Model {

      private static $db;

      function __construct() 
      {
        parent::__construct();
        self::$db = &get_instance()->db;
      }

        static function countTableResults(){
          self::$db->where($coplexQuery);
           return self::$db->count_all_results('#TABLENAME#');
        }
于 2013-01-29T09:46:16.890 に答える