繁体   English   中英

使用Atk4从数据库加载数据

[英]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中使用模型,将适用以下规则:

  • 列出时,只会显示属于当前用户的旅行
  • 添加时,user_id将设置为当前用户的ID

有时我添加功能:

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.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM