oracle to_char 进制转换_〖Oracle 转载〗Oracle的数据类型转换 to_char
Oracle 基本语法
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,当+在左边时称为右连接,反之为左连接,它常常用来当要求未受限制对象的表数据也要求显示时,如下:
select * from student
ID NAME ADDRESS
-------------------- --------------
1 zhangshan zhejiang
3 lishi hangzhou
7 lily guangzhou
select * from person
ID NAME ADDRESS
- -------------------- -----------
1 zhangshan zhejiang
3 lishi hangzhou
7 lily guangzhou
select p.id,p.sex,s.id,s.name,s.address from person p ,student s where p.id(+) = s.id
ID SEX ID NAME ADDRESS
-- ---- ---------- -------------------- ------------
1 boy 1 zhangshan zhejiang
3 girl 3 lishi hangzhou
7 lily guangzhou
select p.id,p.sex,s.id,s.name,s.address from person p ,student s where p.id = s.id(+)
ID SEX ID NAME ADDRESS
-- ---- ---------- -------------------- --------------
1 boy 1 zhangshan zhejiang
2 girl
3 girl 3 lishi hangzhou
4 boy
5 girl
self-join,就是同一张表连接,用自连接的时候要注意排除重复的记录(自身,循环重复等),比如说找出student表中所有住在同一个地方的人。
select * from student
ID NAME ADDRESS
--- -------------------- ---------
1 zhangshan zhejiang
3 lishi hangzhou
7 lily guangzhou
2 name2 guangzhou
4 name4 guangzhou
5 name5 hangzhou
6 name6 shanghai
8 name8 shanghai
没有排除重复记录时的结果:
select t1.name,t2.name
from student t1, student t2
where t1.address = t2.address
NAME NAME
-------------------- --------------
lily lily
name2 lily
name4 lily
lily name2
name2 name2
name4 name2
lily name4
name2 name4
name4 name4
lishi lishi
name5 lishi
NAME NAME
-------------------- --------------
lishi name5
name5 name5
name6 name6
name8 name6
name6 name8
name8 name8
zhangshan zhangshan
已选择18行
排除重复与循环记录之后:
select t1.name,t2.name,t1.address
from student t1, student t2
where t1.address = t2.address
and t1.id > t2.id
NAME NAME ADDRESS
-------------------- -------------------- -------------------
lily name2 guangzhou
name4 name2 guangzhou
lily name4 guangzhou
name5 lishi hangzhou
name8 name6 shanghai
cross join,无条件连接,实际上跟不带where时一样得到的是笛卡尔集
natural join(也可以直接记作join),根据表中同名栏位来连接记录,若表中可能出现多个同名栏位,则用using(col_name)来指定所栏位。colname不能指定表的别名!限制条件用on来指定
select id,p.sex,id,s.name from person p join student s using(id);
ID SEX ID NAME
---- ---- ---------- --------------------
1 boy 1 zhangshan
2 girl 2 name2
3 girl 3 lishi
4 boy 4 name4
5 girl 5 name5
在sql标准语法中,左(右)连接用left(right) out join,限制条件用on就可以了。
full out join完全外连接,顾名思义就是左外连接与右外连接都有
select id,p.sex,id,s.name from person p full join student s using(id);
ID SEX ID NAME
---- ---- ---------- ------------------
1 boy 1 zhangshan
3 girl 3 lishi
2 girl 2 name2
4 boy 4 name4
5 girl 5 name5
8 8 name8
6 6 name6
7 7 lily
Oracle的数据类型转换 to_char(date)
Oracle的数据类型转换
Oracle的数据类型转换分为显式数据类型转换和隐式类型转换
在通常情况下,隐式数据类型转换是可用的,但建议你做显示数据类型转换以确保SQL的可靠性.
显式的数据类型转换包括:
to_number 字符转换为数字
to_date 字符转换为日期
to_char 数字转化为字符
to_char 日期转化为字符
TO_CHAR(date,'format_model')
必须加单引号,并且区分大小写
能够包含任一有效的日期格式元素
有一个fm元素用来删除填补的空,或者前导零
用一个逗号与日期值分开
select employee_id,to_char(hire_date,'MM/YY') as month
from employees
where last_name='Higgins'
employee_id month
205 06/94
select to_char(sysdate,'yyyy-mm-dd hh24:mi:ss am') as today from dual
2006-06-24 13:39:06 下午
select to_char(to_date('21-1月-95'),'yyyy-mm-dd hh24:mi:ss am') as today from dual
1995-01-21 00:00:00 上午
select to_char(sysdate,'dd "of" month') from dual
24 of 6月
select to_char(syadate,'yyyy-mm-dd cc') from dual
2006-06-24 21
cc:世纪
select to_char(sysdate,'yyy-mm-dd cc') as today from dual
006-06-24 21
select to_char(sysdate,'yy-mm-dd cc') as today from dual
06-06-24 21
select to_char(sysdate,'y,yyy-mm-dd cc') as today from dual
2,006-06-24 21
select to_char(sysdate,'y,yyy-mm-dd year') as today from dual
2,006-06-24 two thousand six
year:年份
select to_char(sysdate,'y,yyy-mm-dd ad year') as today from dual
2,006-06-24 two thousand 公元 six
ad:公元指示器
select to_char(sysdate,'y,yyy-mm-dd year "的" q "分之一" ') as today from dual
q:四份之一年
select to_char(sysdate,'y,yyy-month-dd ') as today from dual
2,006-6月-24
mont:带空格填充的名字
select to_char(sysdate,'y,yyy-rm-dd ') as today from dual
2,006-vi-24
rm:罗马数字月
select to_char(sysdate,'y,yyy "年的第"ww"周" ') as today from dual
2,006 年的第25周
年的周
select to_char(sysdate,'month "的第"w"周" ') as today from dual
6月的第四周
select to_char(sysdate,'y,yyy "的"ddd"天"') as today from dual
ddd:年的多少天
2,006年的第175天
select to_char(sysdate,'month "的"dd"天"') as today from dual
dd:月的多少天
6月的第24天
select to_char(sysdate,' y,yyy "的" ww "周的"d"天"') as today from dual
d:周的多少天
2,006年的第25周的7天
select to_char(sysdate,'"今天是"day') as today from dual
day:天的名称
今天是星期六
select to_char(sysdate,'"从公元前4713年12月31日开始的天数"j') as today from dual
从公元前4713年12月31日开始的天数2453911
J:从公元前4713年12月31日开始的天数
select to_char(sysdate,'yyyy-mm-dd HH12:mi:ssss') from dual
HH12:12小时数
mi:分钟数
ssss:午夜之后的秒
2006-06-24 02:47:1515
select to_char(sysdate,'yyyyth-mmsp-ddspth') from dual
后缀th序数(数字)
后缀sp拼写出数字
后缀spth拼写出序数
2006th-six-twenty-fourth
oracle to_char 进制转换_〖Oracle 转载〗Oracle的数据类型转换 to_char相关推荐
- javascript进制转换_《算法笔记》3.5小节——入门模拟-gt;进制转换
@[TOC] # Contest100000579 - <算法笔记>3.5小节--入门模拟->进制转换 ## 例题 ### PATB1022 PTA | 程序设计类实验辅助教学平台 ...
- (二) 数据存储_进制转换_编码_字节
文章目录 数据如何存储到计算机? 寄存器 高速缓冲存储器(Cache) 内存 硬盘 进制转换 [1] 十进制->二进制 [2] 二进制->十进制 [3] 十进制->八进制 [4] 八 ...
- python编码进制转换_关于Python|进制转换问题
本文的文字及图片来源于网络,仅供学习.交流使用,不具有任何商业用途,版权归原作者所有,如有问题请及时联系我们以作处理 以下文章来源于腾讯云,作者:算法与编程之美. 问题描述 给定n个十六进制正整数,输 ...
- python ascii码16进制转换_如何在Python十六进制整数和ASCii编码的字符串之间进行转换...
今天,我将与您分享一种将Python十六进制整数转换为ASCii编码的字符串的方法,该方法具有很好的参考价值,希望对大家有所帮助. 让我们一起关注小编,看看 当使用Pyserial与STM32通信时, ...
- python测试脚本 进制转换_使用Python进行新浪微博的mid和url互相转换实例(10进制和62进制互算)...
不过,status中包含了一个mid字段,通过mid,我们实际上是可以通过计算得到url的. 在开始计算之前有必要说明一下,什么是base62编码.它实际上就是十进制和62位进制的互换.对于62进制, ...
- c++进制转换_一文了解进制之间的原理和转换
点击这段文字: 获取2020年,最强Python学习资料 进制这块,可以做简单的了解.生活中我们使用的数字都是十进制的,而二进制是机器能够识别的最直接的语言.但是二进制又太大,记录起来非常的不方便.所 ...
- python123平台作业答案进制转换_各种进制转换详解-python
(1)各个进制的符号:b:二进制:o:八进制:d:十进制:x:十六进制 在python中,bin(),oct(),hex()返回值均为字符串而且会带有0b,0o,0o前缀 (2)各个进制相互转换 a) ...
- sublime16进制转换_编辑器、进制与进制转化
html编辑器 两种: 一.增强的文本编辑器 edplus.sublime.nodepad. 特点:体积小,运行速度快,没有语法提示.自动补全功能 二.IDE(集成开发环境) zend.dreamwe ...
- sublime16进制转换_[转]sublime 使用技巧总结
对于用惯了editplus的人来说,突然接触到sublime有点无所适从,不过稍微适应一段时间后,发现会渐渐的爱上这个小黑盒子. 那么sublime究竟好在啥地方呢? 我看最显著的特点就是他的智能联想 ...
- python 自定义进制转换_[python]从零开始学python——颜色的16进制于RGB之间的转换...
在学习openstack的时候,发现openstack是python开发的:学习mininet自定义拓扑,发现mininet是python开发的:看看ryu,还是python开发的--于是心中升起了自 ...
最新文章
- 上传程序网站至服务器
- 使用PHP对数据库输入进行恶意代码清除
- 全卷积神经网路【U-net项目实战】Unet++
- BackTrack5 R2快速更新至BackTrack5 R3
- observable_Java Observable deleteObserver()方法与示例
- C#内存流示例-----gt;用内存流来读取图片
- MSDN-MDX#001 - 多维表达式 (MDX) 参考
- 靠谱测试人员需具备解决问题能力
- 推荐SQL Server Management Studio以及Visual Studio下的免费的插件 ApexSQL Complete
- 虚拟机VMware 15安装教程
- python读取手机通讯录_python爬取通讯录
- android 五种存储方式,android数据五种存储
- 统计出库数,sql查询数据,sqldf做透视表,循坏处理数据
- vscode运行python没有结果输出
- 爬虫:利用python+requests爬取全国肯德基餐厅门店信息,并写入CSV文件中
- 正则 [.\n]* (.|\n)* 区别
- word中删除脚注中的横线
- 视达配色教程4 色相型和色量率是什么
- 去后厂村开游戏厅吧!基于PP-TinyPose的简易体感游戏开发框架
- 支持m1芯片超级无敌好用的OCR文字扫描工具Text Scanner
热门文章
- macos 系统固件 路径_如何查看MAC itunes下载的软件或固件
- Java架构师-集群:单体部署 ->Nginx 集群【网关、反向代理、动静分离、负载均衡】 -> Keepalived“高可用”组件 -> LVS负载均衡【LVS的并发量是Nginx的几十倍】
- 为什么大数据与云计算密不可分?
- 支付宝当面付_小小的支付完成页上,微信和支付宝“打起来了”
- 数据分析——R语言基础操作(1)-数据表示和矩阵基本操作
- 使用lio_sam建图,然后使用LIO-SAM_based_relocalization-master导航
- 万事开头难 实践出真知
- Power BI 中的货币换算
- 远程过程调用失败而且未执行怎么办
- 使用ZYNQ实现单LUT内容的动态修改(一)PL端OOC设计流程