ORACLE SQL单行函数(二)【weber出品必属精品】

时间:2022-11-08 21:42:05

11.dual:虚表,任何用户都可以使用,表结构如下:

SQL> desc dual
Name Null? Type
----------------------------------------- -------- ----------------------------
DUMMY VARCHAR2()

12.dual的作用:

1. 查询数据库系统日期

2. 进行四则运算

SQL> select sysdate from dual;  ---这里查询数据库系统日期

SYSDATE
---------
-AUG-
SQL> select * from dual; ---这里进行四则运算 *
---------- SQL> select 'abc' from dual; ---这里进行字符串的输出 'AB
---
abc

13.日期的格式:

默认的格式:DD-MON-RR

如何改变日期的格式:nls_date_format

SQL> alter session set nls_date_format='yyyy--mm--dd hh24:mi:ss';   ---修改日期格式

Session altered.

SQL> select sysdate from dual;

SYSDATE
---------------------
---- ::

14.日期的计算

两个日期相减得到是天数:

SQL> select sysdate,hiredate,sysdate-hiredate from emp;

SYSDATE             HIREDATE            SYSDATE-HIREDATE
------------------- ------------------- ----------------
-- :: -- :: 12294.3832
-- :: -- :: 12229.3832
-- :: -- :: 12227.3832
-- :: -- :: 12188.3832
-- :: -- :: 12009.3832
-- :: -- :: 12159.3832
-- :: -- :: 12120.3832
-- :: -- :: 9980.38319
-- :: -- :: 11959.3832
-- :: -- :: 12029.3832
-- :: -- :: 9946.38319
-- :: -- :: 11943.3832
-- :: -- :: 11943.3832
-- :: -- :: 11892.3832

计算周数只需要除以7即可

SQL> select sysdate,hiredate,sysdate-hiredate from emp;

SYSDATE             HIREDATE            SYSDATE-HIREDATE
------------------- ------------------- ----------------
-- :: -- :: 12294.3832
-- :: -- :: 12229.3832
-- :: -- :: 12227.3832
-- :: -- :: 12188.3832
-- :: -- :: 12009.3832
-- :: -- :: 12159.3832
-- :: -- :: 12120.3832
-- :: -- :: 9980.38319
-- :: -- :: 11959.3832
-- :: -- :: 12029.3832
-- :: -- :: 9946.38319
-- :: -- :: 11943.3832
-- :: -- :: 11943.3832
-- :: -- :: 11892.3832

给日期减去1,效果作用在天上

SQL> select hiredate,hiredate- from emp;

HIREDATE          HIREDATE-
--------------------- ---------------------
---- :: ---- ::
---- :: ---- ::
---- :: ---- ::
---- :: ---- ::
---- :: ---- ::
---- :: ---- ::

减少一小时,增加也是一样:

SQL> select sysdate,sysdate-/() from dual;

SYSDATE           SYSDATE-/()
--------------------- ---------------------
---- :: ---- ::

增加一分钟:

SQL> select sysdate ,sysdate+/(*) from dual;

SYSDATE           SYSDATE+/(*)
--------------------- ---------------------
---- :: ---- ::

增加一秒钟:

SQL> select sysdate,sysdate+/(**) from dual;

SYSDATE             SYSDATE+/(**
------------------- -------------------
-- :: -- ::

15.日期函数

MONTHS_BETWEEN:两个日期之间的月数

SQL> select hiredate,sysdate,months_between(sysdate,hiredate) from emp;

HIREDATE            SYSDATE             MONTHS_BETWEEN(SYSDATE,HIREDATE)
------------------- ------------------- --------------------------------
-- :: -- :: 403.947992
-- :: -- :: 401.851218
-- :: -- :: 401.786701
-- :: -- :: 400.431863
-- :: -- :: 394.593153
-- :: -- :: 399.464121
-- :: -- :: 398.206056
-- :: -- :: 327.883476

ADD_MONTHS:为一个日期增加月份:

SQL> select sysdate,add_months(sysdate,) from dual;

SYSDATE           ADD_MONTHS(SYSDATE,)
--------------------- ---------------------
---- :: ---- ::

NEXT_DAY:一个日期的下一个指定日子(例如:星期五)的日期

SQL> select sysdate ,next_day(sysdate,'friday') next_day from dual;

SYSDATE           NEXT_DAY
--------------------- ---------------------
---- :: ---- ::

LAST_DAY:某个月份的最后一天

SQL> select sysdate ,last_day(sysdate) from dual;

SYSDATE           LAST_DAY(SYSDATE)
--------------------- ---------------------
---- :: ---- ::

对日期进行截取:

ROUND:要进行四舍五入

TRUNC:不进行四舍五入

SQL> select sysdate,round(sysdate) round,trunc(sysdate) trunc from dual;

SYSDATE                    ROUND                   TRUNC
--------------------- --------------------- --------------------
2014--08--15 15:21:58 2014--08--16 00:00:00 2014--08--15 00:00:00

16. 转换函数

数据类型转换方式:

1. 隐士转换,也叫自动转换

2. 显示转换,通过转换函数进行转换

TO_CHAR函数:可以把数字和日期转换为字符

TO_CHAR(date, 'format_model'):将日期转换为字符  format_model是:日期的格式

SQL> select sysdate,to_char(sysdate,'mm-dd-yyyy hh24:mi:ss') from dual;

SYSDATE           TO_CHAR(SYSDATE,'MM
--------------------- ------------------- ---按照日期格式将格式转换后输出
---- :: -- ::

Format_model:

1、日期格式必须用单引号括起来,并且是大小写敏感的

2、日期格式必须是可用的

3、前面加上 fm字符以压缩掉开始和结束的空格或者前置的零

4、同日期值用逗号隔开

SQL> select sysdate,to_char(sysdate,'YYYY') from dual;

SYSDATE           TO_C
--------------------- ----
---- ::

验证:日期格式必须用单引号括起来,并且是大小写敏感的

SQL> select sysdate,to_char(sysdate,'YEAR') from dual;

SYSDATE           TO_CHAR(SYSDATE,'YEAR')
--------------------- ------------------------------------------
---- :: TWENTY FOURTEEN SQL> select sysdate ,to_char(sysdate,'year') from dual; SYSDATE TO_CHAR(SYSDATE,'YEAR')
--------------------- ------------------------------------------
---- :: twenty fourteen

验证:简写和祥写的不同 ---日期元素区分大小写

SQL> select sysdate,to_char(sysdate,'mm'),to_char(sysdate,'month') from dual;

SYSDATE           TO TO_CHAR(SYSDATE,'MONTH')
--------------------- -- ---------------------------
---- :: august SQL> select sysdate,to_char(sysdate,'dy'),to_char(sysdate,'day') from dual; SYSDATE TO_CHAR(S TO_CHAR(SYSDATE,'DAY')
--------------------- --------- ---------------------------
---- :: fri friday SQL> select sysdate,to_char(sysdate,'DY'),to_char(sysdate,'DAY') from dual; SYSDATE TO_CHAR(S TO_CHAR(SYSDATE,'DAY')
--------------------- --------- ---------------------------
---- :: FRI FRIDAY

日期中时间部分的格式:

SQL> select sysdate,to_char(sysdate,'yyyy/mm/dd hh24:mi:ss pm')  time from dual;

SYSDATE           TIME
--------------------- ----------------------
---- :: // :: pm

增加字符串需要用双引号将字符串括起来:

SQL> select sysdate,to_char(sysdate,'day "of" month') string from dual;

SYSDATE             STRING
------------------- ---------------------------------------------
-- :: friday of august

fm:去掉日期元素前置的零和空格

SQL> select sysdate,to_char(sysdate,'fmyyyy-mm-dd hh24:mi:ss am') 去掉空格 from dual;

SYSDATE                去掉空格
--------------------- ----------------------
---- :: -- :: pm ---08前面的0被去掉了

在一个数字前面显示$符号 ---$不管在9999.99的前面还是后面,结果显示都是在9999.99的前面。

SQL> select ename,sal,to_char(sal,'9999.99$') from emp;

ENAME    SAL TO_CHAR(S
------ ----- ---------
SMITH $800.00
ALLEN $1600.00
WARD $1250.00
JONES $2975.00
MARTIN $1250.00
BLAKE $2850.00
CLARK $2450.00
SCOTT $4000.00
KING $5000.00
TURNER $1500.00
ADAMS $1100.00
JAMES $950.00
FORD $3000.00
MILLER $1300.00

如果9999.99变成了999.99,大于1000的数字则会显示乱码。

SQL> select ename,to_char(sal,'999.99') from emp;

ENAME      TO_CHAR
---------- -------
SMITH 800.00
ALLEN #######
WARD #######
JONES #######
MARTIN #######
BLAKE #######
CLARK #######
SCOTT #######
KING #######

ORACLE SQL单行函数(二)【weber出品必属精品】的更多相关文章

  1. ORACLE SQL 组函数【weber出品必属精品】

    组函数:对一组数据进行加工,每组数据返回一个值 常用的组函数:count()  avg()  max()   min()  sum()   count()函数  1. count(*) :返回总共的行 ...

  2. 创建存储过程和函数【weber出品必属精品】

    一.什么是存储过程和函数 1. 是被命名的pl/sql块 2. 被称之为pl/sql子程序 3. 与匿名块类似,有块结构: 声明部分是可选的(没有declare关键字) 必须有执行部分 可选的异常处理 ...

  3. oracle数据库事务相关【weber出品必属精品】

    事务的概念:事务:一个事务由一组构成一个逻辑操作的DML语句组成 事务有开始有结束,事务以DML语句开始,以Conmmit和Rollback结束.以下情况会使得事务结束: 1. 执行COMMIT 或者 ...

  4. 全世界最详细的图形化VMware中linux环境下oracle安装(二)【weber出品必属精品】

    <ORACLE 10.2.05版本的升级补丁安装> 首先我们解压 $ unzip p8202632_10205_LINUX.zip 解压后我们会发现多出了个文件夹,他是:Disk1,进入D ...

  5. 全世界最详细的图形化VMware中linux环境下oracle安装(一)【weber出品必属精品】

    安装流程:前期准备工作--->安装ORACLE软件--->安装升级补丁--->安装odbc创建数据库--->安装监听器--->安装EM <前期准备工作> 安装 ...

  6. ORACLE SQL单行函数(三)【weber出品必属精品】

    16.L:代表本地货币符,这个和区域有关.这个时候我们想来显示一下人民币的符号:¥ $ vi .bash_profile ---写入如下内容: export NLS_LANG='SIMPLIFIED ...

  7. ORACLE SQL单行函数(一)【weber出品必属精品】

    1.SUBSTR:求父串中的子串 SUBSTR('HelloWorld',1,5) 1:代表子串的起始位置,如果为正,正数,如果为负,倒数 5:代表字串的终止位置,只能向右数,可以省略,如果省略就是数 ...

  8. 静默安装ORACLE【weber出品必属精品】

    安装配置系统环境安装linux ,所有服务都不选择,只是选择安装开发工具,不要安装防火墙(当然也可以在后面关闭) 打开终端,执行如下命令,检查安装包,没有的都要安装 make, glibc, liba ...

  9. 全世界最详细的图形化VMware中linux环境下oracle安装(三)【weber出品必属精品】

    数据库软件和数据库都建好了,基本上可以说完成90%的工作,但是美中不足的就是企业管理器还没有安装好,现在我们就开始安装企业管理器吧. 安装之前我们先将补丁给补上.补丁我们也是采用禁默安装.补丁:p83 ...

随机推荐

  1. mac os 如何加载 Java Native&sol;Shared Library &lpar;&period;jnilib&rpar;

    1 . 问题描述 今天在开发 Java 解压.z 文件的时候 需要加载 .jnilib 文件. 总是提示 Native code library failed to load. java.lang.U ...

  2. SSM框架整合首只拦路虎——Eclipse新建Maven Project界面select an archetype 空白

    首先给大家说,本篇博客没有技术价值,纯属个人学习总结,权当给大家添加一乐.事件如有雷同,纯属巧合,莫怪! 前一段时间一直在看<淘淘商城>这个教程,里面讲的是SSM框架的一个电商项目.这不是 ...

  3. Razor语法

    1. 截取字符串  @(i.Title.Length > 18 ? i.Title.Substring(0, 18) + "" : i.Title) 2. 格式化日期  @s ...

  4. z-index 应用简单总结

    做过页面布局的同学对z-index属性应该是很熟悉了,z-index是针对网页显示中的一个特殊属性.因为显示器是显示的图案是一个二维平面,拥有x轴和y轴来表示位置属性.为了表示三维立体的概念如显示元素 ...

  5. 关于Android Context一些总结

    1.首先什么是context? 文档语焉不详,说是resource什么的,反正是没看懂,实际上可以认为它是一个指向parent对象的指针,受到那个parent对象的控制. 2.为什么需要context ...

  6. &lbrack;GDI&plus;&rsqb; C&num; ImageDown帮助类教程与源码下载 (转载)

    点击下载 ImageDown.zip 1.下载图片到本地代码如下 /// <summary> /// 编 码 人:苏飞 /// 联系方式:361983679 /// 更新网站:[url=h ...

  7. MySQL日期、时间相关内容

    欢迎和大家交流技术相关问题: 邮箱: jiangxinnju@163.com 博客园地址: http://www.cnblogs.com/jiangxinnju GitHub地址: https://g ...

  8. ThinkPad 安装 Ubuntu 18&period;10 系统 -- 高分屏各项配置与Nvdia独显驱动

    索引: 目录索引 一.机器概述 1.屏幕:14'' 2.分辨率:1920*1080 3.显卡:Intel 核显  &  Nvidia  GeForce 940MX 独显 ,双显卡 4.其它硬件 ...

  9. mysql 多个字段 order by

    mysql中,我们可以使用 ASC 或 DESC 关键字来设置查询结果是按升序或降序排列. 默认情况下,它是按升序排列. order by 后可加2个字段,用英文逗号隔开, 如A用升序, B降序,SQ ...

  10. 2017&period;7&period;4 ACM校内赛 Round 2

    这是一个向导 A - hdu 3652 B - bzoj 4152 C - bzoj 2429 D - bzoj 1087 E - bzoj 1566 F - bzoj 4043 G - bzoj 1 ...