Oracle数据库基本语句笔记

分类

DML(data manipulation language)
它们是select、update、insert、delete,这四条是用来对数据库里的数据进行操作的语言
DDL(data definition language)
DDL比DML要多,主要命令有create、alter、drop等。DDL主要是用在定义或改变表的结构,数据类型,表之间的链接和约束等初始化工作上,大多建立表时使用。
DCL(data control language)
是数据库控制功能。是用来设置或更改数据库用户或角色权限的语句,包括(grant,deny,revoke等)在默认状态下,只有sysadmin,dbcreator,db_owner或db_securityadmin等人员才有权力执行DCL。+

SQL中最重要的DDL语句

create database -创建新数据库
alter database -修改数据库
create table -创建新表
alter database -变更(修改)数据库表
drop table -删除表
create index -创建索引(搜索键)
drop index -删除索引

SQL执行顺序

from 语句-> where语句(结合条件)->GROUP BY语句 ->HAVING 语句->SELECT 语句->ORDER BY 语句

模糊匹配

select * from emp WHERE ENAME like ‘%S’; --LIKE 模糊匹配 A% %S A%S %a%

字段增删改查

增加字段
说明:alter table 表名 add (字段名 字段类型 默认值 是否为空);
修改字段
说明:alter table 表名 modify (字段名 字段类型 默认值 是否为空);
重名字段
说明:alter table 表名 rename column 列名 to 新列名 (其中:column是关键字)
删除字段
说明:alter table 表名 drop column 字段名;

数据查询

select <列名> from <表名> [where <查询条件表达试>] [order by <排序的列名>[asc或desc]]
select round(123.4567,2),TRUNC(123.4567,2),mod(10,3)from dual; --小数点后取2位 round,trunc按位取值 ,取余 mod
select substr(‘abcdefg’,3,4)from dual;–从第三个开始取值 ,取4个
select lower(ename)from emp;–转换为小写
select upper(ename)from emp;–转换为大写
select TRIM(ename)from emp;–除字符串两边的空格,除字符串两边的空格
select DISTINCT DEPTNO from emp;-- DISTINCT去重 ,但多个时 进行组合去重,对较少数据进行去重
select * from emp where rownum <=2;–前2行数据
聚合函数
select round(avg(sal),2)from emp; --查询平均值保留2位小数
select count(sal) from emp;
select MAX(sal) from emp;
select sum(sal) from emp;
select min(sal) from emp;
别名
select ename as 姓名 from emp; select ename 姓名 from emp; --别名 字段可用as或空格 ,表别名空格别名
–别名命名可以提高SQL解析效率、语法检查、语义检查、提高SQL语句的易读性、共享池检查、生成执行数、执行
–WHERE是对分组前的信息进行过滤,HAVING是对分组后的信息进行过滤 也就是说,where 可以对小组内详细详细信息进行过滤
不等于
select * from emp where sal<>3000; – select * from emp where sal != 3000;

多表关联查询、子查询
e,d位表名,e1别名
自连接:FROM e , e1 WHERE e.id = e1.id
左外连接:FROM e JOIN d ON e.id = d.id(+)
右外连接:FROM e JOIN d ON e.id(+) = d.id
全外连接(SQL99里的语法):A full outer join B on 条件

子查询(单行|多行)
from子句中使用子查询:子查询的结果是多行多列,看成一个临时表作为数据源
where子句中使用子查询:子查询的结果可以是单行单列,多行单列(in | not in)或者单行多列,单行多列的情况比较少
having子句中使用子查询:当使用了聚合函数后才会使用
select子句中的子查询一般不使用
关于确定数据范围的 in all(比所有数据大)any(比任意一个大)
子查询的效率高于多表查询,尽量少用多表查询

删除数据

delete from 表名 where 条件 -->删除满足条件的记录
delete from 表名–>删除表下所有数据
commit; -->提交数据
rollback; -->回滚数据
delete方式可以恢复删除的数据,但是提交了,就没办法了 delete删除的时候,会记录日志 -->删除会很慢很慢
truncate table 表名
删除所有数据,不会影响表结构,不会记录日志,数据不能恢复 -->删除很快
drop table 表名
删除所有数据,包括表结构一并删除,不会记录日志,数据不能恢复–>删除很快

更新数据

update 表 set 列=新的值 [where 条件] -->更新满足条件的记录
update 表 set 列=新的值 -->更新所有的数据

插入数据

insert into 表名 values(所有列的值);
insert into test values(1,‘zhangsan’,20);
insert into 表名(列) values(对应的值);
insert into test(id,name) values(2,‘lisi’);
多行插入
insert all
into nbas VALUES (‘活塞’,1990)
INTO nbas VALUES (‘公牛’,1991)
INTO nbas VALUES (‘公牛’,1992)
SELECT 1 FROM DUAL;

SQL语句调优(SQL效率的几条基本原则,注意,并非真理,一切以实际情况为准,遇到问题具体问题具体分析)
避免使用select*
语句大小写
where字句中>=和>的区别
where 字句中不等于判断会导致索引失效
where字句中的对索引列做运算会导致索引失效

in exists表连接方式不同
in、exists、distinct
in 适合于外表大(数据量较大)而内表小(数据量较小)的情况;
exists适合于外表小而内表大的情况,在某些情况下可以使用exist替换distinct
DISTINCT 在返回结果集中进行过滤 exists在过程中有值即返回

  • 4
    点赞
  • 86
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值