Loading [MathJax]/jax/output/CommonHTML/fonts/TeX/AMS-Regular.js
前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
社区首页 >专栏 >oracle(1)基础总结

oracle(1)基础总结

作者头像
Dlimeng
发布于 2023-06-27 08:02:58
发布于 2023-06-27 08:02:58
2650
举报
文章被收录于专栏:开源心路开源心路

以scott用户下的表emp为例

--------------------------------------------------------------------------------------------------------where

查询emp表的不重复的工作

select distinct job from emp

查询工资不等于1500的员工【!=或<>】

select * from emp where sal <> 1500

查询薪水在1300到1600之间的员工,包括1300和1600

select * from emp where sal between 1300 and 1600;

查询薪水不在1300到1600之间的员工,不包括1300和1600

select * from emp where sal NOT between 1300 and 1600;

查询入职时间在指定的时间段的员工

select * from emp where hiredate between '1981/6/9' and '1987/4/19';

或者

select * from emp where hiredate   between  to_date('1981/2/20','yyyy/mm/dd') and to_date('1987-4-19','yyyy/mm/dd');

查询20号或30号部门的员工,例如:根据ID号,选中的员工,批量删除 select * from emp where (deptno=20) or (deptno=30); 或 select * from emp where deptno in (30,20);

查询不是20号或30号部门的员工 select * from emp where deptno NOT in (30,20);

查询员工姓名中含有'_'的员工,使用\转义符,让其后的字符回归本来意思【like '%\_%' escape '\'】

select * from emp where ename like '%\_%' escape '\';

查询佣金为null的员工 select * from emp where comm is null; 注意:null不能参数=运算       null能参数number/date/varchar2类型运算

--------------------------------------------------------------------------------------------------------order by

查询员工信息,按入职日期降序排序,使用列名 select empno,ename,sal,hiredate,sal*12 "年薪" from emp order by hiredate desc;

--------------------------------------------------------------------------------------------------------单行函数

测试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;

测试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表示连续取几个字符

测试length/lengthb函数,编码方式为UTF8/GBK(赵君),一个中文占3/2个字节长度,一个英文一个字节 select length('hello你好') from dual; select lengthb('hello你好') from dual;

测试instr/lpad/rpad函数,从左向右找第一次出现的位置,从1开始 select instr('helloworld','o') from dual; 注意:找不到返回0       大小写敏感 select LPAD('hello',10,'#') from dual; --左加‘#’长度10 select RPAD('hello',10,'#') from dual;--右加‘#’长度10

测试trim/replace函数 select trim(' ' from '  he  ll                ') from dual; select replace('hello','l','L') from dual;

测试round/trunc/mod函数作用于数值型 select round(3.1415,3) from dual; select trunc(3.1415,3) from dual; select mod(10,3) from dual;

当前日期:sysdate = 2016/5/24

测试round作用于日期型(month) select round(sysdate,'month') from dual;    --2016/6/1

测试round作用于日期型(year) select round(sysdate,'year') from dual; --2016/1/1

测试trunc作用于日期型(month) select trunc(sysdate,'month') from dual; --2016/5/1

测试trunc作用于日期型(year) select trunc(sysdate,'year') from dual; --2016/1/1

显示昨天,今天,明天的日期,日期类型 +- 数值 = 日期类型 select sysdate-1 "昨天",sysdate "今天",sysdate+1 "明天" from dual;

以年和月形式显示员工近似工龄,日期-日期=数值,假设:一年以365天计算,一月以30天计算 select ename "姓名",round(sysdate-hiredate,0)/365 "天数" from emp;

使用months_between函数,精确计算到年底还有多少个月 select months_between('31-12月-15',sysdate) from dual;

使用months_between函数,以精确月形式显示员工工龄 select ename "姓名",months_between(sysdate,hiredate) "精确月工龄" from emp;

测试add_months函数,下个月今天是多少号 select add_months(sysdate,1) from dual;

测试add_months函数,上个月今天是多少号 select add_months(sysdate,-1) from dual;

测试next_day函数,从今天开始算,下一个星期三是多少号【中文平台】 select next_day(sysdate,'星期三') from dual;

测试next_day函数,从今天开始算,下下一个星期三是多少号【中文平台】 select next_day(next_day(sysdate,'星期三'),'星期三') from dual;

测试next_day函数,从今天开始算,下一个星期三的下一个星期日是多少号【中文平台】 select next_day(next_day(sysdate,'星期三'),'星期日') from dual;

测试last_day函数,本月最后一天是多少号 select last_day(sysdate) from dual;

测试last_day函数,本月倒数第二天是多少号 select last_day(sysdate)-1 from dual;

测试last_day函数,下一个月最后一天是多少号 select last_day(add_months(sysdate,1)) from dual;

测试last_day函数,上一个月最后一天是多少号 select last_day(add_months(sysdate,-1)) from dual;

注意: 1)日期-日期=天数 2)日期+-天数=日期

--------------------------------------------------------------------------------------------------------三大类型转换

oracle中三大类型与隐式数据类型转换 (1)varchar2变长/char定长-->number,例如:'123'->123 (2)varchar2/char-->date,例如:'25-4月-15'->'25-4月-15' (3)number---->varchar2/char,例如:123->'123' (4)date------>varchar2/char,例如:'25-4月-15'->'25-4月-15'

查询1980年12月17日入职的员工(方式一:日期隐示式转换) select * from emp where hiredate = '17-12月-80';

使用to_char(日期,'格"常量"式')函数将日期转成字符串,显示如下格式:2015 年 04 月 25 日 星期六 select to_char(sysdate,'yyyy" 年 "mm" 月 "dd" 日 "day') from dual;

使用to_char(日期,'格式')函数将日期转成字符串,显示如格式:2015-04-25今天是星期六 15:15:15 select to_char(sysdate,'yyyy-mm-dd"今天是"day hh24:mi:ss') from dual; 或 select to_char(sysdate,'yyyy-mm-dd"今天是"day HH12:MI:SS AM') from dual;

使用to_char(数值,'格式')函数将数值转成字符串,显示如下格式:1,234selecttochar(1234,9,999') from dual;

使用to_char(数值,'格式')函数将数值转成字符串,显示如下格式:¥1,234

select to_char(1234,'$9,999') from dual; select to_char(1234,'L9,999') from dual;

使用to_date('字符串','格式')函数,查询1980年12月17日入职的员工(方式二:日期显式转换) select * from emp where hiredate = to_date('1980年12月17日','yyyy"年"mm"月"dd"日"'); 或 select * from emp where hiredate = to_date('1980#12#17','yyyy"#"mm"#"dd'); 或 select * from emp where hiredate = to_date('1980-12-17','yyyy-mm-dd');

使用to_number('字符串')函数将字符串‘123’转成数字123 select to_number('123') from dual;

注意: select '123' + 123 from dual;246 select '123' || 123 from dual;123123

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2016-05-24,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
SpringBoot入门建站全系列(三十五)整合Oauth2做单机版认证授权
OAuth 2.0 规范定义了一个授权(delegation)协议,对于使用Web的应用程序和API在网络上传递授权决策非常有用。OAuth被用在各钟各样的应用程序中,包括提供用户认证的机制。
品茗IT
2020/05/28
1.4K0
SpringBoot入门建站全系列(二十)SpringDataJpa使用乐观锁与悲观锁
之前有两篇《SpringBoot入门建站全系列(五)使用Spring-data-jpa操作数据库CRUD》和《SpringBoot入门建站全系列(六)Spring-data-jpa进阶使用》介绍了Spring如何结合Spring-data-jpa进行数据库访问操作。这一篇介绍下springboot环境下spring-data-jpa如何进行乐观锁、悲观锁的使用。
品茗IT
2019/08/26
1.4K0
Spring Boot与Kotlin使用Spring Data Rest创建HAL风格Restful接口
REST web服务已成为在web上应用程序集成的首选方式。在其核心中,REST定义了系统由客户端交互的资源组成。这些资源以超媒体驱动的方式实现。Spring MVC为构建这些服务提供了坚实的基础。但是,对于多域对象系统,即使实施REST web服务的最简单原则也可能相当乏味,并且导致大量样板代码。
全科
2018/08/15
8460
Spring Boot 中 10 行代码构建 RESTful 风格应用
RESTful ,到现在相信已经没人不知道这个东西了吧!关于 RESTful 的概念,我这里就不做过多介绍了,传统的 Struts 对 RESTful 支持不够友好 ,但是 SpringMVC 对于 RESTful 提供了很好的支持,常见的相关注解有:
江南一点雨
2019/06/13
1.3K0
使用 spring data rest 快速构建 restful api,再也不用加班了
REST是一种设计风格(与具体的语言无关),它的URL主体是资源,是个名词。而且也仅支持HTTP协议,规定了使用HTTP Method表达本次要做的动作,类型一般也不超过那四五种。这些动作表达了对资源仅有的几种转化方式。
双鬼带单
2018/08/01
5.1K0
使用 spring data rest 快速构建 restful api,再也不用加班了
是时候解放一下广大程序员的双手了
作为靠双手吃饭的广大程序猿媛们,大家基本都是从数据库的增删改查一步一步过来的,每天都有写不完的代码,好不容易写完了,又会因为改了需求,为了能完工不得不加班写这些简单并且耗时的代码。
小柒2012
2020/05/14
5760
Spring Data REST不完全指南(三)
上一篇我们介绍了使用Spring Data REST时的一些高级特性,以及使用代码演示了如何使用这些高级的特性。本文将继续讲解前面我们列出来的七个高级特性中的后四个。至此,这些特性能满足我们大部分的接口开发场景。
东溪陈姓少年
2020/08/06
6790
Spring Data REST不完全指南(一)
Spring Data REST是Spring Data项目的一部分,可轻松在Spring Data存储库上构建超媒体驱动的REST Web服务。
东溪陈姓少年
2020/08/06
1.6K0
springboot+jpa+spring-data-rest 快速实现rest应用
本例使用springboot,并使用了 spring-data-rest 和 spring-data-jpa
吟风者
2020/02/10
7730
SpringBoot入门建站全系列(十三)本地缓存的使用(Ehcache和caffeine的使用)
本地缓存,就是使用应用内使用本地内存将数据暂缓存储,一般数据库的查询如果不怎么改动,可以用本地缓存暂存。
品茗IT
2019/09/12
6750
SpringBoot入门建站全系列(十九)集成Activiti做工作流
Activiti作为一个流行的开源工作流引擎,正在不断发展,其6.0版本以API形式提供服务,而之前版本基本都是要求我们的应用以JDK方式与其交互,只能将其携带到我们的应用中,而API方式则可以服务器独立运行方式,能够形成一个专网内工作流引擎资源共享的方式。
品茗IT
2019/08/23
1.2K0
SpringBoot入门建站全系列(十二)Spring Security使用token做认证
Spring 是一个非常流行和成功的 Java 应用开发框架。Spring Security 基于 Spring 框架,提供了一套 Web 应用安全性的完整解决方案。一般来说,Web 应用的安全性包括用户认证(Authentication)和用户授权(Authorization)两个部分。用户认证指的是验证某个用户是否为系统中的合法主体,也就是说用户能否访问该系统。用户认证一般要求用户提供用户名和密码。系统通过校验用户名和密码来完成认证过程。用户授权指的是验证某个用户是否有权限执行某个操作。在一个系统中,不同用户所具有的权限是不同的。比如对一个文件来说,有的用户只能进行读取,而有的用户可以进行修改。一般来说,系统会为不同的用户分配不同的角色,而每个角色则对应一系列的权限。
品茗IT
2019/08/14
3.4K0
Spring Data REST不完全指南(二)
上一篇文章介绍了Spring Data REST的功能及特征,以及演示了如何在项目中引入Spring Data REST并简单地启动演示了Spring Data REST项目。在本文中,我们将深入了解Spring Data REST的特性,以此来满足我们日常api开发工作的要求。
东溪陈姓少年
2020/08/06
1.2K0
SpringBoot入门建站全系列(十一)Spring-security进行权限认证
Spring 是一个非常流行和成功的 Java 应用开发框架。Spring Security 基于 Spring 框架,提供了一套 Web 应用安全性的完整解决方案。一般来说,Web 应用的安全性包括用户认证(Authentication)和用户授权(Authorization)两个部分。用户认证指的是验证某个用户是否为系统中的合法主体,也就是说用户能否访问该系统。用户认证一般要求用户提供用户名和密码。系统通过校验用户名和密码来完成认证过程。用户授权指的是验证某个用户是否有权限执行某个操作。在一个系统中,不同用户所具有的权限是不同的。比如对一个文件来说,有的用户只能进行读取,而有的用户可以进行修改。一般来说,系统会为不同的用户分配不同的角色,而每个角色则对应一系列的权限。
品茗IT
2019/09/12
2.2K0
Spring Data REST 与 Spring RestTemplate 实战详解
这篇分为两部分内容进行介绍(Spring Data REST 和 Spring RestTemplate)。我之前有一篇文章完整的介绍了 HTTP 协议的内容,而这两个工具中一个帮我们完成 Client 的实现,另一个帮我们完成 Server端的实现。 希望大家对 Spring 和 HTTP 之间有个完整的认识,并能够优雅地使用。 RestTemplate 认识 RestTemplate org.springframework.web.client.RestTemplate 位于 spring-web 的核
CSDN技术头条
2018/03/26
5.5K0
Spring Data REST 与 Spring RestTemplate 实战详解
SpringBoot使用Spring Data REST快速构建restful应用
REST Web服务已经成为Web上应用程序集成的第一大手段。 REST的核心是定义一个包含与客户端进行交互资源的系统。 这些资源以超媒体驱动的方式实现。
烂猪皮
2023/09/04
4310
SpringBoot使用Spring Data REST快速构建restful应用
SpringBoot入门建站全系列(十二)Spring Security使用token做认证
Spring 是一个非常流行和成功的 Java 应用开发框架。Spring Security 基于 Spring 框架,提供了一套 Web 应用安全性的完整解决方案。一般来说,Web 应用的安全性包括用户认证(Authentication)和用户授权(Authorization)两个部分。用户认证指的是验证某个用户是否为系统中的合法主体,也就是说用户能否访问该系统。用户认证一般要求用户提供用户名和密码。系统通过校验用户名和密码来完成认证过程。用户授权指的是验证某个用户是否有权限执行某个操作。在一个系统中,不同用户所具有的权限是不同的。比如对一个文件来说,有的用户只能进行读取,而有的用户可以进行修改。一般来说,系统会为不同的用户分配不同的角色,而每个角色则对应一系列的权限。
品茗IT
2019/09/12
8670
SpringBoot入门建站全系列(十一)Spring-security进行权限认证
Spring 是一个非常流行和成功的 Java 应用开发框架。Spring Security 基于 Spring 框架,提供了一套 Web 应用安全性的完整解决方案。一般来说,Web 应用的安全性包括用户认证(Authentication)和用户授权(Authorization)两个部分。用户认证指的是验证某个用户是否为系统中的合法主体,也就是说用户能否访问该系统。用户认证一般要求用户提供用户名和密码。系统通过校验用户名和密码来完成认证过程。用户授权指的是验证某个用户是否有权限执行某个操作。在一个系统中,不同用户所具有的权限是不同的。比如对一个文件来说,有的用户只能进行读取,而有的用户可以进行修改。一般来说,系统会为不同的用户分配不同的角色,而每个角色则对应一系列的权限。
品茗IT
2019/08/13
4510
SpringBoot入门建站全系列(三十一)atomikos实现多数据源的分布式事务
本篇使用atomikos做多数据源的分布式事务,基于Mysql的xa事务数据源,通过atomikos的事务管理器完成。并使用mybatis作为数据库中间件。
品茗IT
2020/05/28
1.8K0
SpringCloud微服务实战系列(十八)Ouath2在真实场景中的应用之授权服务器
在《SpringCloud微服务实战系列(十七)Ouath2在真实场景中的应用之资源服务器》]中
品茗IT
2020/05/28
1.5K0
推荐阅读
相关推荐
SpringBoot入门建站全系列(三十五)整合Oauth2做单机版认证授权
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
查看详情【社区公告】 技术创作特训营有奖征文