修改数据库表的已存在的某列为非空属性
alter table table_name modify column_name not null;
语句很简单,但经常容易忽略一个事实,执行语句时报下面的错误:
ORA-02296: 无法启用 (SYSTEM.) - 找到空值
导致修改不能成功。
因为在数据库中由于原来没有限制此列的非空属性,此列可以为空,所以在一行数据中可以对此列不插入值,最终在此表此列中存在为空的数据。
既然要设置此列不能为空,表示此列的所有数据都不能为空,而现在已存在为空的数据,存在冲突。
首先对此列所有为空的行更新此列为非空数据,在执行上面的SQL语句。