从一个表中获取信息并将返回的信息保存在新表中 - Laravel 5.2


Getting information from one table and saving the returned information in new table - Laravel 5.2

我正在为我的学校制作一个学校系统,我遇到了这个问题,我被困了好几天。在我的应用程序中,我有类型为 adminteacherstudent 的用户。管理员创建所有用户和所有其他信息。现在,我正在制作教师面板,教师可以在其中为学生添加分数,稍后它们将显示在学生面板中。

因此,首先,当老师进入他们的帐户时,他将能够选择他教授的课程和他教授的科目,在这种情况下,我有表格 - class_subjects我在其中保存teacher_idsubject_idclass_id从管理面板。我在这里,在我的老师小组中称之为,它似乎工作得很好,因为我看到了我需要的确切课程和科目。之后,我需要对从老师那里挑选的这些进行后期查询,作为回报,从选择的班级 + 选择的主题中获得所有学生,这也完全符合我想要的方式。所以我返回的是一个新的刀片,其中包含来自表class_subject信息的数组,教师需要从这个返回的数组中选择信息,并且在文本字段中,他必须为他选择的学生添加他的标记。之后,我需要将选取的信息保存在名为 student_marks 的新表中,其中包含字段 student_idsubject_idmark_type_idmark

我的问题是如何将这些信息(老师选择的)保存在新表(student_marks)中?

我正在发布控制器:

class AccountController extends Controller
{
    public function getIndex() {
        $user = Auth::user();
        $classStudent = ClassSubject::where('teacher_id','=',$user->id)->get()->lists('class_id');
        $userSubject = ClassSubject::where('teacher_id','=',$user->id)->get()->lists('subject_id');
        return view('educator.account.account',[
            'user' => $user,
            'userTeacher'=> $classStudent,
            'userSubject'=> $userSubject,
        ]);
    }
    public function postIndex(Request $request) {
       ClassSubject::where(
            'subject_id','=',$request->get('userSubject'),
            'class_id','=',$request->get('userClass')
        );
        $user = Auth::user();
        $markType = MarkType::lists('type');
        $sub = Subject::where('id','=',$request->get('userSubject'))->get()->lists('name');
        $stu =  User::where('class_id','=',$request->get('userClass'))
            ->orderBy('first_name', 'asc')->get()->lists('full_name');
        return view('educator.account.input', [
            'user' => $user,
            'studentss'=> $stu,
            'markType' => $markType ,
            'sub'=> $sub,
    }

我知道这有点扭曲,但我真的被困在这里,如果有人最终能帮助我解决这个问题,我将不胜感激。如果有什么不清楚的地方,请询问。

教育者.帐户.帐户(第一个刀片)

@extends('teacher-app')
@section('teacher-content')
    <div class="col-md-6">
    {!! Form::open(['method' => 'post', 'class' => 'form-horizontal']) !!}
        <div class="form-group">
            {!! Form::label('profile_id','Избери клас:', ['class' => 'control-label col-md-4']) !!}
            <div class="col-md-3">
                {!! Form::select('userClass', $userTeacher, null, ['class'=>'form-control']) !!}
            </div>
        </div>
        <br>
        <div class="form-group">
            {!! Form::label('profile_id','Избери предмет:', ['class' => 'control-label col-md-4']) !!}
            <div class="col-md-3">
                {!! Form::select('userSubject', $userSubject, null, ['class'=>'form-control']) !!}
            </div>
        </div>
        <div align="center">
            {!! Form::submit('Избери', ['class' => 'btn btn-default']) !!}
        </div>
        {!! Form::close() !!}

            @stop
    </div>

教育者.帐户.输入(第二个刀片)

@extends('teacher-app')
@section('teacher-content')
    <div class="col-md-8">

        {!! Form::open(['method' => 'post', 'class' => 'form-horizontal']) !!}
        <div class="form-group">
            {!! Form::label('profile_id','Ученик:', ['class' => 'control-label col-md-4']) !!}
            <div class="col-md-3">
                {!! Form::select('userStu', $studentss, null, ['class'=>'form-control']) !!}
            </div>
        </div>
        <div class="form-group">
            {!! Form::label('profile_id','Оценка:', ['class' => 'control-label col-md-4']) !!}
            <div class="col-md-2">
                {!! Form::text('mark',null, ['class'=>'form-control']) !!}
            </div>
        </div>
        <div class="form-group">
            {!! Form::label('profile_id','Тип оценка:', ['class' => 'control-label col-md-4']) !!}
            <div class="col-md-3">
                {!! Form::select('markType', $markType, null, ['class'=>'form-control']) !!}
            </div>
        </div>
        <div class="form-group">
            {!! Form::label('profile_id','Предмет:', ['class' => 'control-label col-md-4']) !!}
            <div class="col-md-3">
                {!! Form::select('stuSub', $sub, null, ['class'=>'form-control']) !!}
            </div>
        </div>
        <br>

        <div align="center">
            <a href="{{url('educator/account')}}"><button type="button" class="btn btn-default">Назад</button></a>
            {!! Form::submit('Запиши', ['class' => 'btn btn-default']) !!}
        </div>
        {!! Form::close() !!}

        </div>

        @stop

当他们提交学生评分表单时,您将有一条类似于以下内容的路线发布到:

class AccountController extends Controller {
    public function markStudent(Request $request)
    {
        // get request data
        $mark = $request->input('mark');
        $subject_id = $request->input('stuSub');
        $mark_type = $request->input('markType');
        $student_id = $request->input('userStu');
        // get the existing record or create a new, empty record
        $student_mark = StudentMark::firstOrNew(compact('student_id', 'subject_id'));
        // add the updated data to the model
        $student_mark->fill(compact('mark_type', 'mark'));
        // persist to database
        $student_mark->save();
        // redirect or do whatever you want after request completion...
    }
}

上面的代码假设你只需要每个学生,每个科目一个条目(即这两个列上都有一个唯一的索引)。

我还建议您在插入数据之前对其进行验证,方法是在StudentMark::firstOrNew()之前执行此操作,或者通过创建具有验证的自定义请求对象。