Oracle 增加修改删除字段/新增记录

本文详细介绍了如何使用SQL语句进行表结构的增删改操作,包括添加、修改和删除字段的方法,并提供了创建表及主键约束的具体示例。

新增字段

添加字段的语法:alter table tablename add (column datatype [default value][null/not null],….);

修改字段的语法:alter table tablename modify (column datatype [default value][null/not null],….);

删除字段的语法:alter table tablename drop (column);

 

添加、修改、删除多列的话,用逗号隔开。

 

使用alter table 来增加、删除和修改一个列的例子。

 

创建表结构:
create table test1
(id varchar2(20) not null);

 

增加一个字段:

alter table test1
add (name varchar2(30) default ‘无名氏’ not null);

 

使用一个SQL语句同时添加三个字段:

alter table test1
add (name varchar2(30) default ‘无名氏’ not null,

age integer default 22 not null,

has_money number(9,2)

);

 

修改一个字段

alter table test1
modify (name varchar2(16) default ‘unknown’);

 

另:比较正规的写法是:

-- Add/modify columns 
alter table TABLE_NAME rename column FIELD_NAME to NEW_FIELD_NAME;

 

删除一个字段

alter table test1
drop column name;

 

需要注意的是如果某一列中已经存在值,如果你要修改的为比这些值还要小的列宽这样将会出现一个错误。

例如前面如果我们插入一个值
insert into test1
values (’1′,’我们很爱你’);

然后曾修改列: alter table test1
modify (name varchar2(8));
将会得到以下错误:
ERROR 位于第 2 行:
ORA-01441: 无法减小列长度, 因为一些值过大

---------------------------------------------------------------------------------------------------------------

高级用法:

重命名表
ALTER TABLE
 table_name RENAME TO new_table_name;

 

修改列的名称

语法:
ALTER TABLE table_name RENAME COLUMN supplier_name to sname;

范例:
alter table s_dept rename column age to age1;

 

附:创建带主键的表>>

create table student (
studentid int primary key not null,
studentname varchar(8),
age int);

 

1、创建表的同时创建主键约束
(1)无命名
create table student (
studentid int primary key not null,
studentname varchar(8),
age int);
(2)有命名
create table students (
studentid int ,
studentname varchar(8),
age int,
constraint yy primary key(studentid));


2、删除表中已有的主键约束
(1)无命名
可用 SELECT * from user_cons_columns;
查找表中主键名称得student表中的主键名为SYS_C002715
alter table student drop constraint SYS_C002715;
(2)有命名
alter table students drop constraint yy;


3、向表中添加主键约束
alter table student add constraint pk_student primary key(studentid);

转载自

http://www.cnblogs.com/laipDIDI/articles/2615210.html


新增记录

 

新增记录语法:

--新增记录(仿照已有表记录)
INSERT INTO T_XXXX T
(T.FIELD_1, T.FIELD_2, T.FIELD_3, T.FIELD_4, T.FIELD_5)
SELECT T2.FIELD_1, T2.FIELD_2, T2.FIELD_3, T2.FIELD_4, T2.FIELD_5
FROM T_YYYY T2
WHERE T2.FIELD_1 = 'DEMO';

 

--新增记录(自定义值)
INSERT INTO T_XXXX T
(T.FIELD_1, T.FIELD_2, T.FIELD_3, T.FIELD_4, T.FIELD_5)
VALUES
(10000, 10000, 'DEMO', 'DEMO', SYSDATE);

####################浅浅的分割线####################

更新语法示例:

--更新记录(自定义值)
UPDATE T_XXXX T
SET T.FIELD_1 = 'DEMO', T.FIELD_2 = 'DEMO'
WHERE T.FIELD_3 = '10000';

--更新记录(仿照已有表记录)

UPDATE T_XXXX T
SET (T.FIELD_1, T.FIELD_2) = (SELECT T2.FIELD_1, T2.FIELD_2
FROM T_YYYY T2
WHERE T2.FIELD_3 = '10000')
WHERE T.FIELD_3 = '10000';


<think>好的,用户现在想在Oracle数据库的表中新增字段,我之前已经回答过关于Java时间转换的问题,现在需要根据提供的引用内容来解答这个问题。首先,我需要回顾用户提供的引用内容,看看里面有哪些相关信息。 引用[1]提到Oracle新增字段,但具体语法可能和MySQL不同,用户需要的是Oracle的方法。引用[2]和引用[4]都给出了ALTER TABLE语句的例子,比如添加字段并设置非空约束。引用[3]也提到了ALTER TABLE ADD的用法,还有添加注释的方法。 用户的问题很明确,就是在Oracle中如何新增字段。需要明确基本语法、添加约束、位置控制、注释以及批量操作等。根据引用内容,Oracle的ALTER TABLE ADD是标准方法,但需要注意和MySQL的不同之处,比如Oracle不支持AFTER来指定字段位置,这点在引用[1]中提到MySQL可以用AFTER,但Oracle不行,所以需要特别指出。 接下来要整理步骤:基本语法、默认值、非空约束、添加多个字段字段注释。可能用户还会关心字段位置的问题,但根据引用,Oracle不支持,所以需要说明只能用其他方法,比如重建表或使用视图。 另外,引用[3]和[4]都提到了添加注释的方法,所以需要包括COMMENT ON的用法。还要注意添加非空约束时,如果表已有数据,可能需要默认值,否则会报错,这点在引用[4]的例子中也有体现。 用户可能没有提到的需求,比如批量添加字段或处理已有数据的情况,也需要考虑进去,给出注意事项,比如锁表风险和默认值的设置。 最后,生成相关问题,帮助用户进一步了解字段修改、注释、默认值设置等。</think>在Oracle数据库中添加表字段的标准方法是通过`ALTER TABLE`语句实现[^2][^4],以下是不同场景下的具体操作方式和注意事项: ### 一、基础字段添加 #### 1. 添加单个字段 ```sql -- 添加允许NULL的字段 ALTER TABLE employees ADD (birth_date DATE); -- 添加带有非空约束的字段(表必须无数据或设置默认值) ALTER TABLE employees ADD (employee_code VARCHAR2(20) NOT NULL); ``` *注意:添加`NOT NULL`约束时,若表已有数据需配合`DEFAULT`使用,否则报错ORA-01758* #### 2. 添加带默认值的字段 ```sql -- 添加默认系统时间 ALTER TABLE orders ADD (create_time TIMESTAMP DEFAULT SYSTIMESTAMP); -- 添加默认字符串值 ALTER TABLE products ADD (status VARCHAR2(10) DEFAULT 'ACTIVE' NOT NULL); ``` ### 二、高级操作技巧 #### 1. 批量添加字段 ```sql ALTER TABLE customers ADD ( wechat_id VARCHAR2(30), membership_level NUMBER(2) DEFAULT 1, last_login_time TIMESTAMP(6) ); ``` #### 2. 添加字段注释 ```sql COMMENT ON COLUMN employees.birth_date IS '员工出生日期(YYYY-MM-DD格式)'; COMMENT ON COLUMN orders.create_time IS '订单创建时间(含6位小数秒)'; [^3] ``` #### 3. 字段约束组合 ```sql ALTER TABLE invoices ADD ( payment_due_date DATE NOT NULL, tax_rate NUMBER(5,4) CHECK (tax_rate BETWEEN 0 AND 0.2) ); ``` ### 三、特殊场景处理 #### 1. 大表字段添加(低停机方案) ```sql -- 步骤1:设置字段可延迟约束 ALTER TABLE sales ADD ( region_code VARCHAR2(10) DEFAULT 'CN' NOT NULL ) NOVALIDATE; -- 步骤2:后台更新历史数据 BEGIN DBMS_REDEFINITION.start_redef_table( uname => 'SCOTT', orig_table => 'SALES', int_table => 'SALES_TMP'); END; ``` #### 2. 虚拟字段添加 ```sql ALTER TABLE employees ADD ( full_name VARCHAR2(45) GENERATED ALWAYS AS (first_name || ' ' || last_name) ); ``` ### 四、注意事项 1. **字段顺序**:Oracle不支持`AFTER`语法指定字段位置[^1],需通过重建表或视图实现 2. **锁表风险**:添加字段默认使用`EXCLUSIVE`锁,大表操作建议使用`ONLINE`模式 3. **默认值存储**:`DEFAULT`值不会回填历史数据,新增记录时才生效 4. **数据类型匹配**:确保应用层数据类型与数据库字段类型兼容,如`TIMESTAMP(6)`对应Java的`java.sql.Timestamp` --相关问题--: 1. 如何修改Oracle表中已有字段的数据类型? 2. 在Oracle中如何为新增字段添加索引? 3. 如何安全删除Oracle表中的冗余字段? 4. Oracle虚拟字段与普通字段在存储上有何区别?
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

macrobn

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值