dongyingla8668 2016-08-03 09:23
浏览 208
已采纳

如何通过yii2中的参数从数据库中获取数据?

I have 2 database tables:

user

id | name,

message

id | sender_id | receiver_id.

How can I generate custom view and get data by sender_id and receiver_id? I mean when user log in he will see his inbox and outbox messages. Please explain the logic of this. I also will be glad if you will provide code examples because I am newbie in php and yii2. If something is not understandable I will explain more specifically.

  • 写回答

1条回答 默认 最新

  • dp7311 2016-08-04 12:10
    关注

    You are really short on details, but I assume you want to display both incoming and sent messages by matching current user ID (logged in user) with both receiver_id and sender_id and display them in a gridview.

    An approach could be:

    public function actionIndex()
    {
        $user = Yii::$app->user->identity;
    
        $searchModel = new MesssageSearch();
        $dataProvider = $searchModel->search(Yii::$app->request->queryParams);
    
        // filter on ownership of either sender or receiver
        $dataProvider
            ->query
            ->andWhere(['receiver_id' => $user->id])
            ->orWhere(['sender_id' => $user->id]);
    
        $dataProvider->setSort([
            'defaultOrder' => ['created_at' => SORT_DESC],
        ]);
    
        return $this->render('index', [
            'searchModel' => $searchModel,
            'dataProvider' => $dataProvider,
        ]);
    }
    

    This assumes you have limited access to logged-in users otherwise you need to catch the case when Yii::$app->user is null.

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 能给我一些人生建议吗
  • ¥15 mac电脑,安装charles后无法正常抓包
  • ¥18 visio打开文件一直显示文件未找到
  • ¥15 请教一下,openwrt如何让同一usb储存设备拔插后设备符号不变?
  • ¥30 使用quartz框架进行分布式任务定时调度,启动了两个实例,但是只有一个实例参与调度,另外一个实例没有参与调度,不知道是为什么?请各位帮助看一下原因!!
  • ¥50 怎么获取Ace Editor中的python代码后怎么调用Skulpt执行代码
  • ¥30 fpga基于dds生成幅值相位频率和波形可调的容易信号发生器。
  • ¥15 R语言shiny包和ncdf4包报错
  • ¥15 origin绘制有显著差异的柱状图和聚类热图
  • ¥20 simulink实现滑模控制和pid控制对比,提现前者优势