当前位置:  数据库>oracle

Oracle学习时关于SQL语言的总结

    来源: 互联网  发布时间:2017-05-12

    本文导语: 1、查询dept表的结构   在命令窗口输入:desc dept;   2、检索dept表中的所有列信息    select * from dept   3、检索emp表中的员工姓名、月收入及部门编号     select ename "员工姓名",sal "月收入",empno "部门编号" from emp   4、检索em...

1、查询dept表的结构 
 
在命令窗口输入:desc dept; 
 
2、检索dept表中的所有列信息 
 
 select * from dept 
 
3、检索emp表中的员工姓名、月收入及部门编号   
 
select ename "员工姓名",sal "月收入",empno "部门编号" from emp 
 
4、检索emp表中员工姓名、及雇佣时间    日期数据的默认显示格式为“DD-MM-YY",如果希望使用其他显示格式(YYYY-MM-DD),那么必须使用TO_CHAR函数进行转换。   
 
select ename "员工姓名", hiredate "雇用时间1",to_char(hiredate,'YYYY-MM-DD') "雇用时间2" from emp   
 
注意:第一个时间是日期类型的,在Oracle的查询界面它的旁边带有一个日历。第二个时间是字符型的。不要将YYYY-MM-DD使用双引号 
 
5、使用distinct去掉重复行。   
 
检索emp表中的部门编号及工种,并去掉重复行。                                                                                                                 
 
select  distinct deptno "部门编号",job "工种"  from emp order by deptno   
 
6、使用表达式来显示列    检索emp表中的员工姓名及全年的月收入   
 
select ename "员工姓名", (sal+nvl(comm,0))*12 "全年收入" from emp    注意:防止提成comm为空的操作,使用nvl函数 
 
7、使用列别名    用姓名显示员工姓名,用年收入显示全年月收入。   
 
select ename "员工姓名",sal*12 "全年收入" from emp 
 
8、连接字符串   
 
在oracle中连接字符串用“||”操作符来完成的,当连接字符串时,如果在字符串要加入数字值    那么在“||”后可以直接指定数字,如果在字符串加入字符和日期值,则必须要用单引号。   
 
检索emp表,用is a 这个字符串来连接员工姓名和工种两个字段   
 
select ename||' is a '||job "他们各自的职位"from emp    注意:用的是单引号!!! 
 
9、使用WHERE子句   
 
检索月收入大于2000的员工姓名及月收入。   
 
select ename "姓名" ,sal "月薪"from emp where sal>2000   
 
检索月收入在1000元到2000元的员工姓名、月收入及雇佣时间。   
 
select ename "姓名" ,sal "月薪",hiredate "雇佣时间" from emp where sal between 1000 and 2000 
 
10、like的用法:   
 
检索以S开头的员工姓名及月收入。   
 
select ename "员工姓名",sal "月收入" from emp where ename like 'S%'   
 
检索员工姓名中的第三个字符是A的员工姓名及月收入。   
 
select ename "员工姓名",sal "月收入" from emp where ename like '__A%'
 
11、在WHERE条件中使用IN操作符   
 
检索emp表中月收入是800的或是1250的员工姓名及部门编号   
 
select ename "姓名",deptno "部门编号",sal "工资" from emp where sal in(800,1250)      注意:IN的意思是或者。是800或者1250而不是表示范围 
 
12、在WHERE条件中使用逻辑操作符(AND、OR、NOT)   
 
显示在部门20中岗位CLERK的所有雇员信息   
 
select * from emp where deptno='20' and job='CLERK'   
 
显示工资高于2500或岗位为MANAGER的所有雇员信息   
 
select * from emp where sal>'2500' or job='MANAGER'      注意:在where里面的条件都是使用的单引号 
 
13、查询表中是空值的数据   
 
检索emp表中有提成的员工姓名、月收入及提成。   
 
select ename "姓名",comm "提成",sal "工资" from emp where comm is not null 
 
14、使用ORDER BY子句,进行排序。   
 
检索emp表中部门编号是30的员工姓名、月收入及提成,并要求其结果按月收入升序、然后按提成降序显示。   
 
select ename "姓名",comm "提成",sal "工资" from emp where deptno='30' order by sal asc,comm desc 
 
15、查询工资大于1200的员工姓名和工资   
 
select ename "姓名",sal "工资" from emp where sal>1200 
 
16、查询员工号为7934的员工的姓名和部门号   
 
select ename "姓名",deptno "部门编号" from emp where empno='7934' 
 
17、选择工资不在5000到12000的员工的姓名和工资   
 
select ename "姓名",sal "工资" from emp where sal not between 5000 and 12000    注意:不是 is not
 
18、选择雇用时间在1981-02-01到1981-05-01之间的员工姓名,职位(job)和雇用时间,按从早到晚排序.   
 
select ename "姓名",job "职位",hiredate "雇佣时间"    from emp where hiredate between to_date('1981-02-01','YYYY-MM-DD') and to_date('1981-05-01','YYYY-MM-DD')    order by hiredate asc   
 
19、选择在20或10号部门工作的员工姓名和部门号   
 
select ename "姓名",deptno "部门号" from emp where deptno in (20,10) 
 
20、选择在1987年雇用的员工的姓名和雇用时间   
 
select ename "姓名",hiredate "雇佣时间" from emp where to_char(hiredate,'YYYY')='1987'   
 
取出雇用时间的年份且转换为字符形式;然后与'1987'比较   
 
select ename "姓名",hiredate "雇佣时间" from emp where to_char(hiredate,'MM')='04'   
 
select ename "姓名",hiredate "雇佣时间" from emp where to_char(hiredate,'MM')='4'    前者是可以的,后者不可以 

    
 
 

您可能感兴趣的文章:

  • Linux下如何用C语言操作Oracle数据库相关的图书推荐
  • oracle中的空类型与c语言的空类型相匹配吗?
  • 怎样在c语言的代码里内嵌的操作oracle数据库,各位大虾谢谢了
  • 请问:ORACLE中的数据取出来后,需不需要进行一定的转换才能变为C语言的数据类型啊?
  • hpux下如何用c语言访问oracle数据库?
  • Oracle下时间转换在几种语言中的实现
  • 通过libsqlora8-2.2.10--c语言程序连接oracle数据库,需要连接,查询,修改等,急!!!
  • Oracle PL/SQL语言入门基础
  • Oracle数据操作和控制语言详解
  • Oracle认证:学好Oracle的六条总结
  • oracle服务启动与停止经验总结
  • Linux下Oracle常见安装错误总结及参考案例
  • Oracle中三种表连接算法的总结
  • Oracle、DB2、PostgreSQL之Sequence大总结
  • Oracle索引(B*tree与Bitmap)的学习总结
  • [Oracle] dbms_metadata.get_ddl 的使用方法总结
  • Oracle数据库中的字符处理技巧总结
  • Oracle数据字典的学习总结
  • Oracle 数据库优化实战心得总结
  • 深入ORACLE迁移到MYSQL的总结分析
  • oracle数据库sql的优化总结
  • Oracle 游标使用总结
  • oracle 日期时间函数使用总结
  • Oracle 存储过程总结(一、基本应用)
  • Oracle 存储过程总结 二、字符串处理相关函数
  • ORACLE 常用函数总结(80个)第1/2页
  •  
    本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
    本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。












  • 相关文章推荐
  • 循序渐进学习Oracle数据库
  • Linux+Oracle学习笔记
  • 想在linux下学习oracle,有经验的高手们给点建议。
  • Oracle 10G进程体系学习笔记
  • 怎样学习oracle
  • Linux 下 Oracle 命令学习笔记 iis7站长之家
  • oracle使用sql脚本生成csv文件案例学习
  • oracle 技巧学习笔记
  • 想学习UNIX,LINUX,ORACLE方面的知识。请帮忙。
  • 我该如何学习Linux和Oracle?
  • Oracle数据库基本知识学习笔记
  • 学习登录oracle数据库时常用的操作命令
  • 技巧学习 在Python环境下连接Oracle数据库
  • Oracle 数据库学习入门心得
  • Oracle与MySQL学习体会比较
  • oracle数据库学习
  • oracle数据库的学习体会
  • Oracle数据库入门学习经验分享
  • Oracle学习笔记(六)
  • 学习Linux下Oracle数据库编程
  • Oracle 12c发布简单介绍及官方下载地址
  • 在linux下安装oracle,如何设置让oracle自动启动!也就是让oracle那个服务自动启动,不是手动的
  • oracle 11g最新版官方下载地址
  • 请问su oracle 和su - oracle有什么不同?
  • Oracle 数据库(oracle Database)Select 多表关联查询方式
  • 虚拟机装Oracle R12与Oracle10g
  • Oracle数据库(Oracle Database)体系结构及基本组成介绍
  • Oracle 数据库开发工具 Oracle SQL Developer
  • 如何设置让Oracle SQL Developer显示的时间包含时分秒
  • Oracle EBS R12 支持 Oracle Database 11g
  • Oracle 10g和Oracle 11g网格技术介绍


  • 站内导航:


    特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

    ©2012-2021,