[英]Loading data from Database with Atk4
对于像我这样的菜鸟来说,与Atk4一起工作是一种伟大的冒险。 现在我真的有一个我自己无法解决的问题。 我在MySQL数据库中有两个表。 第一个命名为用户(id,用户名,电子邮件),第二个命名为trips(id,user_id,name)。 我已经为用户制作了一个登录和注册表格。 我希望登录的用户能够看到它自己的行程。 我以前使用以下代码将其用作配置文件信息:
<?php
class page_userprofile extends Page{
function init(){
parent::init();
$this->api->auth->check();
$model = $this->add('Model_user');
$this->add('FormAndSave')->setModel($model)->loadData($this->api->auth->get('id'));
}
}
我必须对Model_trips做类似的事情,但我不知道是什么。 我已经尝试过从Atk4网站获取该示例:
// Traverse foreign keys. Automatically loads proper model and data
$company=$emp->getRef('company_id');
这是我最后编写的代码:
<?php
class page_mytrips extends Page{
function init(){
parent::init();
$this->api->auth->check();
$model = $this->add('Model_trips');
$this->add('FormAndSave')->setModel($model)->loadData($this->getRef('user_id'));
}
}
您非常接近:
$model = $this->add('Model_trips');
$model->setMasterField('user_id', $this->api->auth->get('id'));
之后,您可以在CRUD,MVCGrid,MVCForm或MVCLister中使用模型,将适用以下规则:
有时我添加功能:
class Model_User extends Model_Table {
function getTrips(){
return $this->add('Model_trips')
->setMasterField('user_id',$this->get('id'));
}
}
然后,您可以使用以下内容。
$model = $this->add('Model_user')->loadData($user_id)->$getTrips();
如果您想查看其他用户的旅行,则非常方便。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.