thinkphp5中save方法怎么用
在thinkphp5中,save()方法用于向指定数据表中添加一条记录,该方法每次仅能向表中添加一条新记录,添加多条可重复执行,语法为“模型对象 -> save(数组)”或“模型对象 -> data(数组) -> save();”。
本文操作环境:Windows10系统、ThinkPHP5版、Dell G3电脑。
thinkphp5中save方法怎么用
新增单条数据: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中文网其它相关文章!
下一篇:没有了
免责声明:本站所有文章和图片均来自用户分享和网络收集,文章和图片版权归原作者及原出处所有,仅供学习与参考,请勿用于商业用途,如果损害了您的权利,请联系网站客服处理。
来源:网友投稿 关注:
时间:2022-02-18 16:04
☉首先声明,只要是我们的vip会员所有源码均可以免费下载,不做任何限制(了解更多)
☉本站的源码不会像其它下载站一样植入大量的广告。为了更好的用户体验以后坚持不打水印
☉本站只提供精品织梦源码,源码在于可用,不在多!!希望在这里找到你合适的。
☉本站提供的整站织梦程序,均带数据及演示地址。可以在任一源码详情页查看演示地址
☉本站所有资源(包括源码、模板、素材、特效等)仅供学习与参考,请勿用于商业用途。
☉如有其他问题,请加网站客服QQ进行交流。
☉本站的源码不会像其它下载站一样植入大量的广告。为了更好的用户体验以后坚持不打水印
☉本站只提供精品织梦源码,源码在于可用,不在多!!希望在这里找到你合适的。
☉本站提供的整站织梦程序,均带数据及演示地址。可以在任一源码详情页查看演示地址
☉本站所有资源(包括源码、模板、素材、特效等)仅供学习与参考,请勿用于商业用途。
☉如有其他问题,请加网站客服QQ进行交流。
相关织梦教程: