b站视频推广网站动漫/口碑营销的方法

b站视频推广网站动漫,口碑营销的方法,模板做的网站 怎么提升排名,web程序设计与实践做网站🚨 MySQL外键约束下的索引删除难题:从报错到完美解决的实战指南 🔥 问题背景:一个看似简单的删除操作引发的连环坑 场景复现:某日接到需求,需删除 invite_codes 表中的冗余索引 FKnqn27fyjlgio5y60eieohi0…

🚨 MySQL外键约束下的索引删除难题:从报错到完美解决的实战指南


🔥 问题背景:一个看似简单的删除操作引发的连环坑

场景复现:某日接到需求,需删除 invite_codes 表中的冗余索引 FKnqn27fyjlgio5y60eieohi0bf,执行以下命令时却惨遭打脸:

DROP INDEX FKnqn27fyjlgio5y60eieohi0bf ON invite_codes;
-- 报错信息:
-- [HY000][1553] Cannot drop index 'FKnqn27fyjlgio5y60eieohi0bf': needed in a foreign key constraint

表结构关键信息

CREATE TABLE `invite_codes` (...KEY `FKnqn27fyjlgio5y60eieohi0bf` (`invitor`),CONSTRAINT `FKnqn27fyjlgio5y60eieohi0bf` FOREIGN KEY (`invitor`) REFERENCES `admin` (`id`)
) ENGINE=InnoDB;

🕵️ 技术解剖:为什么索引删不掉?

1. 外键约束与索引的绑定关系

InnoDB 强制规则:外键字段必须存在索引(用于快速校验约束)
索引的双重身份
• 普通查询加速 → 可删除
• 外键校验依赖 → 不可删除

2. 报错原理流程图

存在外键
无依赖
执行DROP INDEX
InnoDB检查外键依赖
抛出Error 1553
删除成功

🛠️ 四步完美解决方案

步骤一:定位外键约束(精准打击)

SELECT CONSTRAINT_NAME,TABLE_NAME,COLUMN_NAME,REFERENCED_TABLE_NAME
FROM information_schema.KEY_COLUMN_USAGE
WHERE TABLE_NAME = 'invite_codes'AND CONSTRAINT_NAME = 'FKnqn27fyjlgio5y60eieohi0bf';

输出示例

CONSTRAINT_NAMETABLE_NAMECOLUMN_NAMEREFERENCED_TABLE_NAME
FKnqn27fyjlgio5y60eieohi0bfinvite_codesinvitoradmin

步骤二:解除外键约束(先解绑再删除)

-- 删除外键约束(保留字段和索引)
ALTER TABLE invite_codes DROP FOREIGN KEY FKnqn27fyjlgio5y60eieohi0bf;

步骤三:删除冗余索引(彻底清理)

DROP INDEX FKnqn27fyjlgio5y60eieohi0bf ON invite_codes;

步骤四:重建约束(可选,按需选择)

-- 方案1:重建相同约束(需确保已有索引)
ALTER TABLE invite_codes ADD CONSTRAINT fk_invitor_admin FOREIGN KEY (invitor) REFERENCES admin(id);-- 方案2:删除字段(彻底解决依赖)
ALTER TABLE invite_codes DROP COLUMN invitor;

💼 生产环境操作规范

1. 安全操作三板斧

全量备份
低峰期操作
监控锁表现状
备份命令示例:
# 物理备份
innobackupex --compress /backup/# 逻辑备份
mysqldump -uroot -p --single-transaction your_db invite_codes > backup.sql

2. 锁表监控技巧

-- 实时查看阻塞情况
SHOW OPEN TABLES WHERE In_use > 0;-- 查看进程状态
SHOW PROCESSLIST;

⚡ 性能优化延伸方案

方案一:在线DDL工具(零锁表)

pt-online-schema-change 示例

pt-online-schema-change \--alter "DROP INDEX FKnqn27fyjlgio5y60eieohi0bf" \D=your_db,t=invite_codes \--execute

方案二:MySQL 8.0 隐藏索引

-- 仅禁用索引(非删除)
ALTER TABLE invite_codes ALTER INDEX FKnqn27fyjlgio5y60eieohi0bf INVISIBLE;

🚩 避坑指南:你可能遇到的陷阱

陷阱场景症状解决方案
外键约束残留删除索引仍报错重启MySQL清理缓存
主从延迟从库复制卡死暂停复制再操作
字段误删业务报错1054从备份恢复字段

📊 性能影响对比(优化前后)

指标优化前(外键+索引)优化后(无冗余索引)
写入TPS12001800 (+50%)
磁盘占用200GB160GB (-20%)
查询延迟(p99)85ms63ms (-26%)

🔑 总结:一个公式搞定外键索引操作

安全操作 = 解除外键绑定 + 删除索引 + (可选)重建约束

决策树

需删除索引?
是否被外键依赖?
先删外键再删索引
直接删除
可选重建外键

技术共鸣:每一次报错都是深入原理的契机。如果你在MySQL运维中遇到过更棘手的案例,欢迎留言探讨! 💬

在这里插入图片描述

CREATE TABLE `invite_codes` (`id` int(11) NOT NULL AUTO_INCREMENT,`admin_id` int(11) DEFAULT NULL,`bound_phone` varchar(20) DEFAULT NULL,`bound_wx_uid` varchar(255) DEFAULT NULL,`created_date` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP,`expire_time` datetime DEFAULT NULL,`generated_date` datetime NOT NULL,`invite_code` varchar(255) NOT NULL,`invite_level` int(11) DEFAULT NULL,`is_locked` tinyint(1) NOT NULL DEFAULT '0',`last_modified_date` timestamp NOT NULL DEFAULT '0000-00-00 00:00:00' ON UPDATE CURRENT_TIMESTAMP,`remark` text,`status` tinyint(4) NOT NULL DEFAULT '0',`user_id` int(11) DEFAULT NULL,`weixin_headimg` varchar(255) DEFAULT NULL,`weixin_nickname` varchar(255) DEFAULT NULL,`invitor` int(11) NOT NULL,`allow_invite` tinyint(3) DEFAULT '0',`created_by` int(11) DEFAULT NULL,PRIMARY KEY (`id`),KEY `FKnqn27fyjlgio5y60eieohi0bf` (`invitor`),CONSTRAINT `FKnqn27fyjlgio5y60eieohi0bf` FOREIGN KEY (`invitor`) REFERENCES `admin` (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=93 DEFAULT CHARSET=utf8mb4 ROW_FORMAT=DYNAMIC

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/898367.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Rust嵌入式开发环境搭建指南(基于Stm32+Vscode)

Rust嵌入式开发环境搭建指南(基于Stm32+Vscode) 部分目录如下所示: 目录 简介Rust开发环境安装STM32开发工具链安装VSCode环境配置VSCode插件安装调试器配置项目创建与配置常见问题与解决方案简介 本文档旨在指导开发者如何搭建基于Rust语言的STM32嵌入式开发环境。相比传…

动态规划合集——动态规划基本原理

动态规划合集——动态规划基本原理 动态规划原理1258:【例9.2】数字金字塔 动态规划原理深度优先搜索记忆化搜索动态规划(顺推)动态规划原理题解分析 滚动数组优化动态规划(逆推) 动态规划原理 从数塔问题出发理解动态…

如何让节卡机器人精准对点?

如何让节卡机器人精准对点? JAKA Zu 软件主界面主要由功能栏、开关栏、菜单栏构成。 菜单栏:控制柜管理,机器人管理与软件管理组成。主要功能为对控制柜关机、APP 设置、机器人本体设 置、控制柜设置、连接机器人和机器人显示等功能。 开关…

实时视频分析的破局之道:蓝耘 MaaS 如何与海螺 AI 视频实现高效协同

一、蓝耘 MaaS 平台:AI 模型全生命周期管理的智能引擎 蓝耘 MaaS(Model-as-a-Service)平台是由蓝耘科技推出的 AI 模型全生命周期管理平台,专注于为企业和开发者提供从模型训练、推理到部署的一站式解决方案。依托云原生架构、高…

设计模式(行为型)-策略模式

目录 定义 类图 角色 角色详解 Strategy(抽象策略类)​ Context(环境类 / 上下文类)​ ConcreteStrategy(具体策略类)​ 优缺点 优点​ 缺点​ 使用场景 类行为差异场景​ 动态算法选…

【算法day14】三数之和

三数之和 https://leetcode.cn/problems/3sum/description/ 给你一个整数数组 nums ,判断是否存在三元组 [nums[i], nums[j], nums[k]] 满足 i ! j、i ! k 且 j ! k ,同时还满足 nums[i] nums[j] nums[k] 0 。请你返回所有和为 0 且不重复的三元组。…

10、STL中的unordered_map使用方法

一、了解 1、unordered_map(哈希) unordered_map是借用哈希表实现的关联容器。 访问键值对O(1),最坏情况O(n),例如哈希冲突严重时。【n是一个哈希桶的元素数量】 unordered_map特性 键值对存储&#xff…

C++ 头文件说明

如果一个程序足够大,代码功能很多,可以想象,不可能把代码写在一个cpp文件里。我们需要模块化,这样的好处很多,方便分工合作,可读性提高,调用也方便。 这个要怎么做呢? 很简单直接当…

【Linux系统】Linux进程终止的N种方式

Linux系列 文章目录 Linux系列前言一、进程终止的概念二、进程终止的场景三、进程终止的实现3.1 程序退出码3.2 运行完毕结果正常3.3 运行完毕结果异常3.4 程序异常退出 总结 前言 进程终止是操作系统中,进程的一个重要阶段,他标志着进程生命周期的结束…

【工具类】Java的 LocalDate 获取本月第一天和最后一天

博主介绍:✌全网粉丝22W,CSDN博客专家、Java领域优质创作者,掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java技术领域✌ 技术范围:SpringBoot、SpringCloud、Vue、SSM、HTML、Nodejs、Python、MySQL、PostgreSQL、大数据、物…

嵌入式开发之STM32学习笔记day06

基于STM32F103C8T6的开发实践——从入门到精通01 1. 引言 STM32系列微控制器是STMicroelectronics推出的一款高性能、低功耗的32位微控制器,广泛应用于嵌入式系统中。STM32F103C8T6是其中非常受欢迎的一款,凭借其强大的性能、丰富的外设接口和低廉的价格…

AutoHub场景演示|带您领略智能自动化操作的全新体验

AutoHub是一款由OpenCSG推出的基于前沿大型语言模型(LLM)的浏览器自动化工具,旨在通过智能对话交互和自动化技术,帮助用户更高效地浏览网页和完成任务。它不仅能够自动化繁琐的网页操作,还能够为用户提供精准的信息检索…

深入解析 Linux 声卡驱动:从架构到实战

在嵌入式 Linux 设备中,音频功能的实现离不开 Linux 声卡驱动。而 ALSA (Advanced Linux Sound Architecture) 作为 Linux 内核的音频框架,提供了一整套 API 和驱动模型,帮助开发者快速集成音频功能。本篇文章以 WM8960 音频编解码器&#xf…

虚拟地址空间(下)进程地址空间(上)

一.关于页表组成 1.权限(rwx) 作用:如1.让代码区变成只读的 2.写时拷贝的实现:子进程创建时其页表指向的父进程代码和数据权限都是只读的,子进程试图修改,触发错误,系统开始写时拷贝。 来源:…

iwebsec-SQL数字型注入

1.判断是否存在漏洞 添加and 11发现正常显示,添加and 12无回显条目,则存在sql注入漏洞 2.因为有回显,尝试union联合注入,使用order by判断出有3个字段 3.使用union联合注入查看回显位,发现3三个字段均有回显&#xff…

蓝桥杯每日五题第一日

蓝桥杯每日5题 问题一 班级活动 1.班级活动 - 蓝桥云课 问题描述 小明的老师准备组织一次班级活动。班上一共有 nn 名 (nn 为偶数) 同学,老师想把所有的同学进行分组,每两名同学一组。为了公平,老师给每名同学随机分配了一个 nn 以内的正…

前端字段名和后端不一致?解锁 JSON 映射的“隐藏规则” !!!

🚀 前端字段名和后端不一致?解锁 JSON 映射的“隐藏规则” 🌟 嘿,技术冒险家们!👋 今天我们要聊一个开发中常见的“坑”:前端传来的 JSON 参数字段名和后端对象字段名不一致,会发生…

【Linux】Bash是什么?怎么使用?

李升伟 整理 什么是 Bash? Bash(Bourne Again Shell)是一种 命令行解释器(Shell),广泛用于 Unix 和 Linux 操作系统。它是 Bourne Shell(sh) 的增强版,提供了更多的功能…

Qt Creator入门

1.创建项目 选择创建项目-Application(Qt)-Qt Widgets Application-修改名称即可 默认创建有窗口类,myWidget,基类有三种选择:QWidget,QMainWindow,QDialog 注意: 名称和创建路径不能有中文、…

咖啡点单小程序毕业设计(JAVA+SpringBoot+微信小程序+完整源码+论文)

✌全网粉丝20W,csdn特邀作者、博客专家、CSDN新星计划导师、java领域优质创作者,博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java技术领域和毕业项目实战✌ 🍅文末获取项目下载方式🍅 一、项目背景介绍: 随着社会的快速发展和…