语言分类:
1.ddl:create,alter,drop
2.dcl:grant ,revoke
3.dml:select,insert,delete,update
完全匹配的内连接:
简洁写法: select tt1.name,t2,name from t1,t2 where t1.id=t2.id
标准写法:select t1.name,t2.name from t1 join t2 on t1.id=t2.id
不完全匹配的内连接:
左外连接:select t1.name,t2.name from t1 left outer join t2 on t1.id=t2.id
select t1.name,t2.name from t1,t2 where t1.id=t2.id(+)(oracle9.0以上方式,t1表的数据无条件显示出来)
右连接:select t1.name,t2.name from t1,t2 where t1.id(+)=t2.id
子查询:
独立子查询:select * from e where id in (select id from d);
相关子查询:select * from e where id in(select id#不可用*,否则会出现too many value错误# from d where id=e.id and id='03');
总结:有时在相同的情况下,表连接与子查询都能实现的,用表连接执行,效率会高些
orcle独有的并集(union)与交集(intersect):
1.union:只起显示作用,当有重复时,只显示一个,select ename from t1 union select dname from t2;
2.intersect:可返回两个语句中重复的行, select eid from t1 intersect select id from t2;
批量插入:
1.insert into e(id,name) select id,name from d;
2.create table tee as (select * from t);
视图:是一条存储起来的select语句,是数据的显示方式,也可作为简单报表
作用:安全(权限管理,隐藏数据结构),方便,一致性
限制:组成的表有两个或以上,不允许对两个或以上的表同时更新,只能对一个表进行更新,但可用替代触发器解决这个问题
视图中有聚合函数distance,不允许更新
同义词:一个对象替代名,使不同用户模式下可进行操作同一个对象
公共同义词:dba建立,所有用户可使用
私有同义词:当前用户建立,自己使用
序列:发布一系列唯一数字整型的oral对象,独立型的事务,每次访问时都会按照事先规定的增加或减少,自动完成,提交完成回滚事务,不影响序列的变化,以表的形式存储,默认从1开始,每次增量为1
eg:create sequence myseq
select myseq.netxtval from dual
or
select myseq.currval from dual
触发器:特殊的过程,不接受参数
事务:用于确保数据完整性和并发处理的能力,一条或一组sql语句作为一个逻辑单元保障语句成功或失败
隔离性(加锁):隔离性越强,并发性越差,否则,并发性越强
原子性:手段 一致性:目的 永久性:物理上
行级触发器:
select * from t1 for update(加锁过程),表示查完后立马上要修改(严厉的规则),不允许有别的用户修改操作,直到当前用户修改完成,别的用户处于等待状态(但可以查询)
触发器语句体中不可用commit,rollback;但可在触发器中抛出异常,阻止操作
重要的内存表:old,new
old;内存中的特殊逻辑表,删除时数据移到old边中,结构与删除表一样
eg:delete from emp where id=:old.id
insert into emp(eid,ename,id) values(1,'ee',:new.id);
update emp set id=:new.id where id=:old.id;
记录:是由几个相关值构成的复合变量,常用于支持select语句的返回值,使用记录可将一行数据看成一个单元进行处理,而不必将每一列单独处理,使用前需事先声明
%type 制定字段 %rowtype 整个表的字段类型
游标:是一种pl/sql控制结构,可对sql语句的处理进行显式控制,便与对表的行数据逐条处理,可传参数,数据量大时不推荐使用
补充:判断字段是否为空: is not null
分享到:
相关推荐
oracle_sql笔记
sql笔记sql笔记sql笔记sql笔记sql笔记sql笔记
sql笔记.md
最全的ORACLE-SQL笔记,众多的SQL代码,基本包含了Oracle数据库的SQL语句,加上所有的注释,很容易看懂
OracleSQL笔记
pl/sql笔记pl/sql笔记pl/sql笔记pl/sql笔记pl/sql笔记pl/sql笔记pl/sql笔记
SQL笔记
NULL 博文链接:https://ybds.iteye.com/blog/2392710
hivesql笔记.sql
SQL笔记-副本.sql
这个文档时我的SQL笔记
没有SQL的就下 ,保证真实!大小1G!东方红数据库科技活动附件可回收
oracle SQL笔记,非常全面,足够初学者查询使用。
sql 笔记.md
Server SQL笔记
SQL笔记
sql 笔记,整理自韩顺平的教程 包括oracle mysql sql server
Oracle 常用SQL 笔记 保存,自己留着用.. 简单的关键字说明
超有用sql笔记希望对大家有用..............................................................................
sql笔记,,,,,,,