在thinkphp5中,save()方法用於在指定資料表中新增一筆記錄,該方法每次僅能在表中新增一筆新記錄,新增多個可重複執行,語法為「模型物件-> save(數組)”或“模型物件-> data(數組) -> save();”。
本文操作環境:Windows10系統、ThinkPHP5版、Dell G3電腦。
新增單一資料:save( )方法
功能:在指定資料表中新增一筆記錄
該方法每次只能在表中新增一筆新記錄,新增多條重複執行,不過後面要學習的saveAll()可一次新增多條
原始碼:/thinkphp/library/think/Model .php
save方法是Model類別中較複雜的方法之一,因為save方法身兼多職,不僅用於新增,還可用於更新資料。
基本語法:
格式1:將資料直接寫在save方法參數中
模型对象 -> save(数组);
格式2:先生成資料對象,然後用save方法直接寫入表中
模型对象 -> data(数组) -> save();
這二種語法都可以完成新增操作。但是第二種文法結構更清晰,可讀性好,修改更方便。
<?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中文網其他相關文章!