"입니다. 저장(배열)" 또는 "모델 객체->데이터(배열)->저장();"."/> "입니다. 저장(배열)" 또는 "모델 객체->데이터(배열)->저장();".">

 >  기사  >  PHP 프레임워크  >  thinkphp5에서 저장 메소드를 사용하는 방법

thinkphp5에서 저장 메소드를 사용하는 방법

WBOY
WBOY원래의
2022-02-18 14:57:545336검색

thinkphp5에서는 save() 메소드를 사용하여 지정된 데이터 테이블에 레코드를 추가합니다. 이 메소드는 한 번에 하나의 새 레코드만 테이블에 추가할 수 있습니다. 구문은 "모델 객체"입니다. -> 저장(배열)" 또는 "모델 객체-> 데이터(배열)-> 저장();"

thinkphp5에서 저장 메소드를 사용하는 방법

이 문서의 운영 환경: Windows 10 시스템, ThinkPHP 버전 5, Dell G3 컴퓨터.

thinkphp5에서 save 메소드를 사용하는 방법

단일 데이터 추가: save() 메소드

기능: 지정된 데이터 테이블에 레코드 추가

이 메소드는 한 번에 테이블에 하나의 새 레코드만 추가할 수 있습니다. 여러개의 레코드를 추가할 수 있으며, 반복해서 실행할 수도 있지만 나중에 배울 saveAll()은 한 번에 여러 항목을 추가할 수도 있습니다

소스 코드: /thinkphp/library/think/Model.php

save 방법은 다음 중 하나입니다. Model 클래스의 더 복잡한 메소드는 저장 메소드가 새로운 추가뿐만 아니라 데이터 업데이트에도 여러 가지 기능을 수행하기 때문입니다.

기본 구문:

형식 1: 저장 메서드 매개변수에 직접 데이터 쓰기

模型对象 -> save(数组);

형식 2: 먼저 데이터 개체를 생성한 다음 저장 메서드를 사용하여 테이블에 직접 씁니다

模型对象 -> data(数组) -> save();

둘 다 두 가지 구문으로 새로운 Add 작업을 완료할 수 있습니다. 그러나 두 번째 문법 구조는 더 명확하고 읽기 쉽고 수정하기가 더 편리합니다.

<?php
namespace app\index\controller;
use app\index\model\Staff;
class Index {
  public function index(){
  //1.创建数据:与表中字段对应
  $data = [];
  $data[&#39;name&#39;] = &#39;周星星&#39;;
  $data[&#39;sex&#39;] = 1;
  $data[&#39;age&#39;] = 39;
  $data[&#39;salary&#39;] = 3500;
  $data[&#39;dept&#39;] = 3;
  $data[&#39;hiredate&#39;] = date(&#39;Y-m-d&#39;,time());
  //2.创建数据对象
  $model = (new Staff())-> data($data);
  //3.获取新增操作执行前:数据对象原始数据
  $data_before = $model -> getData();
  //4.查看新增操作执行前的数据对象:$model
  echo &#39;查看新增操作执行前的数据对象:<br />&#39;;
  dump($data_before);
  //5.将数据对象原始数据写入数据表中,返回影响记录数
//allowField(true)过滤post数组中的非数据表字段数据
  $affected = $model -> allowField(true) -> save(); 
  //6.获取新增操作执行后:数据对象原始数据
  $data_after = $model -> getData();
  //7.查看新增操作执行后的数据对象:$model
  echo &#39;查看新增操作执行后的数据对象:<br />&#39;;
  dump($data_after);
  //8. 获取新增记录的主键id,等价于: $model -> id 
  $insert_ID = $affected ? $data_after[&#39;id&#39;] : null;
  //6.验证是否新增成功
  echo $affected ? &#39;新增成功!新记录主键id是:&#39;.$insert_ID : &#39;新增失败!&#39;;    
  }
}

save() 메소드

class Index {
  public function index(){
  //1.创建数据:与表中字段对应
  $data = [];
  $data[&#39;name&#39;] = &#39;周星星&#39;;
  $data[&#39;sex&#39;] = 1;
  $data[&#39;age&#39;] = 39;
  $data[&#39;salary&#39;] = 3500;
  $data[&#39;dept&#39;] = 3;
  $data[&#39;hiredate&#39;] = date(&#39;Y-m-d&#39;,time());
  $model = new Staff();
$affected = $model -> allowField(true) -> save($data); 
  $data[&#39;name&#39;] = &#39;周星星&#39;;
  $data[&#39;sex&#39;] = 1;
  $data[&#39;age&#39;] = 39;
  $data[&#39;salary&#39;] = 3000;
  $data[&#39;dept&#39;] = 3;
  $data[&#39;hiredate&#39;] = date(&#39;Y-m-d&#39;,time());
$affected = $model -> allowField(true)
                           -> setAttr(&#39;id&#39;,null)  //清空ID
                           -> isUpdate(false)     //显式指定新增
                           -> save($data);

추천 학습: "PHP 비디오 튜토리얼"

위 내용은 thinkphp5에서 저장 메소드를 사용하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.