SQL函数

SQL是用于访问和处理数据库的标准的计算机语言,我们所使用的的是Oracle SQL

一个数据库通常包含一个或多个表,每个表有一个名字表示,下图即为一个名为“emp”的表,接下来的操作都将基于以下的表进行

## 字符函数

字符函数:主要指参数类型是字符型,不同函数返回值可能是字符型或数值型

【大小写转换】

函数 效果 结果

LOWER('SQL Course')

将大写或大小写混合的字符转换成小写 sql course

UPPER('SQL Course')

将小写写或大小写混合的字符转换大写 SQL COURSE
INITCAP('SQL Course') 将每个单词的第一个字母转换成大写,其余的字母都转换成小写 Sql course

## 字符处理函数

## 数值函数

  • DUAL:是一张虚表,不能保存任何数据,只有一个字段,一行记录。当我们不希望从任何表中读取数据,同时又想利用SQL引擎中的计算表达式的能力帮我们运算时,就可以使用DUAL表。
select ROUND(100.456,2),Round(100.456,0),Round(100.456,-1) from DUAL

## Date函数

默认的日期形式是: DD-MON-RR

我们可以在系统变量-环境变量中,添加   key = NLS_DATE_FORMAT  value = YYYY:MM:DD HH24:MI:SS  就可以正常按照‘年与日’的格式查询了!

SELECT  ename, sal, MONTHS_BETWEEN(SYSDATE,hiredate) months FROM emp ORDER BY months;
SELECT ename, sal, hiredate, ADD_MONTHS(hiredate,3) new_date FROM emp WHERE hiredate>'01-1月-82';
SELECT NEXT_DAY('2006-02-06','星期一') NEXT_DAY FROM DUAL;
SELECT LAST_DAY('02-2月-06') "LAST DAY" FROM DUAL;
SELECT  empno, hiredate, ROUND(hiredate, 'MONTH') FROM emp WHERE SUBSTR(hiredate,-2,2)='';
SELECT empno, hiredate, TRUNC(hiredate, 'MONTH') FROM emp WHERE SUBSTR(hiredate,-2,2)='';

## 转换函数

【隐式数据类型转换规则】

  • 不同的数据类型之间关联,如果不使用显式转换函数,则它会根据以下规则对数据进行隐式转换:   

    • 对于 INSERT 和 UPDATE 操作,oracle会把插入值或者更新值隐式转换为字段的数据类型
    • 对于SELECT语句,oracle会把字段的数据类型隐式转换为变量的数据类型
    • 当比较一个字符型和数值型的值时,oracle会把字符型的值隐式转换为数值型
    • 当比较字符型和日期型的数据时,oracle会把字符型转换为日期型
    • 用连接操作符 (||)时,oracle会把非字符类型的数据转换为字符类型
    • 如果字符类型的数据和非字符类型的数据(如number、date、rowid等)作算术运算,则oracle会将字符类型的数据转换为合适的数据类型,这些数据类型可能是number、date、rowid等

 【显式数据类型转换规则】

  • 通常是在字符类型、日期类型、数值类型之间进行显式转换。
  • 主要的三种显式转换函数:TO_char  TO_NUMBER TO_DATE
  • To_char(日期格式模型)
    • 必须用单引号引起来并且是大小写敏感的
    • 可以包含任何有效的日期元素
    • 使用逗号将日期型数据与日期型格式模型分隔开
    • 日期格式模型的元素
    • To_char用于日期型,用时间元素 格式化日期的事件部分
    • To_char语句中也可以通过双引号添加字符串
    • To_char作用于数值型,可以按照以下形式将数值型数据转化为变长的字符串
    • 栗子:
      SELECT ename, TO_CHAR(hiredate, 'DD Month YYYY') HIREDATE FROM  emp;
      Select To_char(sal,'$99,999') Salary from emp where ename = 'Scott'
  • To_number:可以将一个字符串转换成数值型数据

    select to_number(1999) year from dual;
  • To_Date: 将一个字符串转换成日期型数据

    select to_date('2005-01-01 13:14:20','yyyy-MM-dd HH24:mi:ss') from dual;

## 通用函数

  • 通用函数即与空值(NULL)相关的一些函数,完成对空值(NULL)的一些操作。
  • 主要包括以下函数:
    • NVL:如果expr1不是null,返回expr1,否则返回expr2

      SELECT ename, sal, comm, (sal*12)+NVL(comm,0) from emp
    • NVL2:如果expr1不是null,返回expr2,否则返回expr3
    • NULLIF:比较两个表达式,如果相等,返回null,否则,返回第一个表达式
    • COALESCE: COALESCE (表达式1, 表达式2, ...,表达式n)函数是对NVL函数的扩展。COALESCE函数的功能是返回第一个不为空的参数,参数个数不受限制。
      SELECT  ename, COALESCE(comm, 0)  comm , deptno FROM   emp;
  • 条件处理函数:
    • CASE表达式:

      SELECT ename, deptno,
      (CASE deptno
      WHEN 10 THEN '销售部'
      WHEN 20 THEN '技术部'
      WHEN 30 THEN '管理部'
      ELSE '无' END)
      deptname
      FROM emp;
    • DECODE
      SELECT ename, deptno,
      decode(deptno,
      10,'销售部',
      20,'技术部',
      30 , '管理部',
      '无') deptname
      FROM emp;

【东软实训】SQL函数的更多相关文章

  1. 【东软实训】SQL多表链接

    如果一个查询同时涉及两个以上的表,则称之为链接查询,链接查询是关系数据库中最主要的查询,主要包括等值链接查询.非等值链接查询.自身链接查询.外链接查询和复合条件链接查询. 这篇博文我们来对多表链接进行 ...

  2. 逆袭之旅DAY17.东软实训.Oracle.PLSQL.过程,函数,包,练习

    2018-07-13 14:54:46 --1.创建一个包,包含一个为雇员加薪的过程,一个为雇员减薪的过程 CREATE OR REPLACE PACKAGE pac_test1 IS PROCEDU ...

  3. 逆袭之旅DAY14.东软实训.Oracle.多表连接、分组函数、子查询

    2018-07-10 08:29:55 思考应用场景 异常数据的测试 6.显示能挣得奖金的雇员的姓名.工资.奖金,并以工资和奖金降序排列.select ename,sal,commfrom empWH ...

  4. 东软实训4-JDBC连接数据库

    JDBC(Java Data Base Connectivity,java数据库连接)是一种用于执行SQL语句的Java API,可以为多种关系数据库提供统一访问,它由一组用Java语言编写的类和接口 ...

  5. 【东软实训】SQLselect及其相关操作

    SQL select 及相关操作 SQL是用于访问和处理数据库的标准的计算机语言,我们所使用的的是Oracle SQL 一个数据库通常包含一个或多个表,每个表有一个名字表示,下图即为一个名为“emp” ...

  6. 逆袭之旅DAY16.东软实训.Oracle.索引

    2018-07-12 14:44:27 四.索引1.创建索引手动创建:create index 索引名 on 表名(列名,[列名,...])create table employee(pno numb ...

  7. 逆袭之旅DAY15.东软实训.Oracle.约束、序列、视图、索引、用户管理、角色

    2018-07-11  08:26:00 有某个学生运动会比赛信息的数据库,保存了如下的表: 运动员sporter表:(运动员编号sporterid,运动员姓名name,运动员性别sex,所属系dep ...

  8. 逆袭之旅DAY13.东软实训.Oracle.简单的查询语句.限制.排序

    2018-07-09  21:34:00 一.简单查询: .查询数据表的所有列: SELECT * FROM 表名; SELECT 列名,列名.... FROM 表名; .起别名: SELECT 列名 ...

  9. 东软实训1 -jsp内置对象及其常用方法

    JSP 的内置对象及方法详细说明 一. request 对象 客户端的请求信息被封装在 request 对象中,通过它才能了解到客户的需 求,然后做出响应.它是 HttpServletRequest ...

随机推荐

  1. js页面报错javax.servlet.jsp.PageContext cannot be resolved to a type解决

    构建了一个maven项目但是项目创建好的jsp总会报错javax.servlet.jsp.PageContext cannot be resolved to a type,但是不影响项目运行.但总归难 ...

  2. 数据库sqlite3的使用-基本语法

    一.SQL语句 如果要在程序运行过程中操作数据库中的数据,那得先学会使用SQL语句 1.什么是SQL SQL(structured query language):结构化查询语言 SQL是一种对关系型 ...

  3. Violet蒲公英

    传送门 题目要求求出给定区间内编号最小的众数,强制在线. 虽然说这是个黑题……不过我们可以用暴力分块解决它.首先先对所有数离散化,这个不影响众数.我们先预处理出每个数在前i个块内出现了多少次,再预处理 ...

  4. Tool:XMind

    ylbtech-Tool:XMind XMind 是一款非常实用的商业思维导图软件,应用全球最先进的Eclipse RCP 软件架构,全力打造易用.高效的可视化思维软件,强调软件的可扩展.跨平台.稳定 ...

  5. HDU6012:Lotus and Horticulture(扫描线)(前缀和)

    传送门 题意 给出n种植物的适宜培育温度区间[l,r],低于下限获值c,高于上限获值b,其他获值a 分析 首先考虑应该尝试选择哪些点:区间的左右端点.与区间左右端点距离0.50.5的点,这样就一定可以 ...

  6. P5107 能量采集

    传送门 官方题解 话说最后的答案忘记取模了结果连暴力都挂了可海星-- //minamoto #include<bits/stdc++.h> #define R register #defi ...

  7. Phpstorm安装和优化

    Phpstorm是php开发一个强大的IDE,但是它不是免费的需要注册码,而且界面是英文界面,对英文不太好的人有点不友好.所以这篇文章主要从phpstorm的破解和汉化来优化phpstorm. 1.首 ...

  8. Luogu P2858 [USACO06FEB]奶牛零食Treats for the Cows 【区间dp】By cellur925

    题目传送门 做完A Game以后找道区间dp练练手...结果这题没写出来(哭). 和A Game一样的性质,从两边取,但是竟然还有天数,鉴于之前做dp经常在状态中少保存一些东西,所以这次精心设计了状态 ...

  9. 使用pabot并行执行robotframework用例

    主要观点:使用pabot并行运行robotframework,可以解决:robotframework执行案例时间长的问题 解决执行案例时间长的方案: 目的: 缩短案例的运行时间 两种方法: 将大的项目 ...

  10. [UOJ388]配对树

    题解 贪心+线段树 首先如果我们知道了哪些点是关键点应该怎么搞 显然最小的匹配方案所有的边至多被经过一次 可以考虑每条边的贡献 因为我们要贡献尽量小 所以我们尽量让每条边经过的人尽量少 那么每条边被经 ...