[独孤九剑]Oracle知识点梳理(四)SQL语句之DML和DDL
本系列链接导航:
[独孤九剑]Oracle知识点梳理(四)SQL语句之DML和DDL
[独孤九剑]Oracle知识点梳理(五)数据库常用对象之Table、View
[独孤九剑]Oracle知识点梳理(六)数据库常用对象之Procedure、function、Sequence
[独孤九剑]Oracle知识点梳理(七)数据库常用对象之Cursor
[独孤九剑]Oracle知识点梳理(八)常见Exception
[独孤九剑]Oracle知识点梳理(九)数据库常用对象之package
[独孤九剑]Oracle知识点梳理(十)%type与%rowtype及常用函数
4、SQL语句
Oracle 将sql语句分为一下几类:
a) 数据操作语言语句[Data manipulation language,DML],如select、insert、update、delete、merge、lock、fetch等
b) 数据定义语言语句[Data definition language,DDL],如create、alter、drop、rename、truncate、grant、revoke、audit、noaudit、comment等
c) 事务控制语句[transaction control statement],如commit、rollback、savepoint、set transaction等
d) 会话控制语句[session control statement]
d.1 执行特定操作,修改当前会话,例如启用或禁用 SQL 跟踪功能[SQL trace facility](ALTER SESSION);
d.2 为当前会话启用或禁用角色[role](即一组权限的集合)(SET ROLE)
e) 系统控制语句[system control statement],alter system 是唯一的系统控制语句
f) 嵌入 SQL 语句[embedded SQL statement]
f.1 cursor的定义(declare cursor)、打开(open)、关闭(close),
f.2 选择一个oracle数据库并进行连接 declare database,connect
f.3 分配变量名 declare statement
f.4 初始化描述符[descriptor](DESCRIBE)
f.5 设定如何处理错误及警告(WHENEVER)
f.6 解析并执行 SQL 语句(PREPARE,EXECUTE,EXECUTE IMMEDIATE)
f.7 从数据库中取回数据(FETCH)
我操作最多的是a,b,c和f中的部分。
4.1、DML
4.1.1、增删改查的语法使用标准sql语句即可:
select * from table1;
insert into table1(f1,f2,f3) values(v1,v2,v3);
update table1 t set t.f1=v1 where t.f2=v2;
delete table1 t where t.f2=v2;
rownum,是oracle中特有的一个关键字,当select一张表时,oracle会对查询结果进行标记,rownum是number类型的,每次都是从1开始,如果查询出10行数据,那么rownum就会从1到10,按查询结果的顺序标记。
rownum是不可以跳跃的,即可以使用where rownum=1,但不可以使用where rownum=2; 可以使用rownum <5,但不可以使用rownum>5,而where rownum=0可以得到表结构。
4.1.2、分页查询:
select tt.* from (select t.*,rownum rn from table1 t where rownum<=10) tt where tt.rn>=1; --这就是使用rownum的最好例子
4.1.3、联合查询
- where方式关联:
select t1.*,t2.* from table1 t1,table2 t2 where t1.f1=t2.f2 --同inner join
select t1.*,t2.* from table1 t1,table2 t2 where t1.f1(+)=t2.f2 --同left join
select t1.*,t2.* from table1 t1,table2 t2 where t1.f1=t2.f2(+) --同right join
- join方式关联:
select t1.* from table1 t1
join table2 t2
on t1.f1=t2.f2
where t1.fx>10 and t2.fy>100
left join 、right join、outer join 方式与标准sql一致,略。
4.1.4、merge 合并
该命令使用一条语句从一个或者多个数据源中完成对表的更新和插入数据.
/*涉及到两个表关联的例子*/
merge into toTable a --需要更新的表
using fromTable b --关联表(数据源表)
on (a.id=b.id) --关联条件
when metched then --匹配关联条件,做更新处理
update set a.f1=b.f1, a.f2=b.f2+1
when not metched then --不匹配关联条件,做插入处理
insert values(b.f1,b.f2,b.f3...);
/*涉及到多个表关联的例子,有3个表,table1 是目标表,table2和table3需要关联后,作为table1的数据源;并且只做更新操作*/
merge into table1 a
using (select t2.id,t2.f1,t2.f2,t3.f1 from table t2 join table2 t3 on t2.id=t3.id) b
4 on (a.id=b.id)
when matched then
update set a.f1=b.f1,a.f2=b.f2+1;
注意:
- 使用merge时,update或insert的字段,不能是 on中用于匹配的字段
- 对于update和insert语句,都可以使用where条件;where中可针对a表,也可针对b表进行过滤
4.2、DDL
create用于创建table、view、procedure、function、sequence等。
alter用于修改
drop用于删除table、view、procedure、function、sequence等。
grant、revoke用于给用户赋权限和取下权限
audit、noaudit用于审计功能
comment用于添加备注信息
truncate用于截断表,不能回滚
rename用于重命名
第5节,在介绍table、view、procedure、function、sequence时,使用的都是DDL语句
4.3、其他类型的SQL语句
略( ̄▽ ̄)"
[独孤九剑]Oracle知识点梳理(四)SQL语句之DML和DDL的更多相关文章
- [独孤九剑]Oracle知识点梳理(十)%type与%rowtype及常用函数
本系列链接导航: [独孤九剑]Oracle知识点梳理(一)表空间.用户 [独孤九剑]Oracle知识点梳理(二)数据库的连接 [独孤九剑]Oracle知识点梳理(三)导入.导出 [独孤九剑]Oracl ...
- [独孤九剑]Oracle知识点梳理(九)数据库常用对象之package
本系列链接导航: [独孤九剑]Oracle知识点梳理(一)表空间.用户 [独孤九剑]Oracle知识点梳理(二)数据库的连接 [独孤九剑]Oracle知识点梳理(三)导入.导出 [独孤九剑]Oracl ...
- [独孤九剑]Oracle知识点梳理(八)常见Exception
本系列链接导航: [独孤九剑]Oracle知识点梳理(一)表空间.用户 [独孤九剑]Oracle知识点梳理(二)数据库的连接 [独孤九剑]Oracle知识点梳理(三)导入.导出 [独孤九剑]Oracl ...
- [独孤九剑]Oracle知识点梳理(七)数据库常用对象之Cursor
本系列链接导航: [独孤九剑]Oracle知识点梳理(一)表空间.用户 [独孤九剑]Oracle知识点梳理(二)数据库的连接 [独孤九剑]Oracle知识点梳理(三)导入.导出 [独孤九剑]Oracl ...
- [独孤九剑]Oracle知识点梳理(六)数据库常用对象之Procedure、function、Sequence
本系列链接导航: [独孤九剑]Oracle知识点梳理(一)表空间.用户 [独孤九剑]Oracle知识点梳理(二)数据库的连接 [独孤九剑]Oracle知识点梳理(三)导入.导出 [独孤九剑]Oracl ...
- [独孤九剑]Oracle知识点梳理(五)数据库常用对象之Table、View
本系列链接导航: [独孤九剑]Oracle知识点梳理(一)表空间.用户 [独孤九剑]Oracle知识点梳理(二)数据库的连接 [独孤九剑]Oracle知识点梳理(三)导入.导出 [独孤九剑]Oracl ...
- [独孤九剑]Oracle知识点梳理(三)导入、导出
本系列链接导航: [独孤九剑]Oracle知识点梳理(一)表空间.用户 [独孤九剑]Oracle知识点梳理(二)数据库的连接 [独孤九剑]Oracle知识点梳理(三)导入.导出 [独孤九剑]Oracl ...
- [独孤九剑]Oracle知识点梳理(二)数据库的连接
本系列链接导航: [独孤九剑]Oracle知识点梳理(一)表空间.用户 [独孤九剑]Oracle知识点梳理(二)数据库的连接 [独孤九剑]Oracle知识点梳理(三)导入.导出 [独孤九剑]Oracl ...
- [独孤九剑]Oracle知识点梳理(一)表空间、用户
本系列链接导航: [独孤九剑]Oracle知识点梳理(一)表空间.用户 [独孤九剑]Oracle知识点梳理(二)数据库的连接 [独孤九剑]Oracle知识点梳理(三)导入.导出 [独孤九剑]Oracl ...
随机推荐
- 美图秀秀 web开发图片编辑器
美图秀秀web开发平台 http://open.web.meitu.com/wiki/ 1.环境配置 1.1.设置crossdomain.xml 下载crossdomain.xml文件,把解压出来的c ...
- 每天一个Linux命令(45)lsof命令
lsof命令用于查看你进程打开的文件,端口(TCP.UDP),找回/恢复删除的文件,打开文件的进程. (1)用法: 用法: lsof [参数] [文件] (2)功 ...
- mysql ERROR 1045 (28000): Access denied (using password: YES)
mysql 安装完成后 mysql -u root -p #让输入密码直接回车就能登录 设置mysql的root用户初始密码: mysqladmin -u root password 'root' 解 ...
- [SCOI2013]火柴棍数字(背包)
题目 做饭 由于越高位越好,我们先得出能组成的最高位 \(f[i][j][k]\)表示从低到高位第\(i\)位,手里拿着\(j\)根火柴,第\(i\)位是否为\(0\)所需要的最少火柴 我们转移仅需得 ...
- apache2.4配置ssl
1,yum 安装openssl和openssl-devel,httpd-devel2,生成证书(也可以从公司的证书颁发机构获取): #建立服务器密钥 openssl genrsa -des3 > ...
- PHP自动导入类
自动require出所需要的类文件,支持PSR系列规范 spl_autoload_register(function ($class) { $classNames = explode('\\',$cl ...
- R语言的输出函数cat,sink,writeLines,write.table
根据输出的方向分为输出到屏幕和输出到文件. 1.cat函数即能输出到屏幕,也能输出到文件. 使用方式:cat(... , file = "", sep = " " ...
- 《网络对抗》 逆向及Bof基础实践
<网络对抗>-逆向及Bof基础实践 1 逆向及Bof基础实践说明 1.1 实践目标 本次实践的对象是一个名为pwn1的linux可执行文件. 该程序正常执行流程是:main调用foo函数, ...
- Android源码目录分析【转】
本文转载自:http://blog.csdn.net/backgarden_straw/article/details/8050783 在学习Android的过程中,学习写应用还好,一开始不用管太多代 ...
- vmxnet3 丢包处理
https://vswitchzero.com/2017/09/26/vmxnet3-rx-ring-buffer-exhaustion-and-packet-loss/