1、创建表
Create table student( Sid number(10), Sname varchar2(10) ) tablespace tt;
以上tablespace不是必须的。默认不写,则创建在登录的用户所在的表空间上。
2、使用子查询创建表
create table myemp as select * from yangx.emp;
create table myemp as select * from yangx.emp where deptno=10;
create table myemp as select * from yangx.emp 1=2;
3、添加字段
Alter table student add age number(5);
4、修改字段
Alter table student modify age number(10);
alter table table2 rename column result to result2;
5、删除字段
Alter table student drop column age;
6、清空表中数据
Truncate table student;
正常情况下删除数据,如果发现删除错了,则可以通过rollback回滚。如果使用了截断表,
则表示所有的数据不可恢复了.所以速度很快(更详细的说明可查看Oracle体系结构)
truncate和delete的主要区别:
1、delete是DML,执行delete操作时,每次从表中删除一行,并且同时将该行的的删除操作记录在redo和undo表空间中以便进行回滚(rollback)和重做操作,但要注意表空间要足够大,需要手动提交(commit)操作才能生效,可以通过rollback撤消操作。
2、delete可根据条件删除表中满足条件的数据,如果不指定where子句,那么删除表中所有记录。
3、delete语句不影响表所占用的extent,高水线(high watermark)保持原位置不变。
4、truncate是DDL,会隐式提交,所