data(array)->save();"。"/> data(array)->save();"。">

ホームページ >PHPフレームワーク >ThinkPHP >thinkphp5でsaveメソッドを使用する方法

thinkphp5でsaveメソッドを使用する方法

WBOY
WBOYオリジナル
2022-02-18 14:57:545484ブラウズ

thinkphp5 では、save() メソッドは、指定されたデータ テーブルにレコードを追加するために使用されます。このメソッドでは、一度に 1 つの新しいレコードのみをテーブルに追加できます。複数のレコードの追加は繰り返すことができます。構文「モデル オブジェクト -> save(array)」または「モデル オブジェクト -> データ (配列) -> save();」です。

thinkphp5でsaveメソッドを使用する方法

この記事の動作環境: Windows 10 システム、ThinkPHP バージョン 5、Dell G3 コンピューター。

thinkphp5 で save メソッドを使用する方法

単一のデータを追加します: save() メソッド

関数: 指定されたデータ テーブルにレコードを追加します

The メソッドでは、一度に 1 つの新しいレコードのみをテーブルに追加できます。複数のレコードの追加を繰り返すことができます。ただし、後で学習する saveAll() は、一度に複数のレコードを追加できます。

ソースコード: /thinkphp/library/think/Model .php

save メソッドは、新しいデータを追加するだけでなく、複数の役割を果たすため、Model クラスのより複雑なメソッドの 1 つです。データ更新用。

基本構文:

形式 1: save メソッドのパラメーターにデータを直接書き込みます。

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

形式 2: 最初にデータ オブジェクトを生成し、次に save メソッドを使用してテーブルに直接書き込みます。 これら 2 つの構文

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

は両方とも、新しい操作を完了できます。しかし、2 番目の文法構造はより明確で読みやすく、修正するのがより便利です。

<?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でsaveメソッドを使用する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。