我在 oracle 10g 中创建了一个表,如下所示:
CREATE TABLE studentTbl(
studId VARCHAR2(20) PRIMARY KEY,
StudName VARCHAR2(40)
);
现在想从 studId 中删除主键而不删除此列。我搜索了一下,发现 Dropping unnamed constraints 但它也帮不了我。无法获取 sys.columns 表或视图。
谢谢
我在 oracle 10g 中创建了一个表,如下所示:
CREATE TABLE studentTbl(
studId VARCHAR2(20) PRIMARY KEY,
StudName VARCHAR2(40)
);
现在想从 studId 中删除主键而不删除此列。我搜索了一下,发现 Dropping unnamed constraints 但它也帮不了我。无法获取 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;