簡體   English   中英

PHP面向對象的foreach循環

[英]PHP object oriented foreach loop

我有一個CodeIgniter查詢返回一個對象數組。 我的查詢是查詢多個具有相同字段名稱的表。 所以我使用select給它們別名。 像這樣:

SELECT t1.platform_brief b1, t2.platform_brief b2

其中t1和t2是我的兩個表。 print_r'd返回這樣的對象時我的數組:

Array
(
    [0] => stdClass Object
        (
            [b1] => Lorem ipsum
            [b2] => 
        )

    [1] => stdClass Object
        (
            [b1] => 
            [b2] => Sic dolor sit
        )

)

在我的foreach中,當我回應它們時,我該怎么做? 我試過這樣的東西,但它不起作用:

<?php foreach ($lasers as $laser) {
echo $laser->?
?>

我該用什么來代替問號?

編輯:

這是我的CI查詢:

$this->db->select('ils1.platform_brief b1, ils2.platform_brief b2');
$this->db->where('ils1.language', $lang);
$this->db->or_where('ils2.language', $lang);
$this->db->join('all_platform_ils975 ils2', 'ils2.laser_id = c.laser_id', 'left');
$this->db->join('all_platform_ils1275 ils1', 'ils1.laser_id = c.laser_id', 'left');
$this->db->join('all_lasers l', 'l.laser_id = c.laser_id', 'inner');
return $this->db->get($lang . '_configure_lasers c')->result();

根據您的后續評論判斷,您似乎想要輸出每個結果的所有b1字段,然后輸出所有b2字段。 單程:

foreach( array('b1', 'b2') as $fields ) {
    foreach( $lasers as $laser ) {
        echo $laser->$field, '<br>';
    }
}

可以迭代每個對象:

foreach ($lasers as $laser) {
    foreach($laser as $field) {
        if(!empty($field)) echo $field;
    }
}

但是,您應該更改數據庫設計/查詢設計以更好地滿足您的需求。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM