01-基本的查询语句

A:一些命令

  1. sqlplus sys/sys@192.168.22.220:1521/orcl as sysdba;
  2. conn scott/123456@192.168.22.210:1521/orcl; 从当前用户转换成scott用户
  3. show user; 显示当前用户名
  4. show linesize; 显示的行宽
  5. set linesize 150; 设置行宽
  6. col ename for a8; col sal for 9999;设置列ename为字符长度为8个长度;设置列sal为4位数字;
  7. c 命令字符替换,如: c /form/from 或者c!form!from
  8. host cls;清屏幕
  9. spool d:/1.sql 将命令写入到1.sql文件中。spool off终止写入文件中。

Bsql优化原则

  1. 查询的时候尽量使用列名;如:select ename,sal from emp;
  2. 分组查询没有多行函数(聚合函数),如果使用过滤,考虑使用where还是having
  3. 在子查询和多表查询之间选择,尽量使用多表查询
  4. 在集合运算中,如果union 和union all都可以,考虑使用union all 。因为union需要去掉重复的。
  5. 能够不要使用集合运算就不要使用集合运算。

注意:掌握oracle的常规命令,在学习过程中总结一些优化原则;

02-空值和别名

A:处理列值为null

oracle中的列值为null做四则运算结果都为null。处理方法:nvl(null,0)

B:判断列null

oracle中判断一个列值为null使用is null 或者is not null

C给一个列取一个别名可以使用as 或者省略as

select empno as “员工编号” , ename 员工姓名 from emp;

注意:别名需要使用“”,或者不加“”。别名中间有空格的需要“”;

不能使用单引号;

D:distinct 取出后面的所有列唯一

select distinct job,deptno from emp;这里的distinct作用于后面的所有的列。

select distinct(job) from emp;可以将加()

E:|| concat() 字符连接起来

select concat(‘hello’,’world’) from dual;使用concat()后面需要加表。mysql并严格遵循sql1990标准;

select ‘hello’ || ‘world’ from dual;

注意:字符串使用单引号‘’,不能使用双引号“”,使用双引号的是别名。

dual是伪表;

03-SQL和iSQLPLUS

A:sql、sqlplusisqlplus区别

  1. sql:insert update delete等常见的sql语句,关键词没有缩写。命令可以控制表中定义和数据;
  2. sqlplus:desc/ed/c/col/for等命令都是sqlplus命令,关键词有缩写,命令不能改变数据库中的数据;访问sqlplus服务端口是1158;
  3. isqlplus:是sqlplus是网页版本的sqlplus。可以执行脚本,也可以运行脚本;访问isqlplus服务需要访问5560端口;

04-过滤where

Awhere 后面比较运算符(>,<,!=,>=,<=,between and ,in,like,not like,is null,is not null

  1. 后面=可以接数据或者字符串,其中日期格式需要注意

如果select * from emp where hiredate=’81-09-08’ 执行会出现错误;

因为该日期字符串格式与oracle当前格式不一致,oralce无法处理成日期类型。但是可以修改日期格式;alter session|system set NLS_DATE_FORMATE=’yy-mm-dd’.select * from v$nls_parameters; 可以查看到系统的所有变量;

  1. between and (包括边界,小值在前,大值在后)
  2. in后面集合中可以加null,not in()集合中不能有null
  3. 注意:where 后面用于过滤或者连接其他表的条件,重点掌握常用>,<,!=,>=,<=,between and ,in,like,not like,is null,is not null操作;

05-逻辑运算符和排序

A:where 后面使用逻辑运算符(and ,or ,not)

注意:condition1 and condition2 和condition2 and condition1的区别;解析的顺序是从右边到左边;explain plan for select * from emp where condition1 and condition2;

B:查询排序(order by)

order by 列名/表达式/别名/序列. 且order by 后面可以接多个列

如果列中有值为null,则desc排序会出现null值行在前null最大,为了解决该问题:

select * from emp order by comm desc nulls last;

注意:order by 多个列参与排序的特殊性。

 06-函数简介

A:单行函数和多行函数

注意:操作返回一行数据的函数叫单行函数,操作返回的多行数据的函数叫多行函数;

07-字符函数和数值函数

A:字符函数

  1. 大小写控制

B:数值函数

  1. round():四舍五入
  1. truncate():截断

注意:重点掌握length(),substr(),instr(),round().

08-日期函数

A:日期函数

Oracle中提供了很多和日期相关的函数,包括日期的加减,在日期加减时有一些规律

日期 – 数字 = 日期

日期 + 数字 = 日期

日期 – 日期 = 数字

09-转换函数

Aoracle中隐式转换(查百度)

B:to_char():日期转换成字符串,数字转换成字符

Cto_number():字符串转换成数字

Dto_date():字符串转换成日期

注意:掌握to_char(),to_number(),to_date() ,3个转换函数;

10-通用函数和条件表达式

A:通用函数

  1. nvl(expr1,expr2) 如果repr1是null则把expr1处理成expr2
  2. nvl2(expr1,expr2,expr3),如果repr1不为null,则值为expr2,为null则返回expr3
  3. nullif(expr1,expr2),如果repr1=repr2,则返回null,否则返回expr1
  4. coalesce(expr1,expr2….), 依次参考各参数表达式,遇到非null值即停止并返回该值。
    如果所有的表达式都是空值,最终将返回一个空值B:条件表达式
    1. case  xx when xx then xx  when xxx  then xx else xx end;
    2. decode()

注意:nvl(),nvlif()和2个条件语句必须掌握。

11-多行函数

A:分组函数(avg(),max(),min(),count(),sum()

B:分组

group by  having  order by

注意:多行函数在sql中的使用;

oracle01的更多相关文章

  1. Oracle01——基本查询、过滤和排序、单行函数、多行函数和多表查询

    作者: kent鹏 转载请注明出处: http://www.cnblogs.com/xieyupeng/p/7272236.html Oracle的集群 Oracle的体系结构 SQL> --当 ...

  2. Oracle-01:基础命令小结

    ------------吾亦无他,唯手熟尔,谦卑若愚,好学若饥------------- 记录一下我的Oracle学习之路,详细的安装教程忙完这俩天会认真总结一版 本次记录这次学习cmd基础命令 一, ...

  3. 文件控制列表命令setfacl和getfacl的使用

    一 需求 有以下需求,通过setfacl命令实现 一组用户可写可读可执行,一组用户可写可执行,另一组用户只可读 linux rwx oracle wx uplook r 二 解决 第一步 添加六个用户 ...

  4. OCP读书笔记(26) - 题库(ExamF)

    501.Note the output of the following query;SQL> SELECT flashback_archieve_name, status FROM dba_f ...

  5. 【恢复】 Redo文件丢失的恢复

    第一章 Redo文件丢失的恢复 1.1  online redolog file 丢失 联机Redo日志是Oracle数据库中比较核心的文件,当Redo日志文件异常之后,数据库就无法正常启动,而且有丢 ...

  6. ORACLE监听配置及测试实验(2)

    实验四 在tnsname.ora里添加默认监听代号 [oracle@oracle01 admin]$ vi tnsnames.ora 添加一行 PORT1528=(ADDRESS = (PROTOCO ...

  7. ORACLE监听配置及测试实验

    实验一: 修改db_domain和service_name 我们将Db_name和Db_domain两个参数用'.'连接起来,表示一个数据库,并将该数据库的名称称为Global_name即等于serv ...

  8. ORACLE network environment

    监听程序 建立网络连接 要建立客户机或中间层连接,Oracle Net要求客户机 下列事项: 运行监听程序的主机 监听程序监视的端口 监听程序使用的协议 监听程序处理的服务名 Hostname/ip ...

  9. oracle RAC srvctl命令关闭节点实例的时候 不能正常执行

    场景描述: [oracle@oracle01 admin]$ srvctl stop database -d oradb1 PRCD- : The resource for database ORAD ...

随机推荐

  1. Task log(未)

    Keyword: fatal, crash, dead, out of memory, oom, anr in, non-protected File: main ,sys ,crash

  2. 【分享】2017 开源中国新增开源项目排行榜 TOP 100

    2017 年开源中国社区新增开源项目排行榜 TOP 100 新鲜出炉! 这份榜单根据 2017 年开源中国社区新收录的开源项目的关注度和活跃度整理而来,这份最受关注的 100 款开源项目榜单在一定程度 ...

  3. ETL实践--kettle转到hive

    ETL实践--kettle只做源数据的抽取,其他数据转换转到hive上. 1.用hive代替kettle的数据关联的原因 (1).公司之前的数据ELT大量使用了kettle.用kettle导原始数据速 ...

  4. 登陆模块的进化史,带大家回顾java学习历程(一)

    一直在想着写点特别点的东西,让有兴趣学编程的人确实能学到点干货,今天就来随意写写. 大家在网上查找资料看到最多的demo估计就是登陆功能的演示了,为何大家偏爱拿登陆来做demo呢?因为行业应用类程序的 ...

  5. 001_JS基础_JavaScript简介

    1.1 历史 JS的发展历史: http://www.w3school.com.cn/js/pro_js_history.asp 1.2 JavaScript简介 以下摘自维基百科对javascrip ...

  6. YDKJS:作用域与闭包

    作用域与闭包 什么是作用域 编译器 理解作用域 嵌套的作用域 词法作用域 词法分析时 欺骗词法作用域 函数与块作用域 函数中的作用域 隐藏标识符于普通作用域 函数作为作用域 块作为作用域 提升 先有鸡 ...

  7. flask动态url规则

    动态URL规则 URL规则可以添加变量部分,也就是件更符合同规则的URL抽象成一个URL模式. @app.route('/item/<id>') def item(id): return ...

  8. C#学习笔记-状态模式

    题目1:通过代码描述每一天的不同时间段的工作效率 分析: 首先确定,工作状态指正在工作,或者以及下班这些情况,而这些情况所受影响的因素包括:当前时间以及任务是否已经完成.所以在Work中需要两个属性: ...

  9. python的运维交流学习笔记

    #!/usr/bin/env | #!/usr/bin/python#coding:gbk #python 运维练习 #需求: #1.利用python实现自动监控服务器性能 #2.并将监控到的数据进行 ...

  10. 七牛php-sdk使用-文件上传

    使用七牛进行文件上传可以有多种方式: 直接form表单上传,需要自己按照文档做配置 使用七牛jssdk,部署较简单,大文件分片上传 php-sdk后台上传 首先,所有的上传方法以及所有的跟七牛接口相关 ...