演示如何使用select语句,接下来对emp、dept、salgrade表结构进行解说。

emp 雇员表

    字段名称   数据类型       是否为空   备注

    --------   -----------   --------   --------

    EMPNO    NUMBER()                 员工编号                

    ENAME    VARCHAR2() Y         员工名称        

    JOB        VARCHAR2()   Y         职位                

    MGR       NUMBER()       Y         上级的编号            

    HIREDATE DATE             Y         入职日期               

    SAL         NUMBER(,)   Y         月工资            

    COMM      NUMBER(,)   Y         奖金                

    DEPTNO   NUMBER()      Y         所属部门

    -------------------------------------------

    job字段:

    clerk 普员工

    salesman 销售

    manager 经理

    analyst 分析师

    president 总裁
dept 部门表

    字段名称    数据类型          是否为空   备注

    --------    -----------      --------   --------

    DEPTNO   NUMBER()                    部门编号               

    DNAME    VARCHAR2()    Y          部门名称        

    LOC         VARCHAR2()   Y          部门所在地点

    -------------------------------------------

    DNAME字段:

    accounting 财务部

    research 研发部

    operations 业务部

    salgrade 工资级别表

    字段名称  数据类型   是否为空  备注

    --------  ---------  --------  --------

    GRADE   NUMBER     Y         级别                

    LOSAL    NUMBER     Y         最低工资               

    HISAL     NUMBER     Y         最高工资

1、查看表结构

 desc emp;

2、查询所有列

 select * from dept;
--备注:切忌动不动就用select *,使用*效率比较低,特别在大表中要注意。

3、打开显示操作时间的开关,在底部显示操作时间。

set timing on/off;

eg: sql> insert into tb_stu values('0001','zhangsan',24);
1 row inserted
executed in 0.015 seconds

4、insert into ...select ... 表复制语句

  语法:insert into table2(field1,field2,...) select value1,value2,... from table1

--创建tb_dept

create table tb_dept
(
deptno number(4) not null,
dname varchar2(14),
loc varchar2(13)
)
--添加主键约束
alter table tb_dept add constraint tb_dept primary key (deptno);

  --insert into...select...用法 insert into tb_dept (deptno, dname, loc) select a.deptno, a.dname, a.loc from dept a;

5、统计 select count(*) from emp;

6、查询指定列 select ename, sal, job, deptno from emp;

7、如何取消重复行distinct select distinct deptno, job from emp;

8、查询smith所在部门,工作,薪水 select deptno, job, sal from emp where ename = 'smith'; 注意:oracle对内容的大小写是敏感的,所以ename='smith'和ename='SMITH'是不同的

9、nvl函数

格式为:nvl(string1, replace_with)   
功能:如果string1为null,则nvl函数返回replace_with的值,否则返回string1的值。  
注意事项:string1和replace_with必须为同一数据类型,除非显示的使用to_char函数。  
eg、如何显示每个雇员的年工资?
select sal*13+nvl(comm, 0)*13 "年薪" , ename, comm from emp;

10、使用列的别名 select ename "姓名", sal*12 as "年收入" from emp;

11、如何处理null值 使用nvl函数来处理

12、如何连接字符串(||) select ename || ' is a ' || job from emp;

13、使用where子句

问题:如何显示工资高于3000的员工?
select * from emp where sal > 3000; 问题:如何查找1982.1.1后入职的员工?
select ename,hiredate from emp where hiredate >'1-1 月-1982'; 问题:如何显示工资在2000到3000的员工?
select ename,sal from emp where sal>=2000 and sal<=3000;

14、如何使用like操作符

%:表示0到多个字符
_:表示任意单个字符 问题:如何显示首字符为s的员工姓名和工资?
select ename,sal from emp where ename like 's%'; 问题:如何显示第三个字符为大写o的所有员工的姓名和工资?
select ename,sal from emp where ename like '__o%';

15、在where条件中使用in

问题:如何显示empno为7844,7839,123,456的雇员情况?
select * from emp where empno in (7844, 7839, 123, 456);

16、使用is null的操作符

问题:如何显示没有上级的雇员的情况?
错误写法:select * from emp where mgr = '';
正确写法:select * from emp where mgr is null;

最新文章

  1. java web学习总结(二十六) -------------------JSP属性范围
  2. android应用中增加权限判断
  3. Arcgis API For IOS扩展AGSDynamicLayer新旧版API对比
  4. CentOS-6.5安装配置Tengine
  5. 实例演示 kino.razor (前端 Javascript 模板工具,Razor 风格)的使用
  6. visual studio 2005 编fortran程序,运行后dos窗口显示问题
  7. 离线安装maven,重新打开eclipse报错处理方法
  8. AspectJ给类的属性打桩,进行替换。
  9. 基于集合成工控机Ubuntu系统安装分区详解
  10. PaaS 调研:GAE与 AWS(上)
  11. Html5如何自学 只需这几步
  12. 当前时间、前n天、后n天、取前n条记录、从第n条开始取m条
  13. Cutting Codeforces Round #493 (Div. 2)
  14. iTerm2 与 Oh My Zsh的配套使用
  15. iOS弹出UIViewController小视图
  16. CF917D Stranger Trees
  17. uvalive 3887 Slim Span
  18. checked 选择框选中
  19. Requests中出现大量ASYNC_NETWORK_IO等待
  20. Codeforces 469 D. Two Sets (并查集)

热门文章

  1. springboot(七)JavaMail发送邮件
  2. 小白必看,Python入门你要懂那些
  3. Nginx安全优化与性能调优
  4. Dom运用1
  5. org.springframework.beans.factory.UnsatisfiedDependencyException异常
  6. 中国剩余定理(CRT)及其扩展(EXCRT)详解
  7. this.getClass().getResource(String) 路径问题
  8. MySQL-安装配置篇
  9. 关于DateTimeOffset的爱恨情仇
  10. 每日一道 LeetCode (8):删除排序数组中的重复项和移除元素