data(array)->save();"。"/> data(array)->save();"。">
ホームページ >PHPフレームワーク >ThinkPHP >thinkphp5でsaveメソッドを使用する方法
thinkphp5 では、save() メソッドは、指定されたデータ テーブルにレコードを追加するために使用されます。このメソッドでは、一度に 1 つの新しいレコードのみをテーブルに追加できます。複数のレコードの追加は繰り返すことができます。構文「モデル オブジェクト -> save(array)」または「モデル オブジェクト -> データ (配列) -> save();」です。
この記事の動作環境: Windows 10 システム、ThinkPHP バージョン 5、Dell G3 コンピューター。
単一のデータを追加します: 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['name'] = '周星星'; $data['sex'] = 1; $data['age'] = 39; $data['salary'] = 3500; $data['dept'] = 3; $data['hiredate'] = date('Y-m-d',time()); //2.创建数据对象 $model = (new Staff())-> data($data); //3.获取新增操作执行前:数据对象原始数据 $data_before = $model -> getData(); //4.查看新增操作执行前的数据对象:$model echo '查看新增操作执行前的数据对象:<br />'; dump($data_before); //5.将数据对象原始数据写入数据表中,返回影响记录数 //allowField(true)过滤post数组中的非数据表字段数据 $affected = $model -> allowField(true) -> save(); //6.获取新增操作执行后:数据对象原始数据 $data_after = $model -> getData(); //7.查看新增操作执行后的数据对象:$model echo '查看新增操作执行后的数据对象:<br />'; dump($data_after); //8. 获取新增记录的主键id,等价于: $model -> id $insert_ID = $affected ? $data_after['id'] : null; //6.验证是否新增成功 echo $affected ? '新增成功!新记录主键id是:'.$insert_ID : '新增失败!'; } }
save() メソッド
class Index { public function index(){ //1.创建数据:与表中字段对应 $data = []; $data['name'] = '周星星'; $data['sex'] = 1; $data['age'] = 39; $data['salary'] = 3500; $data['dept'] = 3; $data['hiredate'] = date('Y-m-d',time()); $model = new Staff(); $affected = $model -> allowField(true) -> save($data); $data['name'] = '周星星'; $data['sex'] = 1; $data['age'] = 39; $data['salary'] = 3000; $data['dept'] = 3; $data['hiredate'] = date('Y-m-d',time()); $affected = $model -> allowField(true) -> setAttr('id',null) //清空ID -> isUpdate(false) //显式指定新增 -> save($data);
推奨学習: 「PHP ビデオ チュートリアル 」
以上がthinkphp5でsaveメソッドを使用する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。