过期知识:thinkphp5 使用migrate给现有的数据表新增表字段

个人开发网站记录, 这个文章主要是个以后健忘的我看的.

我在搞我的画笔审核 , 发现数据表的画笔数据在审核驳回的时候还是软删除好一些,

免得用户找不到之前上传的画笔数据, 后期也可以考虑重新显示给用户,让用户可以修改画笔信息重新提交审核.

这个时候想起了thinkphp5 框架提供的软删除功能, 不过使用软删除时发现 我当时设计画笔表结构没有考虑到delete_time字段设置, 怪不得在使用软删除时,就觉得又会报错, 没字段,怎么能在数据表区分数据呢, 真觉得的自己时傻冒.

考虑到自己是使用migrate数据库迁移工具创建数据表的, 我如果手动在数据表用sql语句修改表结构, 到时候后面为将来新功能加新的数据表, 又会run报错. 以前不明白,现在总算明白run不成功的原因了.

怎么用migrate给现有的数据表(已有数据)新增表字段,来实现软删除.

先看我找到的指导文档ThinkPHP官方手册,(我这个找不到以前大佬的代码评论,我记得另一个官方手册有以前的大佬的代码评论)

根据示例代码, 我给我的temphuabi临时画笔表开启了软删除功能,

复制代码
<?php
namespace app\api\model;
use think\Model;
use think\model\concern\SoftDelete;

class TempHuabi extends Model
{
    use SoftDelete;
    protected $deleteTime = 'delete_time';
    protected $defaultSoftDelete = 0;
}

然后查询到对应的画笔数据

temp_huabi = TempHuabiModel::where('status', 0)-\>where('id', temp_huabi_id)->find();

$temp_huabi->delete(); //软删除

测试审核驳回接口,出现报错, 找不到我temp_huabi数据表的delete_time字段, (哦,原来表结构要有delete_time这个字段才能软删除)
SQLSTATE[42S22]: Column not found: 1054 Unknown column 'ptx_temp_huabi.delete_time' in 'where clause'

为了不影响将来迁移创建新数据表, (结合查询文心与通义ai, 无意中发现的解决方案, ai给来给去都是不符合我的实际 , 不过通义它给了update(),我试了一下,发现使用中能被注释出来, 这代表能用. )

这里我创建多一个新的实例, 为了提醒, UpdataTempHuabi说明是更新TempHuabi数据表,

php think migrate:create UpdataTempHuabi

接下来在****_updata_temp_huabi.php文件中,

选择现有的TempHuabi表,用update更新即可

复制代码
 public function change()
    {
        $this->table('temp_huabi')   // 添加 delete_time 列
            ->addColumn('delete_time', 'integer', ['null' => true, 'default' => 0, 'comment' => '删除时间戳'])
            ->update();
    }

run运行迁移就行,这迁移没有出来错误.

php think migrate:run

显然已经更新了表结构了, 但是这个int(11)我感觉不怎么好 ,不过它确实给我现有的表数据都插多了这个字段,

但是实际使用软删除功能,没有成功, 报错为空,

果然是上面时间戳类型设置错误了, 我应该跟 ->addTimestamps()一样用这个类型,

之前设置的字段删除,在迁移记录表中删除这一条数据 修正如下,应该用timestamp, 我真蠢, 类型设错,时间戳怎么放

复制代码
  public function change()
    {
        $this->table('temp_huabi')   // 添加 delete_time 列
            ->addColumn('delete_time', 'timestamp', ['null' => true,  'comment' => '删除时间戳'])
            ->update();
    }

软删除delete一下,哦,删除时间戳总算出现了

再次查阅ThinkPHP官方手册,看到最下面的代码,,,,,,,

突然觉得我用迁移工具更新数据表字段delete_time的代码,

应该放在up还是down方法里面, 而不是新建一个迁移文件, 虽然都能用, ,,,

暂时保留疑问

相关推荐
zx28596340016 小时前
Laravel 8.x 核心特性全面解析
php·laravel
Gh0st_Lx18 小时前
【6】为什么有了 HTTP/1.1 ,还要 HTTP/2 和 HTTP/3
网络协议·http·php
xingpanvip18 小时前
星盘接口开发文档:组合三限盘接口指南
android·开发语言·前端·python·php·lua
灰子学技术20 小时前
Envoy TCP 层面的 Metric 指标分析
开发语言·网络·网络协议·tcp/ip·php
Johnstons20 小时前
TCP Reset(RST)异常是什么?一文讲透连接被动中断的识别方法、适用场景、与超时断开的边界及排查清单
网络协议·tcp/ip·php·es·抓包分析
REDcker1 天前
Linux信号机制详解 POSIX语义与内核要点 sigaction与备用栈实践
linux·运维·php
REDcker1 天前
浏览器端Web程序性能分析与优化实战 DevTools指标与工程清单
开发语言·前端·javascript·vue·ecmascript·php·js
云云只是个程序马喽1 天前
AI漫剧创作系统开发定制指南
人工智能·小程序·php
niucloud-admin2 天前
PHP V6 单商户常见问题——云编译报错处理
php
xxjj998a2 天前
Laravel 1.x:PHP框架的原始魅力
android·php·laravel