千家信息网

thinkphp5中save方法如何用

发表于:2025-01-18 作者:千家信息网编辑
千家信息网最后更新 2025年01月18日,本文小编为大家详细介绍"thinkphp5中save方法如何用",内容详细,步骤清晰,细节处理妥当,希望这篇"thinkphp5中save方法如何用"文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入
千家信息网最后更新 2025年01月18日thinkphp5中save方法如何用

本文小编为大家详细介绍"thinkphp5中save方法如何用",内容详细,步骤清晰,细节处理妥当,希望这篇"thinkphp5中save方法如何用"文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。

在thinkphp5中,save()方法用于向指定数据表中添加一条记录,该方法每次仅能向表中添加一条新记录,添加多条可重复执行,语法为"模型对象 -> save(数组)"或"模型对象 -> data(数组) -> save();"。

本文操作环境:Windows10系统、ThinkPHP5版、Dell G3电脑。

thinkphp5中save方法怎么用

新增单条数据:save( )方法

功能:向指定数据表中添加一条记录

该方法每次仅能向表中添加一条新记录,添加多条可重复执行,不过后面要学习的saveAll()可一次性添加多条

save方法是Model类中较复杂的方法之一,因为save方法身兼多职,不仅用于新增,还可以用于更新数据。

基本语法:

格式1:将数据直接写在save方法参数中

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

格式2:先生成数据对象,然后用save方法直接写入表中

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

这二种语法都可以完成新增操作。但是第二种语法结构更加清晰,可读性好,修改更加方便。

 data($data);  //3.获取新增操作执行前:数据对象原始数据  $data_before = $model -> getData();  //4.查看新增操作执行前的数据对象:$model  echo '查看新增操作执行前的数据对象:
'; dump($data_before); //5.将数据对象原始数据写入数据表中,返回影响记录数//allowField(true)过滤post数组中的非数据表字段数据 $affected = $model -> allowField(true) -> save(); //6.获取新增操作执行后:数据对象原始数据 $data_after = $model -> getData(); //7.查看新增操作执行后的数据对象:$model echo '查看新增操作执行后的数据对象:
'; 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);

读到这里,这篇"thinkphp5中save方法如何用"文章已经介绍完毕,想要掌握这篇文章的知识点还需要大家自己动手实践使用过才能领会,如果想了解更多相关内容的文章,欢迎关注行业资讯频道。

0