ORA-02329: column of datatype string cannot be unique or a primary key
Cause: An attempt was made to place a UNIQUE or a PRIMARY KEY constraint on a column of datatype VARRAY, nested table, object, LOB, FILE or REF.
Action: Change the column datatype or remove the constraint. Then retry the operation.
。
ORA-02329 错误是由于指定的字符串列不能成为唯一索引或者主键索引所引发的数据库错误。
ORA-02329 表示指定的字符串列不能成为唯一索引或者主键索引。字符串类型的列,不能用于唯一约束或者主键约束。
错误的SQL语句例子:
create table student_records(
student_id varchar(100) primary key,
name varchar2(100) not null
);
1、以字符串为主键或唯一索引,没办法保证索引不出错,比如字符串可能会在多处出现空格。为了确保数据准确性,建议用另外一种数据类型,比如数值类型,或者有明确定义规则的字符串类型(比如upper/lower case, 或者每个字符都占用一个位置,使用前缀补足)。
2、另外也可以考虑使用其它能够唯一编码的方式来标识,比如GUID。