यहां एक विकल्प यह होगा कि payment
. के साथ सेल्फ जॉइन किया जाए तालिका, customer_id
. पर शामिल होना और order_id
स्तंभ। आप एक और जॉइन फंक्शन कॉल जोड़ सकते हैं और फिर अपने चयन में परिणाम का उपयोग कर सकते हैं। निम्न समाधान एक कच्ची क्वेरी का उपयोग करता है क्योंकि कोडनिर्देशक शामिल होने की स्थिति में अंकगणित को सहन नहीं करता है:
public function order_balance($order_code)
{
$this->db->query("SELECT p1.*, p2.balance AS previous_balance FROM payment p1 INNER JOIN payment p2 ON p1.order_id = p2.order_id + 1 AND p1.customer_id = p2.customer_id LEFT JOIN services s ON p1.customer_id = s.customer_id ORDER BY p1.id DESC");
$query = $this->db->get_where('p1', array('code' => $order_code));
return $query->previous_row();
}
क्वेरी का रूप है:
SELECT p1.*, p2.balance AS previous_balance
FROM payment p1 INNER JOIN payment p2
ON p1.order_id = p2.order_id + 1 AND
p1.customer_id = p2.customer_id
LEFT JOIN services s
ON p1.customer_id = s.customer_id
ORDER BY p1.id DESC