set linesize 120

set pagesize 20

column file_name format a8

v$nls_parameters 数据字典中的一个表

关于null的注意:

1:包含null的表达式结果为空

2:判断一个值是否等于null是用 is  不等于用is not 。记住(null!=null)

3:如果集合中含有null值,不能使用not in 但可以使用 in

sql 优化:

oracle9之后, *和列名的效率一样,在之前,用*列名效率比较高,因为oracle要解析*,所以效率比较慢

like的使用, 一个_代表匹配所有,多个_代表匹配多个字符,以S开头的 'S%',以S结尾的'%S',包含S的'%S%'

转移字符:escape 后面自顶一个转义字符

查询名字中含有_这个的

1 select *
2 from emp
3* where ename like '%\_%' escape '\'

使用and 时,应该尽量是假值在左边,使用or时应该尽量是真值在左边

排序:

如果要排序的值中含有空值,应当使其在后面  select * from emp order by comm desc nulls last;

修改系统日期的格式

select * from v$bls_parameters;

alter session set NLS_DATE_FORMAT='yyyy-mm-dd';原系统日期格式为'DD-MON-RR'

DISTINCT 去掉重复记录(作用它后面所有的列)

select DISTINCT deptno from emp;

单行函数:

字符函数

lower('Hello Word') 转小写 upper('Hello World') 转大写  select lower('Hello World'),upper('Hello World') from dual

substr(a,b)从a中,第b位开始取,取右边所有的字符 select substr('Hello World',3) from dual;

substr(a,b,c)从a中,第b位开始取,去的长度为c ,select substr('Hello World',2,3) from dual;

length('中国') 字符数  lengthb('中国')字节数 select length('中国'),lengthb('中国') from dual;

instr(a,b)从a中查找b,找到返回下标,否则返回0 select instr('Hello Word','ll') from dual;

lpad左填充 rpad右填充  select lpad('abcd',10,'*') from dual  把字符串abcd填充到第10位,用*填充

trim去掉前后指定的字符 select trim('H' from 'Hello WorldH') from dual;  意思是从 Hello WorldH 去掉H

replace 替换  select replace('hello world',2,'l','*') from dual;  把hello world 中所有字符l用*替换

数字函数

round(45.926,2)四舍五入函数,后面的数字为保留的小数位数 select round(45.926,2) ,round(45.926,1),round(45.926,0),round(45.926,-1),round(45.926,-2) from dual

trunc(45.926,2)一律舍去保留小数位后面的值,不管是否大于5还是小于4  select trunc(45.926,2) ,trunc(45.926,1),trunc(45.926,0),trunc(45.926,-1),trunc(45.926,-2) from dual

mod(1600,300) 求余 select mod(1600,300) from dual;

日期函数

select to_char(sysdate,'yyyy-mm-dd hh24:mi:ss') from dual; 秒级

select to_char(systimestamp,'yyyy-mm-dd hh24:mi:ss:ff') from dual; 毫秒级

昨天,今天,明天

select (sysdate-1), sysdate, (sysdate+1) from dual;

不允许日期+日期

months_between 两个日期相差的月数 select ename,months_between(sysdate,hiredate) from emp;

add_months 指定日期加上若干月数 select add_months(sysdate,100) from dual;

next_day 指定日期的下一个日期 select next_day(sysdate,'星期三') from dual;

last_day 日期所在月份的最后一天 select last_day(sysdate) from dual

round 日期四射五入 select round(sysdate,'month'), round(sysdate,'year'),round(sysdate,'day') from dual;

trunc 日期截断 select trunc (sysdate,'month'), trunc (sysdate,'year'),trunc (sysdate,'day') from dual;

转换函数

隐性转换(不需要你做什么,oracle数据库自动为你转换,前提是被转换对象是可以转换的)

显性转换(需要自己手动的转换)

显示当前时间 select to_char(sysdate,'yyyy-mm-dd hh24:mi:ss "今天是" day') from dual;

把某一个数字按一定格式转换成字符串

查询员工薪水:两位小数,货比代码,千位符

select to_char(sal,'9,999.99L') from emp;

oracle学习总结的更多相关文章

  1. Oracle学习笔记三 SQL命令

    SQL简介 SQL 支持下列类别的命令: 1.数据定义语言(DDL) 2.数据操纵语言(DML) 3.事务控制语言(TCL) 4.数据控制语言(DCL)  

  2. Oracle学习线路

    出自huyangg的博客,地址是:oracle学习路线图 1.sql.pl/sql(网上有很多的视频,可以做一个简单的入手,然后看几本书,多做实验)    作为oracle的基本功,需要大家对sql和 ...

  3. Oracle学习指南

    Oracle学习指南 你走的那天,我决定不落泪,迎着风撑着眼帘用力不眨眼 创建数据库.创建用户.创建表空间.创建表.插入数据..... 1.用系统用户登录,任选系统用户 代码: >>sql ...

  4. Oracle学习系列1-7

    Oracle学习系列1 两个服务必须启动: OracleOraDb10g*TNListener 和 OracleService*** 使用sqlplusw先进行环境的设置 set linesize 3 ...

  5. Oracle学习系列7

    Oracle学习系列7 ************************************************************************************ 关联表 ...

  6. Oracle学习系列6

    Oracle学习系列6 ************************************************************************************ 删除约 ...

  7. Oracle学习系列5

    Oracle学习系列5 ************************************************************************************ ,掌握 ...

  8. Oracle学习系列4

    Oracle学习系列4 ************************************************************************************ 数据库 ...

  9. Oracle学习系列3

    Oracle学习系列3 ************************************************************************************ 多表查 ...

  10. oracle学习笔记(一)用户管理

    --oracle学习第一天 --连接 @后面连接数据库实例,具体连接到那个数据库 conn scott/tiger@MYORA1; --修改密码 passw; --显示用户 show user; -- ...

随机推荐

  1. [001]socket通信--server和client实现迭代的简单例子

    server端: #include<stdio.h> #include<stdlib.h> #include<string.h> #include<unist ...

  2. myql定义和查看语句

     创建数据库: create database IF NOT EXISTS MY_TEST default charset utf8  COLLATE utf8_general_ci; 查看SQL语句 ...

  3. C#_数据库交互_SqlHelper

    using System; using System.Collections.Generic; using System.Text; using System.Data.SqlClient; usin ...

  4. qt-vs-addin-版本支持

    qt-vs-addin-1.2.0-opensource.exe         VS200X qt-vs-addin-1.2.1-opensource.exe         VS200X qt-v ...

  5. Android开发环境搭建完全图解(转)

    本文介绍从0开始,在Linux系统下,搭建一个Android开发环境的方法. 如果你是<Learning Android>这本书的读者,你也可以参考这篇文章,因为这篇文章是以书中的安装方法 ...

  6. 使用Mou 编写Markdown编辑器博客

    Mou Overview Mou, the missing Markdown editor for web developers. Syntax Strong and Emphasize strong ...

  7. java validator的原理与使用

    http://developer.51cto.com/art/201104/253257_1.htm ava EE 6核心特征:Bean Validation特性概述(2) 2011-04-02 14 ...

  8. typedef的使用3——使用经过typedef定义的函数构成的函数数组

    #include <stdio.h> #include <string.h>//不加还能跑,加上反而跑不了了...笑哭 #pragma warning(disable:4996 ...

  9. Excel导入导出帮助类

    /// <summary>    /// Excel导入导出帮助类    /// 记得引入 NPOI    /// 下载地址   http://npoi.codeplex.com/rele ...

  10. java基础学习总结三(jdk7新特性、变量(局部变量和成员变量)、常量以及运算符)

    一:jdk7新特性 可以表示二进制数值,以0b开头,中间可以使用下划线_分隔符.如下: @Test /** * 测试jdk新特性 */ public void testJdk7(){ int a=0b ...