新增单条数据:save( )方法
1. 功能:向指定数据表中添加一条记录
该方法每次仅能向表中添加一条新记录,添加多条可重复执行,不过后面要学习的saveAll()可一次性添加多条
2. 源码:/thinkphp/library/think/Model.php
save方法是Model类中较复杂的方法之一,因为save方法身兼多职,不仅用于新增,还可以用于更新数据。
4. 基本语法:
格式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);
~~~
* * * * *
参考链接:https://www.kancloud.cn/ldkt/tp5_model/237110
- 目录
- 5.0.10环境配置
- 5.0.10控制器模型对象
- 5.0.10模型初始化
- 5.0.10定义数据对象
- 5.0.10创建数据对象data()方法
- 5.0.10创建数据对象-setAttr方法
- 5.0.10创建数据对象__set()方法
- 5.0.10查询数据对象getData()
- 实例
- 5.0.10保存数据save()方法
- 5.0.10保存数据saveAll()
- 5.0.10更新数据save()
- 5.0.10批量更新数据saveAll()
- 5.0.10删除数据delete()
- 5.0.10删除数据destroy()
- 5.0.10traits详解
- ThinkPHP 5.0 速查表
- 注释
- 环境变量配置
- Model分层
- MVC 逻辑服务数据
- Model分层及多对多关联的建立
- 控制器调用逻辑层
- Session
- 子域名session共享
- 系统错误
- 版本错误
- 返回错误
- Token令牌及身份识别
- 关联查询
- 安装
- Git安装
- Composer
- 扩展
- Composer类
- 非Composer类
- 引用第三方库
- 自定义命令行
- 计划任务
- 调试
- 调试模式
- 监听SQL
- 数据库调试
- 单元测试
- 初始化
- 控制器初始化
- 模型初始化
- 数据缓存
- 实战
- 版本升级
- 从V5.0.17升级到V5.0.18