怎么新建MySQL数据库

发布时间:2022-07-23 作者:admin
阅读:462
很多朋友都对“ThinkPHP中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);

感谢各位的阅读,以上就是“ThinkPHP中save方法的功能是什么,怎样用”的内容了,经过本文的学习后,相信大家对ThinkPHP中save方法的功能是什么,怎样用都有更深刻的体会了吧。这里是群英网络,小编将为大家推送更多相关知识点的文章,欢迎关注!

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。

二维码-群英

长按识别二维码并关注微信

更方便到期提醒、手机管理

7*24 全天候服务

售前 400-678-4567

售后 0668-2555666

售后 400 678 4567

信息安全 0668-2555 118

域名空间 3004329145