2011-03-30 84 views
0

我有一些这样的SQL:MySQL的PHP​​的preg_replace,正则表达式

select o.customer_id, o.reference, o.firstname, o.lastname, os.name as status, o.date_modified, o.total as last_purchase_amount, sum(o.total) as total, count(o.order_id) as number_of_orders, o.currency, o.value from `order` o left join order_status os on o.order_status_id = os.order_status_id where os.language_id = '1' group by customer_id order by date_modified desc 

有使用下面的代码来计算的页面索引

function splitQuery($sql, $page = '1', $max_rows = '20') { 
     $count = $this->getRow(preg_replace(array('/select(.*)from /Asi', '/order by (.*)/i'), array('select count(*) as total from ', ''), $sql, 1)); 
     $pages = ceil($count['total']/(int)$max_rows); 

它不工作的功能我SQL,所以我做了一些测试

$sql = "select o.customer_id, o.reference, o.firstname, o.lastname, os.name as status, o.date_modified, o.total as last_purchase_amount, sum(o.total) as total, count(o.order_id) as number_of_orders, o.currency, o.value from `order` o left join order_status os on o.order_status_id = os.order_status_id where os.language_id = '1' group by customer_id order by date_modified desc 
"; 
echo preg_replace(array('/select(.*)from /Asi', '/order by (.*)/i'), array('select count(*) as total from ', ''), $sql, 1); 

它输出

select count(*) as total from `order` o left join order_status os on o.order_status_id = os.order_status_id where os.language_id = '1' group by customer_id 

似乎“通过CUSTOMER_ID组”是在哪里造成trouble.please帮我修改

preg_replace(array('/select(.*)from /Asi', '/order by (.*)/i'), array('select count(*) as total from ', ''), $sql, 1) 

或建议的方式来解决它?mysql_num_rows?

整机功能

function splitQuery($sql, $page = '1', $max_rows = '20') { 
    $count = $this->getRow(preg_replace(array('/select(.*)from /Asi', '/order by (.*)/i'), array('select count(*) as total from ', ''), $sql, 1)); 

    $pages = ceil($count['total']/(int)$max_rows); 

    if (!$page) { 
     $page = 1; 
    } 

    $offset = ((int)$max_rows * ($page - 1)); 

    $sql .= " limit " . (int)$offset . ", " . (int)$max_rows; 

    $this->pages = (int)(($pages > 0) ? $pages : '1'); 
    $this->total = (int)$count['total']; 
    $this->from = (int)(($offset > 0 || $count['total'] == 0) ? $offset+1 : '1'); 

    if ($count['total'] < $max_rows) { 
     $this->to = (int)$count['total']; 
    } elseif ($this->pages == $page) { 
     $this->to = (int)($offset + $max_rows - ($offset + $max_rows - $count['total'])); 
    } else { 
     $this->to = (int)($offset + $max_rows); 
    } 

    return $sql; 
} 

我宁愿没有这个功能,外改变任何东西只要有可能..

确定...我决定用我自己的狡猾修复

 //$count = $this->getRow(preg_replace(array('/select(.*)from /Asi', '/order by (.*)/i'), array('select count(*) as total from ', ''), $sql, 1)); 

     $this->result = mysql_query($sql); 
     $count = array(
      'total' => mysql_num_rows($this->result) 
     ); 

回答