`

主键的变更导致索引无法删除

 
阅读更多
create table t(id number,name varchar2(20));
alter table add primary key(id);--主键自动创建索引
create index ind_t_id_name on t(id,name);--创建索引
alter table t disable primary key; --disable时删除自动创建索引
alter table t enable primary key;--有包含主键索引,关联,不再创建
drop index ind_t_id_name; --不可删除(主键需要索引)

分享到:
评论

相关推荐

    数据库主键生成资料资源

    在进行数据库设计时,不仅要关注主键的生成,还要注意主键与其他字段的关系,比如避免使用外键作为主键,防止级联删除带来的风险;同时,也要注意避免过度依赖主键,因为主键只是用来标识记录,不应当承载过多的业务...

    mysql添加索引.pdf

    2. **更新成本上升**:每次数据变更(插入、更新、删除)时,数据库都需要维护索引,大量的索引意味着更高的维护成本。 3. **写操作性能下降**:相对于读操作,写操作通常会受到更多索引的负面影响,因为需要更新更...

    oracle索引开发指南

    =)可能导致索引无法有效利用。例如,查询`SELECT cust_Id, cust_name FROM customer WHERE cust_rating <> 'A'`即使`cust_rating`有索引,也可能导致全表扫描,因为不等于操作通常无法使用索引。 总的来说,理解...

    双主键表从复

    7. **性能影响**:双主键可能导致索引和查询效率降低,因为数据库需要处理更复杂的索引结构。在修改主键时,需要评估这对查询性能的影响,并可能需要重新考虑索引策略。 8. **应用程序兼容性**:如果这个表被应用...

    sybase索引.pdf

    索引的选择技术需要综合考虑诸多因素:查询模式、数据变更频率、磁盘空间、索引维护开销以及对查询性能的影响。在实践中,可以使用SQL Server的查询分析器和性能监视工具来帮助确定哪些索引是必要的,哪些可能是冗余...

    解决Sqlserver2008(sql2008)修改数据表数据类型或主键后,提示无法保存,失败的问题!.doc

    在SQL Server 2008 (包括R2版本)中,有时用户在尝试修改数据表的数据类型或主键设置后,会遇到一个错误提示,表明无法保存所做的更改,导致操作失败。这个问题通常与数据库设计者的一项默认设置有关,即“阻止保存...

    DBA运维之索引.pdf

    索引作为Oracle数据库中非常核心的组件,它能极大地提高数据查询效率,但同样也会占用额外的存储空间,并对数据插入、更新、删除操作产生影响。DBA运维之索引主要讨论了以下五个方面的知识点: 1. 为什么需要索引 ...

    数据库性能常识借鉴.pdf

    4. 避免索引失效:避免在查询条件中使用函数、表达式,这些可能导致索引无法使用。 5. 'IN' 和 'OR' 子句的使用:理解它们如何影响索引的利用率。 在实际应用中,合理设计和使用索引是提高数据库性能的关键。理解...

    Python-Facebook开源在线MySQL表结构变更工具OnlineSchemaChange

    而OSC通过其在线模式,可以在不影响业务运行的前提下执行复杂的表结构变更,如添加、删除或修改列,调整索引等操作。 **2. Python开发** OSC是用Python编写的,利用Python的灵活性和丰富的数据库库,可以方便地与...

    数据库性能常识分享.pdf

    3. 数据变更时,索引维护可能导致速度下降。 索引主要有以下几种类型: 1. 直接创建和间接创建,如通过CREATE INDEX语句直接创建,或通过约束间接创建。 2. 普通索引和唯一性索引,前者无唯一性要求,后者则要求...

    MySQL面试题.docx

    9. **导致索引失效的操作**: - 左模糊或左右模糊匹配。 - 索引列进行函数或表达式计算。 - WHERE子句的OR条件中,非索引列会导致全表扫描。 - 隐式类型转换。 10. **字符串索引策略**: - 完整索引:占用空间...

    mysql修改自增长主键int类型为char类型示例

    需要注意的是,从整数主键转换为字符型主键可能导致性能下降,因为字符类型的比较和索引通常不如整数高效。此外,如果业务中依赖于自增主键生成的顺序,这种转换可能需要对业务逻辑进行相应调整。 在实际操作中,...

    数据库建表原则

    2. **索引维护**:定期分析和优化索引,删除不再使用的索引,创建缺失的索引,避免索引过多导致写操作性能下降。 3. **索引覆盖**:创建覆盖索引,使得查询可以只通过索引完成,无需回表,提高查询效率。 4. **...

    高并发下接口幂等性解决方案.docx

    7. 分布式锁:如果是分布式系统,构建全局唯一索引比较困难,例如唯一性的字段没法确定,这时候可以引入分布式锁,通过第三方的系统(redis 或 zookeeper)。 8. select + insert:并发不高的后台系统,或者一些任务 ...

    mysql面试题 值得学习

    - 范式化设计减少了数据冗余,提高了数据更新速度,但可能导致查询时需要多表关联,不利于索引优化。 - 反范式化通过冗余数据提高查询性能,减少表关联,但增加了数据维护难度。实践中,通常需要根据实际情况平衡...

    数据库面试题目(很全面哦)

    - 对于在线事务处理(OLTP)表,过多的索引会导致更新、插入和删除操作变慢。 - 每次数据变更时,所有相关的索引都需要被更新,这会增加额外的计算负担。 #### 七、字段值范围限制 **限制方法:** - **CHECK约束:*...

    MySQL军规升级版

    - **禁止负向查询和%开头的模糊查询**:同样可能导致索引无法使用,全表扫描。 - **避免大表JOIN和子查询**:这些操作可能导致性能急剧下降。 - **OR改写为IN**:当OR条件涉及同一字段时,转换为IN,且值数少于50...

    规范设计数据库应注意的技巧

    - **索引的维护**:定期维护索引,避免索引碎片过多导致性能下降。 - **索引的类型**:根据需求选择合适的索引类型,如B树索引、哈希索引等。 #### 7. 外键(FK)的作用 外键用于建立表之间的关系,主要作用包括:...

Global site tag (gtag.js) - Google Analytics