Oracle 总结

Oracle常规命令

conn 用户/密码--客户端连接的命令
show user —显示当前登录的用户

增删改查

insect into 表名(列名列表) values(值列表);

删除符合条件数据
delete from EMP where ENAME= ‘xxx’;

删除所有EMP 所有数据
delete from EMP;

截断表
truncate table EMP;

注意:
当使用DELETE语句删除表数据时,不会释放表所占用的空间,如果用户确定要删除表的所有数据,那么使用截断表更快,并释放表段所占用的空间,注意,DELETE语句可回滚数据,截断表不可回滚数据

更新一列数据
update 表名 set 字段=where 字段=;

更新多列数据
update 表名 set PRICE=PRICE*0.8, NAME=‘值’  where 字段=;

使用默认值修改数据
update EMP set JOB=default where ENAME=‘SCOTT’;

注意:
ORACLE中日期列不能直接插入字符串,需使用日期函数转换 TO_DATE(数 据,’YYYY-MM-DD’`


1.使用select 关键字

select 列名 from 表名;

select * from 表名 where 字段>数值;
select * from 表名 where PRICE>50;

--显示工资在2000到2500工资
select * from 表名 where 字段>=2000 AND 字段<=2500;
select * from 表明 where 字段 BETWEEN 2000 AND 2500

2.模糊查询,使用关键字 like

%:表示任意0到多个字符  ;
_ : 表示任意单个字符

--如何显示首字母为S的员工姓名及工资
select EANAME, SAL from 表名 where EANAME LIKE 'S%' ;

--如何显示第三个字母为O的所有员工姓名及工资
select EANAME, SAL from 表名 where EANAME LIKE '_ _O%';

3.对查询数据排序,使用关键字 order by

ASC:正序
DESC:倒序
格式:
select emame,sal from emp where sal is not null order by sal desc;

4.分组查询,使用关键字group by

查询每个部门员工的数量
select deptno, count(*) 数量 from emp group by deptno;

5.对分组之后的结果进行查询,使用关键字having

查询平均工资大于两千的部门及部门人数
select DEPTNO,count(*) 数量 from EMP group by DEPTNO having AVG(SAL)>2000;

基础表查询

01.查询emp表的所有数据

select * from emp;

02.查询emp表中ename,job,sal几列,其中sal列在结果集中以别名salary查询

select ename,job,sal salary from emp;

03.查询emp表中deptno,ename,年工资,并将年工资命名别名total salary

select deptno,ename,nvl(sal,0)*12 as “total salary” from emp;

04.查看emp表的结构

desc emp;

05.查询emp表中雇员号,雇员的名字,工作岗位,入职日期

select empno,ename,job,hiredate from emp;

06.查询员工表中部门编号,重复的部门编号只查询一次

select distinct deptno as ”部门编号” from emp;

07.在结果集中雇员名和工作岗位相连用"空格逗号空格"分隔,并将列头查询为Employee and Title。

select ename ||,|| job as “Employee and Title” from emp;

08 查询职位(JOB)为’PRESIDENT’的员工的工资

select sal from emp where job = ‘PRESIDENT’;

09 查询佣金(COMM)为0 或为NULL 的员工信息

select * from emp where comm = 0 or comm is null;

10 查询入职日期在1981-5-1 到1981-12-31 之间的所有员工信息

select * from emp where hiredate between
to_date(1981/05/01,‘yyyy/mm/DD’) and
to_date(1981/12/31,‘yyyy/mm/DD’);

11 显示10 号部门的所有经理(‘MANAGER’)和20 号部门的所有职员(‘CLERK’)的详细信息

select * from emp where (deptno = 10 and job = ‘MANAGER’) or (deptno =
20 and job = ‘CLERK’);

12 显示姓名中没有’L’字的员工的详细信息或含有’SM’字的员工信息

select * from emp where ename not like%L%or ename like%SM%;

13 显示各个部门经理(‘MANAGER’)的工资

select sal as 工资 , deptno as 部门 from emp where job = ‘MANAGER’;

14 显示佣金(COMM)收入比工资(SAL)高的员工的详细信息

select * from emp where comm > sal;

15 按照入职日期由新到旧排列员工信息

select * from emp order by hiredate desc;

varchar2和char的区别:

varchar2或者varchar为可变长度的字符类型,比如varchar2(10),实际保存了5个字符abcde,剩下的5个长度的空间不会去补充空格占满整个10个长度,而是自动缩小到五个长度,所以叫可变长度的字符类型,好处为节约空间。

字符类型char,定义是要指定长度,比如char(10), 不可以变的长度的字符类型,比如保存了2个字符ab,剩下的8个长度补空格填满,浪费空间,一般用于长度比较小的字段,比如性别char(3)
保存数据男或女
  • 8
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

二炮

你的鼓励将是我最大的动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值