ThinkPHP中save方法的功能是什么,怎样用
Admin 2022-07-23 群英技术资讯 1174 次浏览
很多朋友都对“ThinkPHP中save方法的功能是什么,怎样用”的内容比较感兴趣,对此小编整理了相关的知识分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获,那么感兴趣的朋友就继续往下看吧!在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);
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
许多人都说算法是程序的核心,算法的好坏决定了程序的质量。作为一个初学者,虽然很少接触到算法方面的东西。但是对于基本的排序算法还是应该掌握的,它是程序开发的必备...
php中页面跳转的方法:1、在php脚本中添加代码header("location:url地址")即可;2、如果要延迟跳转,比如登陆成功后会有几秒钟等待时间,代码为header("Refresh:秒数;url=地址")。
本文介绍通过PDO扩展与MySQL数据库交互实现基本使用。
我们知道PHP中很多数组排序函数,之前我们了解升序排序sort函数,这篇文章就带大家了解一下降序排序rsort函数,降序排序就是从高到低排序,可见rsort函数和sort函数是相反,那么语法和返回值会有所不同吗?下面我们来具体看看rsort函数以及实例
PHP论坛实现积分系统的思路代码详解,首先在用户表定义一个积分字段;然后创建一个等级表,主要字段有等级名,上限积分和下限积分;再根据用户的行为进行积分累加;最后根据判断用户积分在哪个等级
成为群英会员,开启智能安全云计算之旅
立即注册关注或联系群英网络
7x24小时售前:400-678-4567
7x24小时售后:0668-2555666
24小时QQ客服
群英微信公众号
CNNIC域名投诉举报处理平台
服务电话:010-58813000
服务邮箱:service@cnnic.cn
投诉与建议:0668-2555555
Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 ICP核准(ICP备案)粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008