对已有数据库表中添加一个非空字段

本文介绍了如何在SQL中向表中添加非空字段,并提供了将已有表中的某个字段从允许为空改为非空的方法。首先通过设置默认值的方式解决字段添加问题,接着给出了更新字段属性的具体步骤。

(1)ALTER TABLE TABLENAME ADD(COLUMNNAME VARCHAR2(300 CHAR) DEFAULT ' ' NOT NULL);

无法将一个非空字段添加进表中,除非将表中数据清空之后再添加。可以将需要添加的字段设置一个默认值(这里设置的是一个空格)。

(2)将数据库表中的一个可空字段修改为非空字段

1、UPDATE TABLENAME SET COLUMNNAME='默认值' where COLUMNNAME IS NULL;

2、ALTER TABLE TABLENAME MODIFY COLUMNNAME VARCHAR2(300 CHAR) DEFAULT' ' NOT NULL;

 

在Oracle数据库中,如果一张已经定义了两个主键字段,而需要新增第三个主键字段,需要注意主键约束本质上是一个唯一性约束(UNIQUE)与约束(NOT NULL)的组合。Oracle 不允许直接对已有主键的使用 `ALTER TABLE ... ADD PRIMARY KEY` 来新增主键字段,因为这会与现有的主键约束发生冲突。 要实现这一目标,可以按照以下步骤操作: 1. **添加新列并设置为** 首先向添加新的字段,并确保该字段设置为 `NOT NULL`,以满足主键的要求。 ```sql ALTER TABLE 名 ADD (新字段名 数据类型 DEFAULT 默认值 NOT NULL); ``` 2. **重建主键约束** 删除原有的主键约束,然后将新字段与原有主键字段一起重新添加到主键约束中。 - 首先查询现有主键约束的名称,可以通过如下语句查询: ```sql SELECT a.constraint_name FROM user_cons_columns a, user_constraints b WHERE a.constraint_name = b.constraint_name AND b.constraint_type = 'P' AND a.table_name = '名'; ``` - 然后删除原有主键约束: ```sql ALTER TABLE 名 DROP CONSTRAINT 主键约束名称; ``` - 最后重新添加包含新字段的复合主键: ```sql ALTER TABLE 名 ADD CONSTRAINT 新主键约束名称 PRIMARY KEY (字段1, 字段2, 新字段名); ``` 通过上述方式,可以在已有的复合主键基础上添加新的主键字段[^2]。 ### 示例操作 假设有一张 `employees`,其主键为 `first_name` 和 `last_name`,现在需要添加 `phone_number` 作为第三个主键字段: ```sql -- 添加字段并设置为 ALTER TABLE employees ADD (phone_number VARCHAR2(20) DEFAULT '000-0000' NOT NULL); -- 查询现有主键约束名称 SELECT a.constraint_name FROM user_cons_columns a, user_constraints b WHERE a.constraint_name = b.constraint_name AND b.constraint_type = 'P' AND a.table_name = 'EMPLOYEES'; -- 删除原有主键约束(假设约束名为 EMP_PK) ALTER TABLE employees DROP CONSTRAINT EMP_PK; -- 添加新的复合主键(包含三个字段) ALTER TABLE employees ADD CONSTRAINT EMP_PK PRIMARY KEY (first_name, last_name, phone_number); ``` ### 注意事项 - 在删除主键约束之前,应确保没有其他依赖该主键的外键约束,否则会引发错误。 - 操作前建议对数据进行备份,防止误操作导致数据丢失。 - 如果已有大量数据,添加 `NOT NULL` 字段时必须指定 `DEFAULT` 值,否则会因字段而失败。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值