3 番目のテーブルの外部キー Id を持っています (例: (having thirdsubmenu_id
of thirdsubmenu
table) )。menu_name
親テーブルから名前を取得したいmainmenu
。 詳細については、以下のデータベース テーブル構造を参照してください。
データベース構造
1)Table: mainmenu
---------------
mainmenu_id PK(primary key)
menu_name .....
2)Table: submenu
-------------------
submenu_id PK
mainmenu_id FK (foreign key refrences mainmenu table)
submenu_name .....
3)Table: thirdsubmenu
--------------------
thirdsubmenu_id PK
submenu_id FK (foreign key refrences submenu table)
thirdsubmenu_name ........
テーブルmenu_name
から取得するために以下のコードを試しましたが、エラーが発生しています。mainmenu
//---------------------------get Main Menu Name by thirdsubmenu_id-----------------------------------
function getMainMenuNameOfSubmenu($thirdsubmenu_id)
{
$this->load->database();
$this->db->select('*');
$query=$this->db->join('mainmenu', 'mainmenu.mainmenu_id = submenu.mainmenu_id', 'left')
->join('submenu', 'submenu.submenu_id = thirdsubmenu.submenu_id', 'left')
->get_where('thirdsubmenu',array('thirdsubmenu_id'=>$thirdsubmenu_id));
return $query->row('menu_name');
}
私が得ているエラーは次のとおりです。
A Database Error Occurred
Error Number: 1054
Unknown column 'submenu.mainmenu_id' in 'on clause'
SELECT * FROM (`thirdsubmenu`) LEFT JOIN `mainmenu` ON `mainmenu`.`mainmenu_id` = `submenu`.`mainmenu_id` LEFT JOIN `submenu` ON `submenu`.`submenu_id` = `thirdsubmenu`.`submenu_id` WHERE `thirdsubmenu_id` = '17'
Filename: D:\xampp\htdocs\system\database\DB_driver.php
Line Number: 330