繁体   English   中英

如何删除未命名的主键约束

[英]how to drop unnamed primary key constraint

我在oracle 10g中创建了一个表,如下所示:

CREATE TABLE studentTbl(
 studId VARCHAR2(20) PRIMARY KEY,
 StudName VARCHAR2(40)
 );

现在想要从studId中删除主键而不删除此列。 我搜索了它并找到了Dropping未命名的约束,但它也无法帮助我。 无法获取sys.columns表或视图。

谢谢

alter table studenttbl drop primary key;

手册中的更多细节: http//docs.oracle.com/cd/E11882_01/server.112/e26088/statements_3001.htm#i2103997

(这个tbl后缀是什么?听起来像一个可怕的命名约定)

您链接的问题不适用于Oracle。 系统视图USER_CONSTRAINTS具有所有约束的列表。 CONSTRAINT_TYPE列中的P表示它是主键; 你可以利用它来找到其他约束。

您可以使用此视图生成删除约束(或查看其他信息)所需的DDL。

例如:

CREATE TABLE studentTbl(
 studId VARCHAR2(20) PRIMARY KEY,
 StudName VARCHAR2(40)
 );

Table created.


select 'alter table ' || table_name
       || ' drop constraint ' || constraint_name || ';'
  from user_constraints
 where table_name = 'STUDENTTBL'
   and constraint_type = 'P';

'ALTERTABLE'||TABLE_NAME||'DROPCONSTRAINT'||CONSTRAINT_NAME||';'
----------------------------------------------------------------------

alter table STUDENTTBL drop constraint SYS_C0017725;

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM