doucha7329 2018-07-12 08:39
浏览 44

我怎么能用laravel eloquent写这个查询

I have tables Users,departments,files and shareFiles. I want to write a query that when a user tries sending a file to another user, the share function should capture the title of the file and department of the user sending the file which would be saved in the shareFiles table.

  • Users table: id, department_id
  • Files table: id, title, user_id
  • Department table: id, name
  • ShareFiles table: title, file, department_id, user_id, sender, to

Below is what i did in the share function

public function shareFile(Request $request)
    {

        $userfile = new UserFile();
        $userfile->sender = \Auth::user()->username;
        $userfile->to = $request->user;
        $userfile->title = File::select('title')->where(['user_id' => \Auth::user()->id])
        ->orWhere('id','=','user_id')->get();

        $userfile->department = DB::table('departments')->select('departments.name')
        ->join('users','departments.id','=','users.department_id')
        ->where(['users.id' => \Auth::user()->id])
        ->get();

        $userfile->user_id = \Auth::user()->id;
        $userfile->save();
        Session::flash('message','File successfully shared !!');
        return redirect('/hr/document');
    }
  • 写回答

1条回答 默认 最新

  • dongpai2754 2018-07-12 10:19
    关注

    Try this code:-

    For title selection:
    
    $file = File::select('title')->where(['user_id' => \Auth::user()->id]) ->orWhere('id','=','user_id')->first();
    
    For Department:
    
    $dept = DB::table('departments')->select('departments.name') ->join('users','departments.id','=','users.department_id') ->where(['users.id' => \Auth::user()->id]) ->first();
    

    Note: You can also use value() and pluck() (in case if you need array of values) instead of select().

    评论

报告相同问题?

悬赏问题

  • ¥15 C#读写EXCEL文件,不同编译
  • ¥15 如何提取csv文件中需要的列,将其整合为一篇完整文档,并进行jieba分词(语言-python)
  • ¥15 MapReduce结果输出到HBase,一直连接不上MySQL
  • ¥15 扩散模型sd.webui使用时报错“Nonetype”
  • ¥15 stm32流水灯+呼吸灯+外部中断按键
  • ¥15 将二维数组,按照假设的规定,如0/1/0 == "4",把对应列位置写成一个字符并打印输出该字符
  • ¥15 NX MCD仿真与博途通讯不了啥情况
  • ¥15 win11家庭中文版安装docker遇到Hyper-V启用失败解决办法整理
  • ¥15 gradio的web端页面格式不对的问题
  • ¥15 求大家看看Nonce如何配置