dual 你可以理解为一个 万能的虚拟表。dual 确实是一张表.是一张只有一个字段,一行记录的表. 2.习惯上,我们称之为'伪表'.因为他不存储主题数据.3. 他的存在,是为了操作上的方便.因为select 都是要有特定对象的.
select 2+3 frmm dual; select sequence.nextval into yourpid from dual; select 'rrr'||'ggg' from dual;等等的,
主要的是 FROM关键字之前的部分,是主要关注的部分。
我的理解是有时候用来使得select语句完整,符合语法规则而引入的这张虚表
用法:但如果我们不需要从具体的表来取得表中数据,而是单纯地为了得到一些我们想得到的信息,并要通过select 完成时,就要借助一个对象,这个对象,就是dual;如我们要计算 999*999 的值,可以用:
ddl与dml
【DDL】
create table 创建表
alter table 修改表
drop table 删除表
truncate table 删除表中所有行
create index 创建索引
drop index 删除索引
当执行DDL语句时,在每一条语句前后,oracle都将提交当前的事务。
如果用户使用insert命令将记录插入到数据库后,执行了一条DDL语句(如create table),此时来自insert命令的数据将被提交到数据库。
当DDL语句执行完成时,DDL语句会被自动提交,不能回滚。
【DML】
insert 将记录插入到数据库
update 修改数据库的记录
delete 删除数据库的记录
当执行DML命令如果没有提交,将不会被其他会话看到。
除非在DML命令之后执行了DDL命令或DCL命令,或用户退出会话,或终止实例,
此时系统会自动发出commit命令,使未提交的DML命令提交。