当前位置: 首页 > news >正文

帮人做网站在徐州被敲诈五万免费制作网页的网站

帮人做网站在徐州被敲诈五万,免费制作网页的网站,三室二厅二卫装修全套效果图,秦皇岛今日头条新闻个人开发网站记录, 这个文章主要是个以后健忘的我看的. 我在搞我的画笔审核 , 发现数据表的画笔数据在审核驳回的时候还是软删除好一些, 免得用户找不到之前上传的画笔数据, 后期也可以考虑重新显示给用户,让用户可以修改画笔信息重新提交审核. 这个时候想起了…

个人开发网站记录, 这个文章主要是个以后健忘的我看的.
        我在搞我的画笔审核 , 发现数据表的画笔数据在审核驳回的时候还是软删除好一些, 
免得用户找不到之前上传的画笔数据, 后期也可以考虑重新显示给用户,让用户可以修改画笔信息重新提交审核.
        这个时候想起了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方法里面, 而不是新建一个迁移文件, 虽然都能用, ,,,
暂时保留疑问

http://www.tj-hxxt.cn/news/79294.html

相关文章:

  • 宿迁沭阳网站建设域名服务器ip查询网站
  • 什么样的公司开做网站北京网络营销外包公司哪家好
  • seo有哪些作用seo交流群
  • 潍坊企化网站建设网站维护的主要内容
  • 马鞍山网站建设开发营销策划书模板范文
  • 中小企业网站的建设实践报告seo做得比较好的企业案例
  • 做网站上海公司微信小程序开发流程
  • 做水果网站需要多钱免费网站搭建平台
  • 推荐一个可以做ppt的网站免费网站推广群发软件
  • 手机网站制作方案网站页面关键词优化
  • 做电子章网站百度推广怎么联系
  • 一个网站两个空间建立网站用什么软件
  • 做淘宝客最大的网站是叫什么名字seo云优化如何
  • 做网站的书籍快排seo排名软件
  • 好康的网站代码广州新闻报道
  • wordpress参数传递的函数网页优化方法
  • 做色情网站的人是怎么被抓的西安网站seo费用
  • 个人主页网站设计代码好看的seo网站
  • 老板合作网站开发seo检测
  • 织梦做单页面网站如何做一个自己的网站
  • 新疆生产建设兵团领导班子本地网络seo公司
  • 河间做网站做app推广去哪找商家
  • 做喷绘可以在那个网站找搜索引擎优化的重要性
  • 做网站会什么最新推广方法
  • 网站区域名是什么国家免费职业培训平台
  • 网站域名属于哪里管新东方厨师学费价目表
  • 网站建设完善方案做推广的都是怎么推
  • 哪些网站做彩票预测途径今日最新重大新闻
  • 怎么看网站使用什么做的网店运营工作内容
  • 网站平台需要做无形资产吗 怎么做6seo基础知识