我的编程空间,编程开发者的网络收藏夹
学习永远不晚

Oracle系列:(8)单行函数

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

Oracle系列:(8)单行函数




单行函数:只有一个参数输入,只有一个结果输出

多行函数或分组函数:可有多个参数输入,只有一个结果输出


测试lower/upper/initcap函数,使用dual哑表

select lower('www.BAIdu.COM') from dual;
select upper('www.BAIdu.COM') from dual;
select initcap('www.BAIdu.COM') from dual;

Oracle系列:(8)单行函数


测试concat/substr函数,从1开始,表示字符,不论中英文

select concat('hello','你好') from dual;正确

select concat('hello','你好','世界') from dual;错误

select 'hello' || '你好' || '世界' from dual;正确

select concat('hello',concat('你好','世界')) from dual;正确

select substr('hello你好',5,3) from dual;

5表示从第几个字符开始算,第一个字符为1,中英文统一处理

3表示连续取几个字符

Oracle系列:(8)单行函数


测试length/lengthb函数,编码方式为UTF8/GBK,一个中文占3/2个字节长度,一个英文一个字节

select length('hello你好') from dual; 
select lengthb('hello你好') from dual;

Oracle系列:(8)单行函数

 


测试instr/lpad/rpad函数,从左向右找第一次出现的位置,从1开始

select instr('helloworld','o') from dual;

注意:找不到返回0,大小写敏感 

select LPAD('hello',10,'#') from dual;
select RPAD('hello',10,'#') from dual;

Oracle系列:(8)单行函数


测试trim/replace函数

select trim(' ' from '  he  ll                ') from dual;
select replace('hello','l','L') from dual;

Oracle系列:(8)单行函数


测试round/trunc/mod函数作用于数值型

select round(3.1415,3) from dual;
select trunc(3.1415,3) from dual;
select mod(10,3) from dual;

Oracle系列:(8)单行函数



当前日期:

 select sysdate from dual;

Oracle系列:(8)单行函数



测试round作用于日期型(month)

select round(sysdate,'month') from dual;

Oracle系列:(8)单行函数


测试round作用于日期型(year)

select round(sysdate,'year') from dual;

Oracle系列:(8)单行函数


测试trunc作用于日期型(month)

select trunc(sysdate,'month') from dual;

Oracle系列:(8)单行函数


测试trunc作用于日期型(year)

select trunc(sysdate,'year') from dual;

Oracle系列:(8)单行函数


显示昨天,今天,明天的日期,日期类型 +- 数值 = 日期类型

select sysdate-1 "昨天",sysdate "今天",sysdate+1 "明天" from dual;

Oracle系列:(8)单行函数


以年和月形式显示员工近似工龄,日期-日期=数值,假设:一年以365天计算,一月以30天计算

select ename "姓名",round(sysdate-hiredate,0)/365 "工龄" from emp;

Oracle系列:(8)单行函数



使用months_between函数,精确计算到年底还有多少个月

select months_between('31-12月-16',sysdate) from dual;

Oracle系列:(8)单行函数


使用months_between函数,以精确月形式显示员工工龄

select ename "姓名",months_between(sysdate,hiredate) "精确月工龄" from emp;

Oracle系列:(8)单行函数


测试add_months函数,下个月今天是多少号

select add_months(sysdate,1) from dual;

Oracle系列:(8)单行函数


测试add_months函数,上个月今天是多少号

select add_months(sysdate,-1) from dual;

Oracle系列:(8)单行函数


测试next_day函数,从今天开始算,下一个星期三是多少号【中文平台】

select next_day(sysdate,'星期三') from dual;

Oracle系列:(8)单行函数

Oracle系列:(8)单行函数


测试next_day函数,从今天开始算,下下一个星期三是多少号【中文平台】

select next_day(next_day(sysdate,'星期三'),'星期三') from dual;

Oracle系列:(8)单行函数


测试next_day函数,从今天开始算,下一个星期三的下一个星期日是多少号【中文平台】

select next_day(next_day(sysdate,'星期三'),'星期日') from dual;

Oracle系列:(8)单行函数


测试last_day函数,本月最后一天是多少号

select last_day(sysdate) from dual;

Oracle系列:(8)单行函数


测试last_day函数,本月倒数第二天是多少号

select last_day(sysdate)-1 from dual;

Oracle系列:(8)单行函数


测试last_day函数,下一个月最后一天是多少号

select last_day(add_months(sysdate,1)) from dual;

Oracle系列:(8)单行函数


测试last_day函数,上一个月最后一天是多少号

select last_day(add_months(sysdate,-1)) from dual;

Oracle系列:(8)单行函数


注意:

1)日期-日期=天数

2)日期+-天数=日期







免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

Oracle系列:(8)单行函数

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

Oracle中单行函数操作详解

单行函数--PL/SQL (一)字符函数 函    数           说               明  CONCAT 拼接两个字符串,与 || 相同  INITCAP
Oracle中单行函数操作详解
2017-01-27

MySQL函数1(单行函数)

单行函数函数的理解分类数值函数基本函数PI()无参数CETL CETLING()天花板函数(取比自己大的相邻的数)FLOOR()地板函数(取比自己小的相邻的数)RAND()无参数:随机;RAND(参数):一个固定的随机数单行函数可以嵌套角度与弧度的互换函数三
MySQL函数1(单行函数)
2018-03-23

oracle中怎么用unpivot函数实现列转行

在Oracle中,可以使用UNPIVOT函数将多列转换为单列。以下是一个示例,假设有一个包含学生姓名、数学成绩和英语成绩的表格:CREATE TABLE student_scores (student_name VARCHAR2(50),
oracle中怎么用unpivot函数实现列转行
2024-04-09

mysql行列转换函数

摘要: mysql行列转换函数提供方法在行和列之间转换数据,用于数据分析和报表生成。其主要函数包括:pivot: 将行数据转换为列数据,语法:pivot ( sum(value_to_sum) for column_to_group_by
mysql行列转换函数
2024-08-01

编程热搜

目录