oralce入门学习[通俗易懂]

oralce入门学习[通俗易懂]oracle的认识sql数据库语言关键字distinct关键字null连接符||比较运算符排序单行函数字符函数数值函数日期函数转换函数通用函数条件表达式多行函数

大家好,又见面了,我是你们的朋友全栈君。

oracle的认识

1.database数据库
2.数据文件 :
   数据库的数据是存储在表空间中的,有多个文件组成
3.表空间
    一个库被分为多个表空间,一个数据文件只能属于一个表空间

 sql数据库语言

1.DML(数据库操作语言)
其中包括insert,update,delete
2.DDL(数据定义语言)
数据操作语言,其语句包括create,drop,
3.DCL(数据库控制语言)grant 或者 revoke来获得许可
4.数据查询语言

关键字distinct

1.若是单行,就是单行不重复
2.若是多行就是要多行都不重复才可以

关键字null

is not null
is null

连接符 | |

比较运算符

=  (等于不是== )
>=
<=
<> 不等于(也可以是 !=)
//其他的比较运算符
between ...and 
in
like '%%'
is null
and 
or 
not 逻辑否

排序

1.在sql中可以使用 order by 或者order by desc
2.对于排序中我们可能会遇到null值的问题
--放到最前边
 SELECT * FROM emp order by sal nulls first;
 --放到最后边
 SELECT * FROM emp order by sal nulls last;

单行函数

1.字符
2.通用
3.转换
4.日期
5.数值

字符函数 

1.concat 也可以使用||
2.substr
select substr('hello',1,3) from dual;  --截取hel
3.length()
SELECT length('hel') FROM dual;
4.字符串替换
SELECT replace('hello','l','x') FROM  dual;

数值函数

5.数值函数
1.ROUND 四舍五入 ROUND(45.926,2)
2.TRUNC 截断 TRUNC(45.926,2)   45.92
3.MOD 求余 MOD(1600,300) 100

日期函数

//1.获取两个时间段的月数
select months_between(sysdate,hiredate) from emp;

//2.获取几个月后的日期
select add_months(sysdate,3) from dual;

转换函数

to_char(date,'YYYY-MM-DD')
SELECT to_char(hiredate,'yyyy-mm-dd') from emp;
SELECT to_char(hiredate,'fmyyyy-mm-dd') from emp; --可以去掉前导零

to_char(number,'format_model')

to_number
select to_number('10')+to_number('10') from dual;

to_date()
select to_date('1985-04-22','yyyy-mm-dd') from dual;

通用函数

常用的通用函数
NVL(expr1,expr2) -表示如实第一个值为空,就去第二个值
NVL2(expr1,expr2,expr3) -- 如第一个值不为空,取第一个值,否则取第二个值

-- nullif 表示如果第一个参数和第二个参数相等返回第一个值,否则返回第二个值
 select nullif(1,2) from dual;
-- 遇到第一个非空值就返回
 select COALESCE(null,2,null,null,3,5) from dual;

条件表达式

 select case ename 
        when 'SMITH' then '史密斯'
         when 'ALLEN' then '艾伦'
         else '张三'
  end            
from emp          
select decode(ename,'SMITH','史密斯','ALLEN','艾伦','张三') from emp; 

多行函数

什么是多行函数
分组函数是作用于一组函数,并对于一组数据返回一个值
AVG
SUM
MAX
MIN
COUNT
--------------------------------------------
分组函数 group by 
 SELECT deptno,count(ename),count(comm),avg(sal),max(sal) FROM emp group by deptno; 
注意:
1.如果使用分组函数,SQL只可以把group by 分组条件字段和分组函数查询出来
2.如果使用分组函数,不使用GROUP BY 只可以查询出来分组函数的值

where 和 having使用
SELECT  SUM(sal) 
FROM emp
 where sal>'2000'
GROUP BY deptno
HAVING SUM(sal)>8000  order by sum(sal) desc 

-- 查询出工资在2000以上的分组求和 并且分组后要大于8000

  

  

 

 

 

 

 

 

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/155152.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • DDL和DML的含义

    DDL表示DataDefinitionLanguage数据定义语言,主要包括CREATE,ALTER,DROP;隐性提交的,不能rollback。DML表示DataManipulationLanguage数据操作语言,主要的DML有SELECT,INSERT,UPDATE,DELETE;可以手动控制事务的开启、提交和回滚的。…

    2022年4月6日
    52
  • java激活码(JetBrains全家桶)

    (java激活码)本文适用于JetBrains家族所有ide,包括IntelliJidea,phpstorm,webstorm,pycharm,datagrip等。IntelliJ2021最新激活注册码,破解教程可免费永久激活,亲测有效,下面是详细链接哦~https://javaforall.net/100143.html…

    2022年3月21日
    119
  • pytest的使用_java直接调用方法

    pytest的使用_java直接调用方法Pytest执行用例规则Pytest在命令行中支持多种方式来运行和选择测试用例1.对某个目录下所有的用例pytest2.对模块中进行测试pytesttest_mod.py3.对文件夹进行

    2022年7月28日
    4
  • glPushMatrix()和glPopmatirx()

    原文地址:http://blog.csdn.net/tyxkzzf/article/details/40907273OpenGL有三个矩阵堆栈,分别是GL_MODELVIEW(模型视图矩阵堆栈)、GL_PROJECTION(投影矩阵堆栈)、GL_TEXTURE(纹理矩阵堆栈),用法和普通堆栈一样;这里我们只讲模型视图矩阵堆栈,OpenGL提供了相应的接口:glPushMatir

    2022年4月6日
    44
  • 火狐浏览器webdriver驱动_nvidia webdriver

    火狐浏览器webdriver驱动_nvidia webdriver文章目录IE驱动IE驱动ie驱动IEDriverServer网址ie驱动下载后面陆续更新

    2022年9月19日
    4
  • python的py文件打包成exe_python生成文件

    python的py文件打包成exe_python生成文件基本命令:cxfreezexxx.py(打包文件)–target-dirf:\dist\(打包后exe路径) 额外命令:–base-name=win32gui  消除启动exe文件出现的dos窗口 –icon=d:\xxxx.ico  添加exe文件的图标,注意,图标必须是ico格式…

    2022年10月8日
    1

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号