需求:每当项目上线前,都要测试一番,产品经理自己瞎操作一波后会来找后台,给我把有关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();//结束
}