数据库中主要使用的数据类型:字符,数字,日期(时间戳)

日期、字符、数字之间可以完成互相转换功能;

函数名称

描述

TO_CHAR(日期 | 数字 | 列,转换格式)

      • 将指定的数据按照指定的格式变为字符串型
      • 格式化当前的日期时间

SQL> SELECT SYSDATE,TO_CHAR(SYSDATE,'YY-MM-DD HH24:MI:SS') FROM DUAL;

SYSDATE            TO_CHAR(SYSDATE,'

------------------ -----------------

24-JUL-17          17-07-24 17:15:53

SELECT SYSDATE 当前系统时间 ,TO_CHAR(SYSDATE,'YYYY-MM-DD') 格式化日期 ,

TO_CHAR(SYSDATE,'YYYY-MM-DD HH24:MI:SS') 格式化日期时间 ,

TO_CHAR(SYSDATE,'FMYYYY-MM-DD HH24:MI:SS') 去掉前导0的日期时间

FROM dual ;

使用FM可以取消前导0,但不建议去掉.

      • 使用其他方法格式化年、月、日

SELECT SYSDATE ,TO_CHAR(SYSDATE,'YEAR-MONTH-DY')

FROM dual ;

      • 查询出所有在每年2月份雇佣的雇员信息

SELECT * FROM emp WHERE TO_CHAR(hiredate,'MM')='02' ;

SELECT * FROM emp WHERE TO_CHAR(hiredate,'MM')=2 ;

      • 将每个雇员的雇佣日期进行格式化显示,要求所有的雇佣日期可以按照“年-月-日”的形式显示,也可以将雇佣的年、月、日拆开分别显示

SELECT   empno,ename,job,hiredate,

TO_CHAR(hiredate,'YYYY-MM-DD') 格式化雇佣日期, TO_CHAR(hiredate,'YYYY') 年 ,

TO_CHAR(hiredate,'MM') 月,TO_CHAR(hiredate,'DD') 日

FROM emp ;

      • 使用英文的日期格式表示出每个雇员的雇佣日期

SELECT empno ,ename , hiredate ,TO_CHAR(hiredate,'YEAR-MONTH-DY') FROM emp ;

TO_DATE(字符串 | 列,转换格式)

将指定字符串按照指定的格式变为DATE型

SELECT TO_DATE('1979-09-19','YYYY-MM-DD') FROM dual ;

TO_NUMBER(字符串 | 列)

      • 将指定的数据类型变为数字型

1、格式化数字:

      • 格式化数字显示

SELECT TO_CHAR(987654321.789,'999,999,999,999.99999') 格式化数字 ,

TO_CHAR(987654321.789,'000,000,000,000.00000') 格式化数字

FROM dual ;

      • 格式化货币显示

SELECT TO_CHAR(987654321.789,'L999,999,999,999.99999') 显示货币 ,

TO_CHAR(987654321.789,'$999,999,999,999.99999') 显示美元

FROM dual ;

2、字符串变为数字.

      • 使用TO_NUMBER()函数将字符串变为数字

SELECT TO_NUMBER('09') + TO_NUMBER('19') 加法计算 ,

TO_NUMBER('09') * TO_NUMBER('19') 乘法计算

FROM dual ;

      • 不利用TO_NUMBER()函数字符串也可以自动变为数字

SELECT '09' + '19' 加法计算 , '09' * '19' 乘法计算 FROM dual ;

TO_TIMESTAMP

      • 使用TO_TIMESTAMP()函数

SELECT    TO_TIMESTAMP('1981-09-27 18:07:10','YYYY-MM-DD HH24:MI:SS') datetime

FROM dual ;

日期格式化标记:

转换格式

描述

YYYY

完整的年份数字表示,年有四位,所以使用四个Y

Y,YYY

带逗号的年

YYY

年的后三位

YY

年的后两位

Y

年的最后一位

YEAR

年份的文字表示,直接表示四位的年

MONTH

月份的文字表示,直接表示两位的月

MM

用两位数字来表示月份,月有两位,所以使用两个M

DAY

天数的文字表示

DDD

表示一年里的天数(001 ~ 366)

DD

表示一月里的天数(01 ~ 31)

D

表示一周里的天数(1 ~ 7)

DY

用文字表示星期几

WW

表示一年里的周数

W

表示一月里的周数

HH

表示12小时制,小时是两位数字,使用两个H

HH24

表示24小时制

MI

表示分钟

SS

表示秒,秒是两位数字,使用两个S

SSSSS

午夜之后的秒数字表示(0 ~ 86399)

AM | PM(A.M. | P.M.)

表示上午或下午

FM

去掉查询后的前导0,该标记用于时间模板的后缀

数字格式化标识:

转换格式

描述

9

表示一位数字

0

显示前导0

$

将货币的符号显示为美圆符号

L

根据语言环境不同,自动选择货币符号

.

显示小数点

,

显示千位符

Using Conversion Functions

In some cases, the Oracle server receives data of one data type where it expects data of a different data type. When this happens, the Oracle server can automatically convert the data to the expected data type. This data type conversion can be done implicitly隐式 by the Oracle server or explicitly显式 by the user.

隐式

Implicit

Implicit Data Type Conversion

A VARCHAR2 or CHAR value can be implicitly converted to NUMBER or DATE type value by Oracle. Similarly, a NUMBER or DATA type value can be automatically converted to character data by Oracle server. Note that the impicit interconversion happens only when the character represents the a valid number or date type value respectively.

Implicit data type conversions work according to the rules explained in the following sides.

In expressions, the Oracle server can automatically convert the following:

在表达式中,一个字符串值能被隐式转换为数字或日期类型。

字符串到数字的转换只有当字符串表示一个合法的数字时才能成功.

From

To

VARCHAR2 or CHAR

NUMBER

VARCHAR2 or CHAR

DATE

NUMBER

VARCHAR2 or CHAR

DATE

VARCHAR2 or CHAR

显式

Explicit

Explicit Data Type Conversion

SQL Conversion functions are single row functions which are capable of typecasting column value, literal or an expression . TO_CHAR, TO_NUMBER and TO_DATE are the three functions which perform cross modification of data types.

Explicit data type conversions are performed by using the conversion functions.

Conversion functions convert a value from one data type to another.

Generally, the form of the function names follows the convention data type TO data type.

The first data type is the input data type and the second data type is the output.

显示数据类型转换通过转换函数执行。转换函数将一个值从一种类型转换成另一种类型.

Function

Purpose

TO_CHAR(number | date,[fmt],[nlsparams])

Converts a number or date value to a VARCHAR2 character string with the format model fmt.

fmt是格式模型,指定转换后的字符串的格式.

TO_NUMBER(char,[fmt],[nlsparams])

将字符串转换为数字

TO_DATE(char,[fmt],[nlsparams])

将字符转换为时间

SQL Fundamentals || Single-Row Functions || 转换函数 Conversion function的更多相关文章

  1. 转换函数conversion function

    类转换分为两个角度 转换自身为其他类型 把其他类型转换为自身 Example: 这里我们可以将b转换为class xxx 的类型(方式2),也可以将me转换为double,然后再讲结果转换为doubl ...

  2. SQL Fundamentals: Using Single-Row Functions to Customize Output使用单行函数自定义输出

    SQL Fundamentals || Oracle SQL语言 DUAL is a public table that you can use to view results from functi ...

  3. SQL Fundamentals: 子查询 || 行列转换(PIVOT,UNPIVOT,DECODE),设置数据层次(LEVEL...CONNECT BY)

    SQL Fundamentals || Oracle SQL语言 子查询(基础) 1.认识子查询 2.WHERE子句中使用子查询 3.在HAVING子句中使用子查询 4.在FROM子句中使用子查询 5 ...

  4. SQL Fundamentals || Single-Row Functions || 字符函数 character functions

    SQL Fundamentals || Oracle SQL语言   SQL Fundamentals: Using Single-Row Functions to Customize Output使 ...

  5. SQL Fundamentals || Single-Row Functions || 日期函数date functions

    SQL Fundamentals || Oracle SQL语言   SQL Fundamentals: Using Single-Row Functions to Customize Output使 ...

  6. SQL Fundamentals || Single-Row Functions || 数字函数number functions

    SQL Fundamentals || Oracle SQL语言 SQL Fundamentals: Using Single-Row Functions to Customize Output使用单 ...

  7. SQL Fundamentals || Single-Row Functions || 通用函数 General function || (NVL,NVL2,NULLIF,DECODE,CASE,COALESCE)

    SQL Fundamentals || Oracle SQL语言 SQL Fundamentals: Using Single-Row Functions to Customize Output使用单 ...

  8. SQL Fundamentals || Oracle SQL语言

    对于SQL语言,有两个组成部分: DML(data manipulation language) 它们是SELECT.UPDATE.INSERT.DELETE,就象它的名字一样,这4条命令是用来对数据 ...

  9. C++面向对象高级编程(六)转换函数与non-explicit one argument ctor

    技术在于交流.沟通,转载请注明出处并保持作品的完整性. 1.conversion function 转换函数 //1.转换函数 //conversion function //只要你认为合理 你可以任 ...

随机推荐

  1. MyBatis 支持的扩展点(version:3.2.7)

    从 [MyBatis 原码解析(version:3.2.7)] 中,我们得知,MyBatis去执行SQL都是通过 DefaultSqlSession 中的工具方法去执行的. 那么问题来了,MyBati ...

  2. 如何重新排列数组使得数组左边为奇数,右边为偶数,并使得空间复杂度为O(1),时间复杂度为O(n)

    思路分析: 类似快速排序的处理.可以用两个指针分别指向数组的头和尾,头指针正向遍历数组,找到第一个偶数,尾指针逆向遍历数组,找到第一个奇数,使用引用参数传值交换两个指针指向的数字,然后两指针沿着相应的 ...

  3. 架构设计:系统存储(28)——分布式文件系统Ceph(挂载)

    (接上文<架构设计:系统存储(27)--分布式文件系统Ceph(安装)>) 3. 连接到Ceph系统 3-1. 连接客户端 完毕Ceph文件系统的创建过程后.就能够让客户端连接过去. Ce ...

  4. 浅谈Java的学习

    Java就是用来做项目的!Java的主要应用领域就是企业级的项目开发!要想从事企业级的项目开发,你必须掌握如下要点: 1.掌握项目开发的基本步骤2.具备极强的面向对象的分析与设计技巧3.掌握用例驱动. ...

  5. 大杂烩 -- Iterator 和 Iterable 区别和联系

    基础大杂烩 -- 目录 用Iterator模式实现遍历集合  Iterator模式是用于遍历集合类的标准访问方法.它可以把访问逻辑从不同类型的集合类中抽象出来,从而避免向客户端暴露集合的内部结构. 例 ...

  6. 6.824 Lab 5: Caching Extents

    Introduction In this lab you will modify YFS to cache extents, reducing the load on the extent serve ...

  7. html+jquery制作网页地图

    http://jvectormap.com/ <!--StartFragment --> JVectorMap 是一个显示矢量地图的jQuery插件.它使用 SVG 在Firefox 3 ...

  8. CentOS 6.3 + Subversion + Usvn 搭建版本管理服务器

    一. Subversion 简介 Subversion是一个自由,开源的版本控制系统.在Subversion管理下,文件和目录可以超越时空.Subversion将文件存放在中心版本库里.这个版本库很像 ...

  9. 【代码审计】QYKCMS_v4.3.2 任意文件上传漏洞分析

      0x00 环境准备 QYKCMS官网:http://www.qykcms.com/ 网站源码版本:QYKCMS_v4.3.2(企业站主题) 程序源码下载:http://bbs.qingyunke. ...

  10. LINUX安装中文输入法和那些大坑

    明明有很多事要做,却偏偏不知道要做什么,这种感觉,很令人上火. 一.基础知识 在原生ubuntu14.04英文环境系统中只有IBus拼音,真的好难用.由于搜狗输入法确实比Linux系统下其它的中文输入 ...