根据数据库表字段删除所有相关信息(删库)

需求:每当项目上线前,都要测试一番,产品经理自己瞎操作一波后会来找后台,给我把有关XXX的数据都删除了,然后你就去操作数据库,把有关的数据删除!!

代码思路如下:

/**
     * @param $field_name /字段名
     * @param $field_value /字段值
     * @throws \think\db\exception\BindParamException
     * @throws \think\exception\PDOException
     */
    public function fieldDel($field_name,$field_value)
    {
        $table = BaseModel::getInstance()->query('show tables');//获取数据库所有表
        foreach ($table as $key=>$value){
            //$value['Tables_in_表名']长这个样子:xyb_xxx_xxx
            $table_name = explode("_",$value['Tables_in_xyb123']);//切割表名为数组
            $model = '';
            for($i = 1;$i < count($table_name); $i++){//$i=1从1开始,去除表前缀
                $model .= ucfirst($table_name[$i]);//去除前缀的表名
            }
            $table_model = "\\app\\common\\model\\".$model.'Model';//拼接模型的命名空间(注:不能直接用字符串实例模型)
            $table_data = (new $table_model)->getInstance()->find();//实例并查询(这里也可以用获取表字段结构的方式,但个人感觉查询更方便)
            if(isset($table_data[$field_name])){//如果表存在$field_name字段
                (new $table_model)->getInstance()->where([$field_name=>$field_value])->delete();//删除
            }
            //如果需要把自己也干掉的话
            $myself = explode("_",$field_name);
            $myself_table = ucfirst($myself[0]);
            if($model == $myself_table){
                (new $table_model)->getInstance()->where(['id'=>$field_value])->delete();//删除自己
            }
        }
        $this->displayBySuccess();//结束
    }

 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章