SQL转换函数to_char/to_date/to_number
日期型->字符型转换函数to_char(d [,fmt]) 函数to_char(d [,fmt])用于将日期型数值转换为字符串(varchar2类型),其中参数d用于指定日期值,fmt用于指定要转换成的字符串的格式,也称模式串。如不给出参数fmt则系统会缺省采用与所在语言环境相关的默认格式。模式串中的字母(a~z, A~Z)也称日期模式符,被保留使用——相当于关键字,其中大部分被赋予特定含义,在对日期型数字的转换/解析过程中这些模式符将被替换成相应的时间域信息,表4-5列出了常用格式符及其含义。
常用日期模式符
格式符 说明 举例
yyyy 年份 2008
mm 用数字显示月份 02
dd 在当月中是第几天 28
day 星期几 星期五
am / pm 显示上午/下午 上午
hh / hh12 / hh24 小时 / 12小时制 / 24小时制 2:30 14:30
mi 分钟 30
ss 秒钟 46
SELECT EMPNO,HIREDATE,TO_CHAR(HIREDATE),TO_CHAR(HIREDATE,'YYYY-MM-DD') FROM EMP;
EMPNO HIREDATE TO_CHAR(HIREDATE) TO_CHAR(HIREDATE,'YYYY-MM-DD')
7369 1980/12/17 17-DEC-80 1980-12-17
7499 1981/2/20 20-FEB-81 1981-02-20
7521 1981/2/22 22-FEB-81 1981-02-22
7566 1981/4/2 02-APR-81 1981-04-02
7654 1981/9/28 28-SEP-81 1981-09-28
7698 1981/5/1 01-MAY-81 1981-05-01
7782 1981/6/9 09-JUN-81 1981-06-09
7788 1987/4/19 19-APR-87 1987-04-19
7839 1981/11/17 17-NOV-81 1981-11-17
7844 1981/9/8 08-SEP-81 1981-09-08
7876 1987/5/23 23-MAY-87 1987-05-23
7900 1981/12/3 03-DEC-81 1981-12-03
7902 1981/12/3 03-DEC-81 1981-12-03
7934 1982/1/23 23-JAN-82 1982-01-23
SELECT TO_CHAR(SYSDATE,'YYYY-MM-DD HH:MI:SS') FROM DUAL; --2014-06-14 05:54:50
SELECT TO_CHAR(SYSDATE,'YYYY/MM/DD HH:MI:SS') FROM DUAL; --2014/06/14 05:54:38
SELECT TO_CHAR(SYSDATE,'FMYYYY/MM/DD HH:MI:SS') FROM DUAL; --在模式串开头使用fm标记以去掉数字前面的零2014/6/14 5:55:56
SELECT TO_CHAR(SYSDATE,'YYYY "YEAR" MM "MONTH" DD "WEEK" DAY AM HH:MI:SS') FROM DUAL --2014 YEAR 06 MONTH 14 WEEK SATURDAY PM 05:59:25 --2014 YEAR 06 MONTH 14 DAY SATURDAY PM 05:59:25 --------语句中输入的是AM,结果显示为PM?Oracle会智能判断应该显示什么?
字符型->日期型转换函数to_date(char [,fmt]) 和前面的to_char()函数相对应,函数to_char(char[,fmt])用于将字符串型数值转换为日期型(DATE类型),其中参数char用于指定匹配于日期数据的字符串,模式串fmt用于指定日期模式、即按照何种模式解析前面的字符串,如不给出参数fmt则会按照当前语言环境相关的默认格式进行解析。例如:
DROP TABLE users;
CREATE TABLE users(name VARCHAR2(20), birth DATE);
INSERT INTO users VALUES('张三', '24-2月-2009');
INSERT INTO users VALUES('张三', to_date('24-2月-2009'));
INSERT INTO users VALUES('李四', to_date('2016-08-30', 'yyyy-mm-dd '));
其中,前两条INSERT语句完全等价,第一条语句中也是隐含调用了to_date()函数——先将匹配系统默认日期模式的字符串'24-2月-2009'转换为DATE类型、再执行新数据记录的插入操作。但如果字符串的格式不匹配则会出错。
数值型->字符型转换函数to_char(n [,fmt]) 函数to_char(n [,fmt])可将数字值转换为VARCHAR2型数据,通常用于数字值的格式化显示。其中参数n用于指定数字值,参数fmt用于指定转换成的格式,其性质及用法与前面的日期模式串类似,具体如表4-6所示。
表4-6 数字模式符
格式符 说明
9 代表一位数字,忽略前导的0
0 代表一位数字,强制显示0(如果位数不足,则用0补齐)
$ 放置一个美圆符$
L 放置一个本地货币符
C 放置一个国际货币符号
. 小数点
, 千位指示符
SELECT 12345.67, TO_CHAR(12345.67) AS C1, TO_CHAR(12345.67,'$999,999.0000') AS C2, TO_CHAR(12345.67,'$000,000,0000') AS C3 FROM DUAL;
12345.67 C1 C2 C3
12345.67 12345.67 $12,345.6700 $000,001,2346
字符型->数值型转换函数to_number(char [,fmt]) 与前述的to_char(n [,fmt])相对应,函数to_number(char [,fmt])的功能则是将字符串型数值转换/解析为数值型(NUMBER类型)。其中参数char用于指定要解析的字符串,参数fmt用于指定按照字符串的格式。如不给出参数fmt则会按照当前语言环境相关的默认格式进行解析。例如:
SELECT to_number('12345.678901') FROM dual;
SELECT to_number('$12,345.6789', '$99,999.0000') FROM dual;
DROP TABLE t1;
CREATE TABLE t1(name VARCHAR2(20), sal NUMBER);
INSERT INTO t1 values('王五', to_number('$12,345.6789', '$99,999.0000'));
SELECT * FROM t1;
SQL转换函数to_char/to_date/to_number的更多相关文章
- [SQL]oracle 的to_char、to_number、to_date用法
关键字: oracle 的to_char.to_number.to_date用法 TO_CHAR 是把日期或数字转换为字符串TO_DATE 是把字符串转换为数据库中得日期类型转换函数TO_NUMBER ...
- Oracle SQL函数之转换函数To_char汇总
TO_CHAR(x[[,c2],C3])[功能]将日期或数据转换为char数据类型[参数]x是一个date或number数据类型.c2为格式参数c3为NLS设置参数如果x为日期nlsparm=NLS_ ...
- 转换函数TO_CHAR,TO_DATE,TO_NUMBER
TO_CHAR:将日期.数字转为字符串. TO_DATE:将字符串转为日期(注:无数字转日期). TO_NUMBER:将字符串转为数字(注:无日期转数字).此函数作用不大,算术运算时Oracel会自动 ...
- SQL 转换函数
1.字符串与字符串相加 字符串相加 得到的是拼接成一列的字符串类型 例如 select name+code from car name是nvarchar code也是nvarchar ...
- SQL to_char,to_date日期字符串转换问题
1.转换函数 与date操作关系最大的就是两个转换函数:to_date(),to_char() to_date() 作用将字符类型按一定格式转化为日期类型: 具体用法:to_date('2004-11 ...
- SQL 日期函数转换
1.转换函数 与date操作关系最大的就是两个转换函数:to_date(),to_char() to_date() 作用将字符类型按一定格式转化为日期类型: 具体用法:to_date('2004-11 ...
- [转]SQL 常用函数及示例
原文地址:http://www.cnblogs.com/canyangfeixue/archive/2013/07/21/3203588.html --SQL 基础-->常用函数 --===== ...
- SQL 常用函数及示例
--SQL 基础-->常用函数 --================================== /* 一.函数的分类 SQL函数一般分为两种 单行函数 基于单行的处理,一行产生一个结果 ...
- Oracle 转换函数
Oracle 转换函数 -- TO_CHAR(date|number {,fmt} {,nlsparams}) fmt:格式内容,返回的字符串是什么格式的,在此处指定:nlsparams:指定国家语言 ...
随机推荐
- 初级班 Linux使用
ifconfig 查看IP地址 重新启动网卡服务 service network restart 笔记 1.通过远程工具登陆到linux后,所在的位置是当前登录用户的家目录(home director ...
- 工作中部署使用MP平台的一些问题
1.首先先把项目导入到myeclipse中,如果没有.classpath和.mymetadata和.project等文件,就自己创建一个web项目,然后把里面的src覆盖,webroot等文件覆盖. ...
- Cacti添加Advance Ping监控模板
Cacti脚本 1.Advance Ping 脚本及模板 注:要使用此模板,编译PHP时必须加上--enable-sockets选项来支持套接字. 1).功能:此模板用来监控一个TCP/U ...
- 关于Adobe Flash 11.3 引起的火狐使用问题
Adobe Flash 更新到11.3之后,为火狐引入Flash沙盒安全模式,但同时,又造成了部分兼容性问题,导致 Windows vista及 Windows 7上部分火狐崩溃,并致使一些使用Fla ...
- Swift中出现“no such module cocoa”的错误
在Swift开发中,新建了一个UIViewController的子类出现“No such module 'Cocoa' 的错误, 头部是import cocoa.. 原因很简单:在建立新的File文件 ...
- IntelliJ IDEA 12 创建Web项目 教程 超详细版
IntelliJ IDEA 12 新版本发布 第一时间去官网看了下 黑色的主题 很给力 大体使用了下 对于一开始就是用eclipse的童鞋们 估计很难从eclipse中走出来 当然 我也很艰难的走 ...
- 监听<input/>标签行为的方法总结
一.内容改变 1.<input onchange="javascript:function()"/>方法 onchange可以替换为下面几种:oninput,onpro ...
- Spring4.0学习笔记(2) —— 自动装配
Spring IOC 容器可以自动装配Bean,需要做的是在<bean>的autowire属性里指定自动装配的模式 1)byType 根据类型自动装配,若IOC 容器中有多个目标Bean类 ...
- jQuery 分割按钮(Split Button)
代码写多了,有些使用过的方法和技巧会一时半会想不起来,平日记录下来,方便自己和有需要的人日后查阅. <html> <head> <style type="tex ...
- javascript解析从服务器返回的json格式数据
在javascript中我们可以将服务器返回的json格式数据转换成json格式进行使用,如下: 1.服务器返回的json格式数据: 通过response.responseText获得: " ...