oracle select语句学习
来源:互联网 发布:西蒙斯夏季联赛数据 编辑:程序博客网 时间:2024/05/16 11:28
1>字符处理
upper(str)---将字符串str全部转换成大写
lower(str)---将字符串str全部转换成小写
initcap(str)---将字符串中每个单词的首字母大写
concat(str1,str2)---将字符串str1与str2连接起来(也可以通过'||'号直接相连)
substr(str,a,b)---取字符串str中的指定字符,从位置a开始取长度为b的字符串,假如a为正则从左边开始,否则从右边开始
instr(str,'z')---取得str字符串中从左边开始第一次出现z字符的下标位置(下标从1开始)
lpad(str,12,'*')---左填充,即将字符串str长度填充到12,假如其不足12位则在左边以*号填充
rpad(str,12,'*')---右填充,同上
length(str)---计算字符串str的长度
2>数字函数
round(45.926,2)---将前一数保留指定的小数位,并四舍五入(45.93),假如指定位是负数则意为在小数点左边保留指定位,如round(45.923,-1)=50,rount(45.923,0)=46,round(45.93,-2)=0,round(55.93,-2)=100
trunc(45.926,2)---同上,得不四舍五入(45.92)
mod(1600,300)---求余(100)
3>日期型函数
oracle中默认的格式是:DD-MON-RR。oracle中有个到当前系统时间--sysdate,如:select sysdate from dual
可对日期进行自述运算:select (sysdate-mybirthday)/7 from person
months_between('01-sep-95','11-jan-94')---取得二个日期之间的间隔月数(19.6774194)
add_months('11-jan-94',6)---给指定日期加上指定的月份后得到一个新的日期(11-jul-94)
next_day('01-sep-85','friday')---取得当前日期中下个周五的日期(01-jul-95)
last_day('01-feb-95')---取得当前日期中月份的最后一天(28-feb-95)
round进行四舍五入,
trunc则否,
以下是我的操作结果:sysdate为:SYSDATE----------28-7月 -06 select round(sysdate,'month') RM, round(sysdate,'year') RY, trunc(sysdate,'month') TM, trunc(sysdate,'year') TY from dual;
RM RY TM TY---------- ---------- ---------- ----------01-8月 -06 01-1月 -07 01-7月 -06 01-1月 -06
4>转换函数隐式转换:
系统自动转换,如:
varchar2 or char to number
varchar2 or char to date
number to varchar2
date to varchar2
显式转换:
人为以函数加以转换日期,字符,数据三者之间可以相互转换:
日期<-->字符<-->数据
日期格式:YYYY日期-->字符
select to_char(sysdate,'yyyy-mm-dd') ch from dual
CH----------2006-07-28
数字-->字符
to_char(number,'format_model'),oramat_model有如下:
9---用对应数字表示
0---强制用0表示
$---加一$符号
L---前加本地货币单位表示.
---十进制点,---千进制点select to_char(0917,'l9999.99') local from dual
LOCAL------------------ RMB917.00
字符-->日期
tselect to_date('19830917','yyyy-mm-dd') bir from dual
BIR----------17-9月 -83
字符-->数字
select to_number('19821217','999999999') mybr from dual
MYBR---------- 19821217
注:所有函数均可以嵌套使用
5>通用函数
nvl(expr1,expr2)---expr1为空则显示expr2,否则显示expr1
nvl2(expr1,expr2,expr3)---expr1为空则显示expr2,否则显示expr3
nullif(expr1,expr2)---二个相等则显示空符,否则显示expr1
coalesce(expr1,expr2,...,exprn)---从expr1开始依次找到不为空的expr,找到就显示,直到最后,否则显示exprn
case表达式,如下图:
6>多表查询对普通的多表查询,也就是不加where条件的时候实际上查询结果是各表的笛卡尔集外连接:oracle实现外连接时在=号的二边加+号就OK,当+在左边时称为右连接,反之为左连接,它常常用来当要求未受限制对象的表数据也要求显示
- oracle select语句学习
- Oracle学习----select基本语句
- Oracle学习笔记(二):基本SELECT语句
- oracle insert select语句
- Oracle select 查询语句
- oracle select语句
- Oracle之SELECT语句
- Oracle Select查询语句
- Oracle学习笔记 2 --简单查询语句(select)
- oracle 学习之:for循环中包涵select语句
- 01_基本SQL SELECT语句 - Oracle学习笔记
- 数据库SELECT语句学习
- select语句的用法--oracle
- Select 语句 oracle /MSSQL 对比
- Oracle Select SQL语句总结
- Oracle Select语句执行顺序
- oracle select into 动态语句
- Oracle select语句执行顺序
- 本机不安装Oracle客户端,使用PL/SQL Developer和 Instant Client 工具包连接oracle 11g远程数据库 .
- 软件架构设计之七:软件架构设计
- Eight_pku_1077(广搜).java
- 开发者所需要知道的iOS7 SDK新特性
- 轻量级远程调用框架-Hessian学习笔记-Demo实现
- oracle select语句学习
- SELECT INTO 和 INSERT INTO SELECT 两种表复制语句
- VS2005中使用GDI+准备工作
- Android ndk c++加入stl支持
- 新一代 Linux 文件系统 btrfs 简介
- timer
- MFC窗口分割类CSpliterWnd分割窗口
- 一次迭代式开发的研究2:什么是迭代式开发
- edittext focusListener