Laravel 关联模型-关联新增和关联更新

Laravel 关联模型-关联新增和关联更新


网上找了 Laravel 相关的关联新增和关联更新文档,写的都不是很满意。(基本都在抄文档)下面整理下自己代码中的关联操作方法

  • 按照 Laravel 文档中的说明设置关联模型 参考地址
//病人模型
class Patient extends Model
{
    /**
     * 病人附表
     * @return \Illuminate\Database\Eloquent\Relations\HasOne
     */
    public function patientdata ()
    {
        return $this->hasOne(PatientData::class);
    }
    
 //病人附表模型
class PatientData extends Model
{
    public function patient()
    {
        return $this->belongsTo(Patient::class);
    } 
    
  • 关联更新代码
/**
 * 新增病人信息
 * @param array $data
 *
 * @return bool
 */
public function savePatient($data=[])
{
    DB::beginTransaction();
    if($patient = $this->create($data)){
        if ($res = $patient->patientdata()->create(["数据"])){
            DB::commit();
        } else{
            DB::rollBack();
        }
        return true;
    }
    return false;
}
  • 关联更新代码
public function updatePatient($data=[])
{
    DB::beginTransaction();
    //先通过主键获得病人模型的实例
    $patient = $this->find($data['id']);
    if($patient->update($data)){
        if ($res = $patient->patientdata()->where('patient_id',$data['id'])->update(["数据"])){
            DB::commit();
        } else{
            DB::rollBack();
        }
        return true;
    }
    return false;
}

你可能感兴趣的:(php)