Yii框架列表真的很棒,但是我在使用Active Record从MySQL数据库查询数据时遇到了一个问题。
当我在模型构建中的函数"get"中加入2个表('building'和'building_info')时,将不会从我的第二个表返回数据。如果我用query Class执行相同的查询,将返回两个表中的行。使用活动记录,我只从表'building'中获取数据。
模型构建:
...
// Setting Relation
public function getBuildingInfos()
{
return $this->hasMany(BuildingInfo::className(), ['BuildingID' => 'ID']);
}
// Get all buildings
public function get() {
$building = Building::find()
->joinWith('buildingInfos')
->where(['building_info.langID' => 1])
->all();
return $building;
}
// Attributes
public function attributeLabels()
{
return [
'ID' => 'ID',
'NameBreak' => 'Name Break',
'Tileset' => 'Tileset',
'TilesetPosition' => 'Tileset Position',
...
]
}
...
模型BuildingInfo:
...
public function attributeLabels()
{
return [
'buInfoID' => 'Bu Info ID',
'BuildingID' => 'Building ID',
'langID' => 'Lang ID',
'Name' => 'Name',
'ShortDesc' => 'Short Desc',
'ShortDescDisabled' => 'Short Desc Disabled',
];
}
public function getBuilding()
{
return $this->hasOne(Building::className(), ['ID' => 'BuildingID']);
}
...
你知道如何解决这个问题吗?谢谢凯文
再见Kevin:)你用的是yii1还是yii2?
在' getbuildinginfo '中,表通过buildingid链接,在您的get函数中,您通过building_info.langID链接它。您已经验证了您的连接在sql中工作吗?