一。利用已有索引创建主键
1.建表
GAO@PROD> create table abcd(id number(10),name1 varchar2(20));

Table created.

2.插入数据
GAO@PROD> insert into abcd values(1,'genwang');

1 row created.

GAO@PROD> commit;

Commit complete.

3.给id字段创建索引
GAO@PROD> create index pk_abcd on abcd(id);

Index created.

4.利用已有索引创建主键
GAO@PROD> alter table abcd add constraint pk_abcd primary key(id);

Table altered.

5.查看表的索引和约束
GAO@PROD> select index_name from user_indexes where table_name=upper('abcd');

INDEX_NAME
------------------------------------------------------------------------------------------
PK_ABCD

GAO@PROD> select constraint_name from user_constraints where table_name=upper('abcd');

CONSTRAINT_NAME
------------------------------------------------------------------------------------------
PK_ABCD

6.删除主键
GAO@PROD> alter table abcd drop primary key;

Table altered.

7.查看索引和约束是否已经被删除,发现索引还在,约束没了
GAO@PROD> select index_name from user_indexes where table_name=upper('abcd');

INDEX_NAME
------------------------------------------------------------------------------------------
PK_ABCD

GAO@PROD> select constraint_name from user_constraints where table_name=upper('abcd');

no rows selected

8.用别的字段重建主键,发现报错 ORA-00955
alter table abcd add constraint pk_abcd primary key(id,name1);

GAO@PROD> alter table abcd add constraint pk_abcd primary key(id,name1);
alter table abcd add constraint pk_abcd primary key(id,name1)
*
ERROR at line 1:
ORA-00955: name is already used by an existing object

解决办法:
1)删除原来的索引,然后再创建新的主键
GAO@PROD> drop index pk_abcd;

Index dropped.

2)GAO@PROD> alter table abcd add constraint pk_abcd primary key(id,name1);

Table altered.

9.查看此时abcd表的索引和约束(可以看到如果该表主键列没有索引,这时创建主键时会自动在主键列创建索引)
GAO@PROD> select index_name,uniqueness from user_indexes where table_name=upper('abcd');

INDEX_NAME UNIQUENESS
------------------------------------------------------------------------------------------ ---------------------------
PK_ABCD UNIQUE

GAO@PROD> select constraint_name from user_constraints where table_name=upper('abcd');

CONSTRAINT_NAME
------------------------------------------------------------------------------------------
PK_ABCD

9.删除主键
GAO@PROD> alter table abcd drop primary key;

Table altered.

10.查看索引和约束状态(发现索引和约束都不复存在)
GAO@PROD> select index_name from user_indexes where table_name=upper('abcd');

no rows selected

GAO@PROD> select constraint_name from user_constraints where table_name=upper('abcd');

no rows selected

11.此时添加新的主键,不再报错
alter table abcd add constraint pk_abcd primary key(id,name1);

结论:如果主键是基于原来索引创建的,那么alter table XXX drop primary key只能删除约束,无法删除原来索引。如果此时创建主键时,主键列与索引列不同,那么就会报错ORA-00955: name is already used by an existing object。
如果主键创建时,主键列没有索引,那么创建主键时会自动在主键列创建唯一索引,这时alter table XXX drop primary key就会把约束和索引一起删除。重新创建主键时就不会报错。

删除主键时报错ORA-00955的更多相关文章

  1. SQL语句添加,删除主键

    IF EXISTS (SELECT * FROM sys.all_objects  WHERE  type_desc= N'主键名')begin --删除主键 alter table 表名 drop ...

  2. MySQL基础之 如何删除主键

    我们在一个表中设置了主键之后,那么如何删除主键呢? 删除主键的语法是: ALTER TABLE TABLE_NAME DROP PRIMARY KEY; 在这里我们要考虑两种情况: 1.可以直接使用d ...

  3. sql server 删除主键、外键、索引、约束的脚本

    最近公司项目要升级新版本,涉及到数据库升级中各种约束.亦是整理出如下脚本方便以后查询. --删除全文索引 DECLARE c0 cursor for SELECT'DROP FULLTEXT INDE ...

  4. Oracle删除主键约束的同时删除索引

    继续昨天的折腾(Oracle修改主键约束),删掉主键约束后,发现唯一索引并未删掉.仔细看了下,主键约束跟唯一索引名称不一样,这说明是先创建了唯一索引,后创建的主键约束.我们来试验下: SQL> ...

  5. 给表追加主键-----报错ORA-02437: 无法验证 (DENGCHAO.TEST) - 违反主键

    由于 这次 项目 做了 数据库 迁移(从 mysql 转到oracle  用的是navicat) 的工具  所以导致很多主键都丢失了 导致数据库很多 数据的id重复  导致系统修改一条数据的时候 出现 ...

  6. PL/SQL 删除主键 ORA-02443: 无法删除约束条件-不存在的约束条件

    在PL/SQL developer中删除一个表的主键,然后把另外一个字段设置成主键,删除的过程中报错:ORA-02443 我遇到这个问题出现的背景是: alter table saleqtya dro ...

  7. sql server删除主键约束所想到的

    从网上找到了下面一段代码: declare @Pk varchar(100);select @Pk=Name from sysobjects where Parent_Obj=OBJECT_ID('表 ...

  8. mysql 增加字段脚本,以及删除主键约束的脚本,存储过程

    //增加一个库下面所有表的row_id和其他9个字段的存过 DELIMITER $$ USE `erptest`$$ DROP PROCEDURE IF EXISTS `UPTABLE`$$ CREA ...

  9. sqlserver 2014 删除主键约束

    truncate table menu SELECT * FROM sys.foreign_keys WHERE referenced_object_id=OBJECT_ID('menu'); --找 ...

随机推荐

  1. [源码解析] 并行分布式任务队列 Celery 之 负载均衡

    [源码解析] 并行分布式任务队列 Celery 之 负载均衡 目录 [源码解析] 并行分布式任务队列 Celery 之 负载均衡 0x00 摘要 0x01 负载均衡 1.1 哪几个 queue 1.1 ...

  2. Asp.NetCore Web开发之模型验证

    在开发中,验证表单数据是很重要的一环,如果对用户输入的数据不加限制,那么当错误的数据提交到后台后,轻则破坏数据的有效性,重则会导致服务器瘫痪,这是很致命的. 所以进行数据有效性验证是必要的,我们一般通 ...

  3. Mybatis-plus在原有的select查询语句中动态追加查询条件

    一.适用场景 1.使用了xml形式的mapper.2.不想在select查询中大量使用<if>标签来判断条件是否存在而加入条件. 二.步骤 1.自定义wrapper继承QueryWrapp ...

  4. sed 's/AA/BB/' file # 将文件中的AA替换成BB,只替换一行中第一次出现的AA,替换后的结果输出到屏幕 sed 's/AA/BB/g' file # 将文件中的所有AA都替换成BB,替换后的结果输出到屏幕

    生信人的自我修养:Linux命令速查手册 简佐义 ​ 四川大学 生物信息学硕士 科学求真 赢 10 万奖金 · 院士面对面 209 人赞同了该文章 许多人做生物信息学,要么不重视Linux,要么不知道 ...

  5. Docker------阿里云部署私有镜像仓库

    Docker------阿里云部署私有镜像仓库   前言 公共镜像仓库 官方:https://hub.docker.com/ 基于各个软件开发或者软件提供方开发的 非官方:其它组织或公司开发的镜像,供 ...

  6. [转载]XStar's Libvirt+KVM部署记录 目录

    XStar's Libvirt+KVM部署记录 目录 Create: 2013-12-11 Update: 2014-01-03 准备工作 KVM网站 http://sourceforge.net/p ...

  7. 攻防世界(十一)warmup

    攻防世界系列 :warmup 1.打开题目,一个贱贱的滑稽表情 F12看到注释内容source.php 2.访问source.php <?php highlight_file(__FILE__) ...

  8. IDEA Git 项目实战场景

    实战场景一:上班啦,从远程仓库克隆项目到本地仓库(Clone) 打开 IDEA,在 Check out from Version Control 下拉菜单选择 Git,如下: 在弹出窗口的 URL 地 ...

  9. python3 读取txt文件数据,绘制趋势图,matplotlib模块

    python3 读取txt文件数据,绘制趋势图 test1.txt内容如下: 时间/min cpu使用率/% 内存使用率/% 01/12-17:06 0.01 7.61 01/12-17:07 0.0 ...

  10. Nginx|Apache目录权限禁止执行PHP设置

    Ngnix: location ~ /upload/.*.(php|php5)?$ { deny all; } 这就是禁止upload内执行php,但是图片可以打开哦 多目录禁止: location ...