Oracle/MySQL/SQL Server修改表字段类型和长度

本文介绍了如何在Oracle、MySQL及SQL Server中修改表字段的数据类型和长度,包括处理字段有主键、唯一约束和索引的情况。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

  • Oracle
    ALTER TABLE T_USER MODIFY USERNAME VARCHAR2(200);

  • MySQL
    ALTER TABLE T_USER CHANGE USERNAME USERNAME VARCHAR(200) NOT NULL COMMENT '用户名称';

  • SQL Server
    ALTER TABLE T_USER ALTER COLUMN USERNAME VARCHAR(200);

         :SQL Server 字段有约束或者索引,需要按如下方式处理:

  1. 字段是主键:
    ALTER TABLE T_USER DROP CONSTRAINT PK_T_USER;
    ALTER TABLE T_USER ALTER COLUMN ID VARCHAR(20) NOT NULL;
    ALTER TABLE T_USER ADD CONSTRAINT PK_T_USER PRIMARY KEY (ID);

  2. 字段有约束,比如唯一约束,并且修改后字段长度大于原长度:
    ALTER TABLE T_USER DROP CONSTRAINT UN_T_USER;
    ALTER TABLE T_USER ALTER COLUMN USERNAME VARCHAR(20);
    ALTER TABLE T_USER ADD CONSTRAINT UN_T_USER UNIQUE (USERNAME);


  3. 字段有索引,比如唯一索引,并且修改后字段长度大于原长度:
    DROP INDEX IDX_USER ON T_USER;
    ALTER TABLE T_USER ALTER COLUMN USERNAME VARCHAR(20);
    CREATE INDEX IDX_USER ON T_USER(USERNAME);


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值