0

正直なところ、ここで少し迷っています.joomla 2.5のコンポーネントを作成し、データベースに「マネージャー」と「ブランチ」という2つのテーブルを作成しています。支店を持つマネージャーに参加しようとしています。

私の問題をもっと正確に説明できたらいいのにと思いますが、正直なところ理解できません。データベースを呼び出すモデルファイルは次のとおりです。

<?php
defined( '_JEXEC' ) or die;

 jimport('joomla.application.component.model');

class LocateModelBranches extends JModel
{
public function getItem()
{
    $branch_id = JRequest::getInt('id');

    $row = JTable::getInstance('branches', 'LocateTable');
    $row->load($branch_id);

    return $row;
}

public function getBranches()
{
    $branch_id = JRequest::getInt('id');

    $db = $this->getDbo();
    $query = $db->getQuery(true);

    $query->select('*');
    $query->from('#__branches');
    $query->join('LEFT', '#__managers AS a USING(manager_id)');
    $query->where("published = 1");

    $db->setQuery($query);

    $rows = $db->loadObjectList();

    return $rows;
}
}

それから私のview.json.phpファイル:

<?php
defined( '_JEXEC' ) or die;

jimport( 'joomla.application.component.view');

class LocateViewBranches extends JView
{
public function display($tpl = null)
{
    $branch = $this->get('Branches');
    $response = array();

    foreach ($branch as $row) {
            $response[] = array(
                    'lat' => $row->branch_latitude,
                    'lng' => $row->branch_longitude,
                    'data' => array(
                        'name' => $row->branch_name,
                        'address' => $row->branch_address,
                        'fax' => $row->branch_fax,
                        'email' => $row->branch_email,
                        'city' => $row->branch_city,
                        'telephone' => $row->branch_telephone,
                        'id' => $row->branch_id,
                        'lati' => $row->branch_latitude,
                        'lngi' => $row->branch_longitude,
                        'manager_id' => $row->manager_id,
                    ),
                );
        }
    echo json_encode($response);
}
}

次に、次の応答を受け取ります。

[]

「$query->join('LEFT', '#__managers AS a USING(manager_id)');」を削除した場合 私の応答は次のとおりです(これは、マネージャーの詳細とともに欲しいものです:

[{"lat":"-33.9249","lng":"18.4241","data":{"name":"test 2","address":"greenpoint, Cape Town","fax":"044 382 0605","email":"test","city":"blah","telephone":"044 382 0605","id":"2","lati":"-33.9249","lngi":"18.4241"}},{"lat":"-34.0438","lng":"23.0759","data":{"name":"jam factory","address":"15 meeu street knysna","fax":"00000000","email":"00000000","city":"am factory","telephone":"0000000","id":"14","lati":"-34.0438","lngi":"23.0759"}}]

私のview.json.phpの問題だと確信しています

また、json_encode から print_r に変更し、"$query->join('LEFT', '#__managers AS a USING(manager_id)');" を保持する場合 私は次の応答を受け取ります:

Array
 (
 )
 1

確かにそれはデータを出力する方法です

4

1 に答える 1

0

次のように簡単:

    public function getBranches()
{
    $branch_id = JRequest::getInt('id');

    $db = $this->getDbo();
    $query = $db->getQuery(true);

    $query->select('*, a.manager_name,manager_mobile');
    $query->from('#__branches AS t')
            ->join('LEFT', '#__managers AS a USING(manager_id)')
            ->where('t.published = 1');

    $db->setQuery($query);

    $rows = $db->loadObjectList();

    return $rows;
}

皆様のご意見をお寄せいただきありがとうございます。:)

于 2012-11-27T21:40:16.187 に答える