0

0

Oracle与MySQL删除字段时的处理对照_MySQL

php中文网

php中文网

发布时间:2016-06-01 13:59:50

|

1198人浏览过

|

来源于php中文网

原创


不知道有多少人清楚的知道,在Oracle中,如果一个复合索引,假定索引(a,b,c)三个字段,删除了(包括unused)其中一个字段,Oracle会怎么处理这个索引。同样,如果是约束,Oracle又怎么处理?

oracle为例子,我又拿mysql做了一个对比,看看mysql是怎么处理这个问题的。我这里不讨论谁好谁差,只是希望大家知道其中的差别与细节而已。

我们先看Oracle的例子,我们创建一个表,然后在上面创建一个约束,创建一个索引:

SQL 10G>create table test(a int,b int,c int); Table created. SQL 10G>alter table test add constraint pk_test primary key (a,b); Table altered. SQL 10G>create index ind_test on test(b,c); Index created. 


然后,我们检查刚才创建的约束与索引

SQL 10G>select t.constraint_name,c.constraint_type,t.column_name,t.position,c.status,c.validated 2 from user_cons_columns t,user_constraints c 3 where c.constraint_name=t.constraint_name 4 and c.constraint_type != 'C' 5 and t.table_name = 'TEST' 6 order by constraint_name,position; CONSTRAINT_NAME C COLUMN_NAME POSITION STATUS VALIDATED ---------------- - ------------ ---------- -------- ------------- PK_TEST P A 1 ENABLED VALIDATED PK_TEST P B 2 ENABLED VALIDATED SQL 10G>select t.index_name,t.column_name,t.column_position,i.status 2 from user_ind_columns t,user_indexes i 3 where t.index_name=i.index_name 4 and t.table_name = 'TEST' 5* order by index_name,column_position INDEX_NAME COLUMN_NAME COLUMN_POSITION STATUS -------------- ------------ --------------- -------- IND_TEST B 1 VALID IND_TEST C 2 VALID 

 

现在,我们先删除索引上的字段,其实并没有物理删除,只是设置为unused:

SQL 10G>ALTER TABLE test SET UNUSED (c); Table altered. SQL 10G>select t.index_name,t.column_name,t.column_position,i.status 2 from user_ind_columns t,user_indexes i 3 where t.index_name=i.index_name 4 and t.table_name = 'TEST' 5 order by index_name,column_position; no rows selected 

发现了什么,索引也删除了。那我们再删除约束上的字段呢?

Dora
Dora

创建令人惊叹的3D动画网站,无需编写一行代码。

下载

SQL 10G>ALTER TABLE test SET UNUSED (b); ALTER TABLE test SET UNUSED (b) * ERROR at line 1: ORA-12991: column is referenced in a multi-column constraint SQL 10G>ALTER TABLE test SET UNUSED (b) CASCADE CONSTRAINTS; Table altered. SQL 10G>select t.constraint_name,c.constraint_type,t.column_name,t.position,c.status,c.validated 2 from user_cons_columns t,user_constraints c 3 where c.constraint_name=t.constraint_name 4 and c.constraint_type != 'C' 5 and t.table_name = 'TEST' 6 order by constraint_name,position; no rows selected 


我们可以看到,正常的删除会报一个错误,如果我们指定了cascade,将会把对应的约束也删除。

我们看完了Oracle的处理过程,再看看mysql是这么处理删除索引上字段这个事情的

mysql> create table test(a int,b int,c int); Query OK, 0 rows affected (0.72 sec) mysql> alter table test add primary key(a,b); Query OK, 0 rows affected (0.27 sec) Records: 0 Duplicates: 0 Warnings: 0 mysql> create index ind_test on test(b,c); Query OK, 0 rows affected (0.32 sec) Records: 0 Duplicates: 0 Warnings: 0 


我们执行同样的操作,先删除复合索引中的一个字段,然后删除约束中的一个字段。

mysql> alter table test drop c; Query OK, 0 rows affected (0.58 sec) Records: 0 Duplicates: 0 Warnings: 0 mysql> show index from test; +-------+------------+----------+--------------+-------------+-----------+ | Table | Non_unique | Key_name | Seq_in_index | Column_name | Collation | +-------+------------+----------+--------------+-------------+-----------+ | test | 0 | PRIMARY | 1 | a | A | | test | 0 | PRIMARY | 2 | b | A | | test | 1 | ind_test | 1 | b | A | +-------+------------+----------+--------------+-------------+-----------+ 3 rows in set (0.06 sec) mysql> alter table test drop b; Query OK, 0 rows affected (0.28 sec) Records: 0 Duplicates: 0 Warnings: 0 mysql> show index from test; +-------+------------+----------+--------------+-------------+-----------+ | Table | Non_unique | Key_name | Seq_in_index | Column_name | Collation | +-------+------------+----------+--------------+-------------+-----------+ | test | 0 | PRIMARY | 1 | a | A | +-------+------------+----------+--------------+-------------+-----------+ 1 row in set (0.03 sec) 

可以看到,mysql的处理方式是有差别的,mysql仅仅是把字段从索引中拿掉,而不是删除该索引。

本文的意思,就是想提醒大家,平常在做columns删除的时候,包括unused,一定要小心,是否有复合索引包含了该字段,否则,一不小心把索引删除了,可能将引发大的错误

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
全国统一发票查询平台入口合集
全国统一发票查询平台入口合集

本专题整合了全国统一发票查询入口地址合集,阅读专题下面的文章了解更多详细入口。

4

2026.02.03

短剧入口地址汇总
短剧入口地址汇总

本专题整合了短剧app推荐平台,阅读专题下面的文章了解更多详细入口。

9

2026.02.03

植物大战僵尸版本入口地址汇总
植物大战僵尸版本入口地址汇总

本专题整合了植物大战僵尸版本入口地址汇总,前往文章中寻找想要的答案。

6

2026.02.03

c语言中/相关合集
c语言中/相关合集

本专题整合了c语言中/的用法、含义解释。阅读专题下面的文章了解更多详细内容。

2

2026.02.03

漫蛙漫画网页版入口与正版在线阅读 漫蛙MANWA官网访问专题
漫蛙漫画网页版入口与正版在线阅读 漫蛙MANWA官网访问专题

本专题围绕漫蛙漫画(Manwa / Manwa2)官网网页版入口进行整理,涵盖漫蛙漫画官方主页访问方式、网页版在线阅读入口、台版正版漫画浏览说明及基础使用指引,帮助用户快速进入漫蛙漫画官网,稳定在线阅读正版漫画内容,避免误入非官方页面。

5

2026.02.03

Yandex官网入口与俄罗斯搜索引擎访问指南 Yandex中文登录与网页版入口
Yandex官网入口与俄罗斯搜索引擎访问指南 Yandex中文登录与网页版入口

本专题汇总了俄罗斯知名搜索引擎 Yandex 的官网入口、免登录访问地址、中文登录方法与网页版使用指南,帮助用户稳定访问 Yandex 官网,并提供一站式入口汇总。无论是登录入口还是在线搜索,用户都能快速获取最新稳定的访问链接与使用指南。

39

2026.02.03

Java 设计模式与重构实践
Java 设计模式与重构实践

本专题专注讲解 Java 中常用的设计模式,包括单例模式、工厂模式、观察者模式、策略模式等,并结合代码重构实践,帮助学习者掌握 如何运用设计模式优化代码结构,提高代码的可读性、可维护性和扩展性。通过具体示例,展示设计模式如何解决实际开发中的复杂问题。

2

2026.02.03

C# 并发与异步编程
C# 并发与异步编程

本专题系统讲解 C# 异步编程与并发控制,重点介绍 async 和 await 关键字、Task 类、线程池管理、并发数据结构、死锁与线程安全问题。通过多个实战项目,帮助学习者掌握 如何在 C# 中编写高效的异步代码,提升应用的并发性能与响应速度。

2

2026.02.03

Python 强化学习与深度Q网络(DQN)
Python 强化学习与深度Q网络(DQN)

本专题深入讲解 Python 在强化学习(Reinforcement Learning)中的应用,重点介绍 深度Q网络(DQN) 及其实现方法,涵盖 Q-learning 算法、深度学习与神经网络的结合、环境模拟与奖励机制设计、探索与利用的平衡等。通过构建一个简单的游戏AI,帮助学习者掌握 如何使用 Python 训练智能体在动态环境中作出决策。

2

2026.02.03

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
SQL 教程
SQL 教程

共61课时 | 3.7万人学习

Java 教程
Java 教程

共578课时 | 56.5万人学习

oracle知识库
oracle知识库

共0课时 | 0人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号