搜尋
首頁資料庫mysql教程ORACLE单行函数与多行函数之五:转换函数示例

一、数据类型的隐式转换规则: 字符串可以转化为数字和日期。数字要合法,日期要式匹配。 下面两句执行结果一样: BYS@bys1select ename,empno from emp where empno='7788'; BYS@bys1select ename,empno from emp where empno=7788; ENAME EMPNO ----------

一、数据类型的隐式转换规则:

字符串可以转化为数字和日期。数字要合法,日期要格式匹配。
下面两句执行结果一样:
BYS@bys1>select ename,empno from emp where empno='7788';
BYS@bys1>select ename,empno from emp where empno=7788;
ENAME           EMPNO
---------- ----------
SCOTT            7788
数字和日期在赋值的时候也可以转为字符串,但在表达式的时候不可以转换。如下:
BYS@bys1>select ename,empno from emp where ename='123';
no rows selected
BYS@bys1>select ename,empno from emp where ename=123;
select ename,empno from emp where ename=123
                                  *
ERROR at line 1:
ORA-01722: invalid number
TO_DATE能否隐式转换的示例:http://blog.csdn.net/q947817003/article/details/13015993
######################################################################################

二、最常用的转换函数:TO_CHAR,TO_DATE,TO_NUMBER

TO_CHAR 将给出的日期、数字转换为字符。

日期类型转换为字符类型:加fm消除前置的0或空格,还可以使用双引号来加入字符。
select to_char(sysdate,'yyyy/mm/dd hh24:mi:ss'),to_char(sysdate,'fmyyyy"年"/mm/dd hh24:mi:ss') from dual;
TO_CHAR(SYSDATE,'YYYY/MM/DDHH2 TO_CHAR(SYSDATE,'FMYYYY"年"/MM
------------------------------ ------------------------------
2013/11/02 20:10:07            2013年/11/2 20:10:7
to_char转换数字类型
9是代表有多少宽度,如果不足会显示成######;0代表强制显示0,可以放在最后或最前,但不会改变你的结果;G是千分符,D是小数点;可以在数字前加货币符号$,会强制显示。
select to_char(456789) as a1,to_char(456789,'00999,999.0000') as a2,to_char(456789,'$999,999.00') as a3,to_char(456789,'$999G999D00') as a4,to_char(456789,'$99,999.00') as a5 from dual;
A1     A2              A3           A4           A5
------ --------------- ------------ ------------ -----------
456789  00456,789.0000  $456,789.00  $456,789.00 ###########

将十进制的数转换为十六进制的数请使用to_char函数。

数据库中16进制的表达是按照字符串来描述的,所以将十进制的数转换为十六进制的数使用to_char函数

BYS@bys1>select to_char(10,'xxx'), to_char(42,'xxx') from dual;
TO_C TO_C
---- ----

   a   2a

TO_NUMBER将给出的字符转换为数字

SQL> select to_number('1999') year from dual;

     YEAR
---------
     1999
将十六进制的数转换为十进制的数请使用to_number函数。
如下,16进制A是10.2A是2*16+A=42.注意xxx,如果转换的数比较大,要多写几个,避免位数不足而报错。
BYS@bys1>select to_number('a','xxx'), to_number('2a','xxx') from dual;
TO_NUMBER('A','XXX') TO_NUMBER('2A','XXX')
-------------------- ---------------------
                  10                    42

TO_DATE(string,'format')  将字符串转化为ORACLE中的一个日期.注意日期是格式和语言敏感的。

更多在http://blog.csdn.net/q947817003/article/details/13015993

BYS@bys1>select to_date('2013/10/25 19:40:31' ,'yyyy-mm-dd hh24:mi:ss') from dual;
TO_DATE('2013/10/25
-------------------

2013/10/25 19:40:31

下面例子引用引烈讲义:

yy是两位来表示年,世纪永远和说话者的当前世纪相同。
RR比较灵活,它将世纪分为上半世纪和下半世纪。如果你处于上半世纪,描述的是0-49,那么就和当前世纪相同,描述的是50-99就是上世纪。如果你处于下半世纪,描述的是0-49,那么是下个世纪,描述的是50-99就是当前世纪。从而可以看出,RR的设计完全为了1990年到2010之间我们的思维习惯而设计的。当我们时间到2050前后,使用起来就非常的别扭。

select to_char(sysdate,'yyyy') "当前",to_char(to_date('98','yy'),'yyyy') "yy98",to_char(to_date('08','yy'),'yyyy') "yy08",to_char(to_date('98','rr'),'yyyy') "rr98",to_char(to_date('08','rr'),'yyyy') "rr08" from dual;
当前 yy98 yy08 rr98 rr08
---- ---- ---- ---- ----
2013 2098 2008 1998 2008

##########################################################################################################################################

三、其它转换函数--有些不懂尚未实验

1.GREATEST  返回一组表达式中的最大值,即比较字符的编码大小.

.LEAST  返回一组表达式中的最小值
SQL> select greatest('AA','AB','AC') from dual;

GR
--
AC
SQL> select greatest('白','李','张') from dual;
GREATEST('白','李','张')
------------------------

SQL> select least('白','李','张') from dual;
LEAST('白','李','张')
---------------------

2.CHARTOROWID  将字符数据类型转换为ROWID类型

ROWIDTOCHAR     将ROWID数据类型转换为字符类型
BYS@bys1>select rowid,rowidtochar(rowid),chartorowid(rowidtochar(rowid)),ename from emp where rownum ROWID              ROWIDTOCHAR(ROWID) CHARTOROWID(ROWIDT ENAME
------------------ ------------------ ------------------ ----------
AAAST0AAEAAAALDAAA AAAST0AAEAAAALDAAA AAAST0AAEAAAALDAAA SMITH

3.CONVERT(c,dset,sset)

将源字符串 sset从一个语言字符集转换到另一个目的dset字符集
SQL> select convert('strutz','we8hp','f7dec') "conversion" from dual;
conver
------
strutz

4.DUMP(s,fmt,start,length)

DUMP函数以fmt指定的内部数字格式返回一个VARCHAR2类型的值
SQL> select global_name,dump(global_name,1017,8,5) dump_string from global_name;
GLOBAL_NAME                    DUMP_STRING
------------------------------ --------------------------------------------------
ORACLE.WORLD                   Typ=1 Len=12 CharacterSet=ZHS16GBK: W,O,R,L,D

5.BFILENAME(dir,file)
指定一个外部二进制文件
SQL>insert into file_tb1 values(bfilename('lob_dir1','image1.gif'));

6.CONVERT('x','desc','source')
将x字段或变量的源source转换为desc

7.EMPTY_BLOB()和EMPTY_CLOB()
这两个函数都是用来对大数据类型字段进行初始化操作的函数





陳述
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
oracle怎么查询所有索引oracle怎么查询所有索引May 13, 2022 pm 05:23 PM

方法:1、利用“select*from user_indexes where table_name=表名”语句查询表中索引;2、利用“select*from all_indexes where table_name=表名”语句查询所有索引。

什么是oracle asm什么是oracle asmApr 18, 2022 pm 04:16 PM

oracle asm指的是“自动存储管理”,是一种卷管理器,可自动管理磁盘组并提供有效的数据冗余功能;它是做为单独的Oracle实例实施和部署。asm的优势:1、配置简单、可最大化推动数据库合并的存储资源利用;2、支持BIGFILE文件等。

oracle全角怎么转半角oracle全角怎么转半角May 13, 2022 pm 03:21 PM

在oracle中,可以利用“TO_SINGLE_BYTE(String)”将全角转换为半角;“TO_SINGLE_BYTE”函数可以将参数中所有多字节字符都替换为等价的单字节字符,只有当数据库字符集同时包含多字节和单字节字符的时候有效。

Oracle怎么查询端口号Oracle怎么查询端口号May 13, 2022 am 10:10 AM

在Oracle中,可利用lsnrctl命令查询端口号,该命令是Oracle的监听命令;在启动、关闭或重启oracle监听器之前可使用该命令检查oracle监听器的状态,语法为“lsnrctl status”,结果PORT后的内容就是端口号。

oracle怎么删除sequenceoracle怎么删除sequenceMay 13, 2022 pm 03:35 PM

在oracle中,可以利用“drop sequence sequence名”来删除sequence;sequence是自动增加数字序列的意思,也就是序列号,序列号自动增加不能重置,因此需要利用drop sequence语句来删除序列。

oracle怎么查询数据类型oracle怎么查询数据类型May 13, 2022 pm 04:19 PM

在oracle中,可以利用“select ... From all_tab_columns where table_name=upper('表名') AND owner=upper('数据库登录用户名');”语句查询数据库表的数据类型。

oracle查询怎么不区分大小写oracle查询怎么不区分大小写May 10, 2022 pm 05:45 PM

方法:1、利用“LOWER(字段值)”将字段转为小写,或者利用“UPPER(字段值)”将字段转为大写;2、利用“REGEXP_LIKE(字符串,正则表达式,'i')”,当参数设置为“i”时,说明进行匹配不区分大小写。

Oracle怎么修改sessionOracle怎么修改sessionMay 13, 2022 pm 05:06 PM

方法:1、利用“alter system set sessions=修改后的数值 scope=spfile”语句修改session参数;2、修改参数之后利用“shutdown immediate – startup”语句重启服务器即可生效。

See all articles

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

AI Hentai Generator

AI Hentai Generator

免費產生 AI 無盡。

熱門文章

R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
3 週前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳圖形設置
3 週前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您聽不到任何人,如何修復音頻
3 週前By尊渡假赌尊渡假赌尊渡假赌

熱工具

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

MantisBT

MantisBT

Mantis是一個易於部署的基於Web的缺陷追蹤工具,用於幫助產品缺陷追蹤。它需要PHP、MySQL和一個Web伺服器。請查看我們的演示和託管服務。

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

Safe Exam Browser

Safe Exam Browser

Safe Exam Browser是一個安全的瀏覽器環境,安全地進行線上考試。該軟體將任何電腦變成一個安全的工作站。它控制對任何實用工具的訪問,並防止學生使用未經授權的資源。

PhpStorm Mac 版本

PhpStorm Mac 版本

最新(2018.2.1 )專業的PHP整合開發工具