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:指定国家语言 ...
随机推荐
- 如何在CentOS 7上修改主机名
如何在CentOS 7上修改主机名 在CentOS中,有三种定义的主机名:静态的(static),瞬态的(transient),和灵活的(pretty).“静态”主机名也称为内核主机名,是系统在启动时 ...
- PHP MYSQL读取中文乱码的解决办法
其他试了很多种办法,结果最直接最简单的办法就是在SELECT前先发送设置.如下 mysqli_query($con,"SET NAMES 'UTF8'"); mysqli_quer ...
- Java导入证书失败Keystore was tampered with, or password was incorrect
keytool 错误: java.io.IOException: Keystore was tampered with, or password was incorrect 在进行证书相关操作, ...
- git clone 远程分支
先初始化一个git 仓库 命令:git init git clone 相应的地址 这样就会形成一个.git 隐藏文件夹 一定要注意的,要进入到子文件夹去git checkout feature/0. ...
- Js打开网页后居中显示
使用JavaScript定义打开网页后居中显示,并可为窗口设置大小,使用“window.open”方法打开新窗口:先来看完整的代码及调用方法: <html xmlns="http:// ...
- 文成小盆友python-num11-(2) python操作Memcache Redis
本部分主要内容: python操作memcache python操作redis 一.python 操作 memcache memcache是一套分布式的高速缓存系统,由LiveJournal的Brad ...
- 数值统计 AC 杭电
数值统计 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) Total Submi ...
- java-Mysql-SQLServer数据类型匹配速查表
java-Mysql-SQLServer数据类型匹配速查表 Mysql ************************************ 当前列 ClassName ColumnType Di ...
- 转:单片机C语言中的data,idata,xdata,pdata,code
从数据存储类型来说,8051系列有片内.片外程序存储器,片内.片外数据存储器,片内程序存储器还分直接寻址区和间接寻址类型,分别对应code.data.xdata.idata以及根据51系列特点而设定的 ...
- Android 之 AlertDialog 用户登录
1:activity_main.xml <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/androi ...